Skip to content

Commit

Permalink
Declare project-wide useAppDispatch and useAppSelector
Browse files Browse the repository at this point in the history
`useAppDispatch` and `useAppSelector` are typed
version of `useDispatch` and `useSelector`. This change
is mostly to follow convention and make our code more
consistent overall for the few cases were it actually
helps or is required.
  • Loading branch information
Arnei committed Jan 16, 2024
1 parent 59f74b8 commit 60520b5
Show file tree
Hide file tree
Showing 28 changed files with 178 additions and 176 deletions.
6 changes: 3 additions & 3 deletions src/main/Body.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,15 @@ import Lock from "./Lock";

import { css } from '@emotion/react'

import { useSelector } from 'react-redux';
import { useAppSelector } from "../redux/store";
import { selectIsEnd } from '../redux/endSlice'
import { selectIsError } from "../redux/errorSlice";
import { settings } from '../config';

const Body: React.FC = () => {

const isEnd = useSelector(selectIsEnd)
const isError = useSelector(selectIsError)
const isEnd = useAppSelector(selectIsEnd)
const isError = useAppSelector(selectIsError)

// If we're in a special state, display a special page
// Otherwise display the normal page
Expand Down
17 changes: 8 additions & 9 deletions src/main/Cutting.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,7 @@ import CuttingActions from "./CuttingActions"
import Timeline from './Timeline';
import { fetchVideoInformation, selectCurrentlyAt, selectDuration, selectIsPlaying, selectIsMuted, selectVolume, selectIsPlayPreview, selectTitle, setClickTriggered, setCurrentlyAt, setIsPlaying, setIsMuted, setVolume, setIsPlayPreview } from '../redux/videoSlice';
import { useTranslation } from 'react-i18next';
import { useDispatch, useSelector } from 'react-redux';
import { AppDispatch } from '../redux/store';
import { useAppDispatch, useAppSelector } from "../redux/store";
import { httpRequestState } from '../types';
import { useTheme } from "../themes";
import { setError } from '../redux/errorSlice';
Expand All @@ -20,12 +19,12 @@ const Cutting: React.FC = () => {
const { t } = useTranslation();

// Init redux variables
const dispatch = useDispatch<AppDispatch>()
const videoURLStatus = useSelector((state: { videoState: { status: httpRequestState["status"] } }) => state.videoState.status);
const error = useSelector((state: { videoState: { error: httpRequestState["error"] } }) => state.videoState.error)
const duration = useSelector(selectDuration)
const dispatch = useAppDispatch();
const videoURLStatus = useAppSelector((state: { videoState: { status: httpRequestState["status"] } }) => state.videoState.status);
const error = useAppSelector((state: { videoState: { error: httpRequestState["error"] } }) => state.videoState.error)
const duration = useAppSelector(selectDuration)
const theme = useTheme();
const errorReason = useSelector((state: { videoState: { errorReason: httpRequestState["errorReason"] } }) => state.videoState.errorReason)
const errorReason = useAppSelector((state: { videoState: { errorReason: httpRequestState["errorReason"] } }) => state.videoState.errorReason)

// Try to fetch URL from external API
useEffect(() => {
Expand Down Expand Up @@ -87,8 +86,8 @@ const Cutting: React.FC = () => {

const CuttingHeader: React.FC = () => {

const title = useSelector(selectTitle)
const metadataTitle = useSelector(selectTitleFromEpisodeDc)
const title = useAppSelector(selectTitle)
const metadataTitle = useAppSelector(selectTitleFromEpisodeDc)
const theme = useTheme();

return (
Expand Down
6 changes: 3 additions & 3 deletions src/main/CuttingActions.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { ReactComponent as TrashRestore } from '../img/trash-restore.svg';

import { css } from '@emotion/react'

import { useDispatch, useSelector } from 'react-redux';
import { useAppDispatch, useAppSelector } from "../redux/store";
import {
cut, markAsDeletedOrAlive, selectIsCurrentSegmentAlive, mergeLeft, mergeRight, mergeAll
} from '../redux/videoSlice'
Expand All @@ -28,7 +28,7 @@ const CuttingActions: React.FC = () => {
const { t } = useTranslation();

// Init redux variables
const dispatch = useDispatch();
const dispatch = useAppDispatch();

/**
* General action callback for cutting actions
Expand Down Expand Up @@ -158,7 +158,7 @@ interface markAsDeleteButtonInterface {
*/
const MarkAsDeletedButton : React.FC<markAsDeleteButtonInterface> = ({actionHandler, action, hotKeyName}) => {
const { t } = useTranslation();
const isCurrentSegmentAlive = useSelector(selectIsCurrentSegmentAlive)
const isCurrentSegmentAlive = useAppSelector(selectIsCurrentSegmentAlive)
const ref = React.useRef<HTMLDivElement>(null)

const theme = useTheme();
Expand Down
6 changes: 3 additions & 3 deletions src/main/Discard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { basicButtonStyle, backOrContinueStyle, navigationButtonStyle, flexGapRe

import { LuChevronLeft, LuXCircle } from "react-icons/lu";

import { useDispatch, useSelector } from 'react-redux';
import { useAppDispatch, useAppSelector } from "../redux/store";
import { selectFinishState } from '../redux/finishSlice'
import { setEnd } from '../redux/endSlice'

Expand All @@ -22,7 +22,7 @@ const Discard : React.FC = () => {

const { t } = useTranslation();

const finishState = useSelector(selectFinishState)
const finishState = useAppSelector(selectFinishState)

const cancelStyle = css({
display: finishState !== "Discard changes" ? 'none' : 'flex',
Expand Down Expand Up @@ -53,7 +53,7 @@ const DiscardButton : React.FC = () => {
const { t } = useTranslation();

// Initialize redux variables
const dispatch = useDispatch()
const dispatch = useAppDispatch();
const theme = useTheme();

const discard = () => {
Expand Down
10 changes: 5 additions & 5 deletions src/main/Error.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { css } from '@emotion/react'

import { LuFrown } from "react-icons/lu";

import { useSelector } from 'react-redux';
import { useAppSelector } from "../redux/store";
import { selectErrorDetails, selectErrorIcon, selectErrorMessage, selectErrorTitle } from '../redux/errorSlice'
import { flexGapReplacementStyle } from "../cssStyles";

Expand All @@ -19,10 +19,10 @@ const Error : React.FC = () => {
const { t } = useTranslation();

// Init redux variables
const errorTitle = useSelector(selectErrorTitle)
const errorMessage = useSelector(selectErrorMessage)
const errorDetails = useSelector(selectErrorDetails)
const ErrorIcon = useSelector(selectErrorIcon)
const errorTitle = useAppSelector(selectErrorTitle)
const errorMessage = useAppSelector(selectErrorMessage)
const errorDetails = useAppSelector(selectErrorDetails)
const ErrorIcon = useAppSelector(selectErrorIcon)

const detailsStyle = css({
display: 'flex',
Expand Down
6 changes: 3 additions & 3 deletions src/main/Finish.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import { basicButtonStyle, navigationButtonStyle } from '../cssStyles'

import { IconType } from "react-icons";

import { useDispatch, useSelector } from 'react-redux';
import { useAppDispatch, useAppSelector } from "../redux/store";
import { selectPageNumber, setPageNumber } from '../redux/finishSlice';
import { useTheme } from "../themes";
import { settings } from "../config";
Expand All @@ -24,7 +24,7 @@ import { useTranslation } from "react-i18next";
*/
const Finish : React.FC = () => {

const pageNumber = useSelector(selectPageNumber)
const pageNumber = useAppSelector(selectPageNumber)

const pageZeroStyle = css({
display: pageNumber !== 0 ? 'none' : 'block',
Expand Down Expand Up @@ -63,7 +63,7 @@ export const PageButton : React.FC<{pageNumber: number, label: string, Icon: Ico
const theme = useTheme();

// Initialize redux variables
const dispatch = useDispatch()
const dispatch = useAppDispatch();

const onPageChange = () => {
dispatch(setPageNumber(pageNumber))
Expand Down
4 changes: 2 additions & 2 deletions src/main/FinishMenu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { basicButtonStyle, flexGapReplacementStyle, tileButtonStyle } from '../c
import { IconType } from "react-icons";
import { LuSave, LuDatabase, LuXCircle } from "react-icons/lu";

import { useDispatch } from 'react-redux';
import { useAppDispatch } from "../redux/store";
import { setState, setPageNumber, finish } from '../redux/finishSlice'

import { useTranslation } from 'react-i18next';
Expand Down Expand Up @@ -41,7 +41,7 @@ const FinishMenuButton: React.FC<{Icon: IconType, stateName: finish["value"]}> =

const { t } = useTranslation();
const theme = useTheme()
const dispatch = useDispatch();
const dispatch = useAppDispatch();

const finish = () => {
dispatch(setState(stateName));
Expand Down
4 changes: 2 additions & 2 deletions src/main/Header.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import React from "react";
import { useSelector } from "react-redux"
import { useAppSelector } from "../redux/store";
import { useTheme } from "../themes";

import { css } from '@emotion/react'
Expand All @@ -22,7 +22,7 @@ function Header() {
const { scheme } = useColorScheme();
const { t } = useTranslation()

const isEnd = useSelector(selectIsEnd)
const isEnd = useAppSelector(selectIsEnd)

const headerStyle = css({
display: 'flex',
Expand Down
14 changes: 7 additions & 7 deletions src/main/Lock.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React, { useEffect } from "react";
import { LuLock } from "react-icons/lu";

import { useDispatch, useSelector } from "react-redux";
import { useAppDispatch, useAppSelector } from "../redux/store";
import { settings } from "../config";
import { setLock, video } from "../redux/videoSlice";
import { selectIsEnd } from '../redux/endSlice'
Expand All @@ -13,12 +13,12 @@ import { useBeforeunload } from 'react-beforeunload';
const Lock: React.FC = () => {
const endpoint = `${settings.opencast.url}/editor/${settings.id}/lock`

const dispatch = useDispatch();
const lockingActive = useSelector((state: { videoState: { lockingActive: video["lockingActive"] } }) => state.videoState.lockingActive);
const lockRefresh = useSelector((state: { videoState: { lockRefresh: video["lockRefresh"] } }) => state.videoState.lockRefresh);
const lockState = useSelector((state: { videoState: { lockState: video["lockState"] } }) => state.videoState.lockState);
const lock = useSelector((state: { videoState: { lock: video["lock"] } }) => state.videoState.lock);
const isEnd = useSelector(selectIsEnd)
const dispatch = useAppDispatch();
const lockingActive = useAppSelector((state: { videoState: { lockingActive: video["lockingActive"] } }) => state.videoState.lockingActive);
const lockRefresh = useAppSelector((state: { videoState: { lockRefresh: video["lockRefresh"] } }) => state.videoState.lockRefresh);
const lockState = useAppSelector((state: { videoState: { lockState: video["lockState"] } }) => state.videoState.lockState);
const lock = useAppSelector((state: { videoState: { lock: video["lock"] } }) => state.videoState.lock);
const isEnd = useAppSelector(selectIsEnd)

function requestLock() {
const form = `user=${lock.user}&uuid=${lock.uuid}`;
Expand Down
10 changes: 5 additions & 5 deletions src/main/MainContent.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import { LuWrench } from "react-icons/lu";

import { css } from '@emotion/react'

import { useSelector } from 'react-redux'
import { useAppSelector } from "../redux/store";
import { selectMainMenuState } from '../redux/mainMenuSlice'

import { MainMenuStateNames } from '../types'
Expand All @@ -30,10 +30,10 @@ import Cutting from "./Cutting";
*/
const MainContent: React.FC = () => {

const mainMenuState = useSelector(selectMainMenuState)
const videoChanged = useSelector(videoSelectHasChanges)
const metadataChanged = useSelector(metadataSelectHasChanges)
const subtitleChanged = useSelector(selectSubtitleHasChanges)
const mainMenuState = useAppSelector(selectMainMenuState)
const videoChanged = useAppSelector(videoSelectHasChanges)
const metadataChanged = useAppSelector(metadataSelectHasChanges)
const subtitleChanged = useAppSelector(selectSubtitleHasChanges)
const theme = useTheme()

// Display warning when leaving the page if there are unsaved changes
Expand Down
6 changes: 3 additions & 3 deletions src/main/MainMenu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import { LuScissors, LuFilm, LuFileText, LuCheckSquare } from "react-icons/lu";
import { LuImage } from "react-icons/lu";
import { ReactComponent as SubtitleIcon } from '../img/subtitle.svg';

import { useDispatch, useSelector } from 'react-redux'
import { useAppDispatch, useAppSelector } from "../redux/store";
import { setState, selectMainMenuState, mainMenu } from '../redux/mainMenuSlice'
import { setPageNumber } from '../redux/finishSlice'

Expand Down Expand Up @@ -109,8 +109,8 @@ export const MainMenuButton: React.FC<mainMenuButtonInterface> = ({
iconCustomCSS,
}) => {

const dispatch = useDispatch();
const activeState = useSelector(selectMainMenuState)
const dispatch = useAppDispatch();
const activeState = useAppSelector(selectMainMenuState)
const theme = useTheme();

const onMenuItemClicked = () => {
Expand Down
15 changes: 7 additions & 8 deletions src/main/Metadata.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import React, { useEffect } from "react";
import { css } from '@emotion/react'
import { calendarStyle, errorBoxStyle, selectFieldStyle, titleStyle, titleStyleBold } from '../cssStyles'

import { useSelector, useDispatch } from 'react-redux';
import { useAppDispatch, useAppSelector } from "../redux/store";
import {
fetchMetadata, postMetadata, selectCatalogs,
Catalog, MetadataField, setFieldValue, selectGetError, selectGetStatus, selectPostError, selectPostStatus, setFieldReadonly
Expand All @@ -17,7 +17,6 @@ import { useTranslation } from 'react-i18next';
import { DateTime as LuxonDateTime} from "luxon";

import { configureFieldsAttributes, settings } from '../config'
import { AppDispatch } from "../redux/store";
import { useTheme } from "../themes";
import { ThemeProvider } from "@mui/material/styles";
import { cloneDeep } from "lodash";
Expand All @@ -37,12 +36,12 @@ const Metadata: React.FC = () => {
const { t, i18n } = useTranslation();

// Init redux variables
const dispatch = useDispatch<AppDispatch>()
const catalogs = useSelector(selectCatalogs);
const getStatus = useSelector(selectGetStatus);
const getError = useSelector(selectGetError);
const postStatus = useSelector(selectPostStatus);
const postError = useSelector(selectPostError);
const dispatch = useAppDispatch();
const catalogs = useAppSelector(selectCatalogs);
const getStatus = useAppSelector(selectGetStatus);
const getError = useAppSelector(selectGetError);
const postStatus = useAppSelector(selectPostStatus);
const postError = useAppSelector(selectPostError);
const theme = useTheme();

// Try to fetch URL from external API
Expand Down
31 changes: 15 additions & 16 deletions src/main/Save.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,14 @@ import { basicButtonStyle, backOrContinueStyle, ariaLive, errorBoxStyle,

import { LuLoader, LuCheckCircle, LuAlertCircle, LuChevronLeft, LuSave, LuCheck} from "react-icons/lu";

import { useDispatch, useSelector } from 'react-redux';
import { useAppDispatch, useAppSelector } from "../redux/store";
import { selectFinishState } from '../redux/finishSlice'
import { selectHasChanges, selectSegments, selectTracks, setHasChanges as videoSetHasChanges } from '../redux/videoSlice'
import { postVideoInformation, selectStatus, selectError } from '../redux/workflowPostSlice'

import { CallbackButton, PageButton } from './Finish'

import { useTranslation } from 'react-i18next';
import { AppDispatch } from "../redux/store";
import { postMetadata, selectPostError, selectPostStatus, setHasChanges as metadataSetHasChanges,
selectHasChanges as metadataSelectHasChanges } from "../redux/metadataSlice";
import { selectSubtitles, selectHasChanges as selectSubtitleHasChanges,
Expand All @@ -31,16 +30,16 @@ const Save : React.FC = () => {

const { t } = useTranslation();

const finishState = useSelector(selectFinishState)
const finishState = useAppSelector(selectFinishState)

const postWorkflowStatus = useSelector(selectStatus);
const postError = useSelector(selectError)
const postMetadataStatus = useSelector(selectPostStatus);
const postMetadataError = useSelector(selectPostError);
const postWorkflowStatus = useAppSelector(selectStatus);
const postError = useAppSelector(selectError)
const postMetadataStatus = useAppSelector(selectPostStatus);
const postMetadataError = useAppSelector(selectPostError);
const theme = useTheme();
const metadataHasChanges = useSelector(metadataSelectHasChanges)
const hasChanges = useSelector(selectHasChanges)
const subtitleHasChanges = useSelector(selectSubtitleHasChanges)
const metadataHasChanges = useAppSelector(metadataSelectHasChanges)
const hasChanges = useAppSelector(selectHasChanges)
const subtitleHasChanges = useAppSelector(selectSubtitleHasChanges)

const saveStyle = css({
height: '100%',
Expand Down Expand Up @@ -101,13 +100,13 @@ export const SaveButton: React.FC = () => {
const { t } = useTranslation();

// Initialize redux variables
const dispatch = useDispatch<AppDispatch>()
const dispatch = useAppDispatch();

const segments = useSelector(selectSegments)
const tracks = useSelector(selectTracks)
const subtitles = useSelector(selectSubtitles)
const workflowStatus = useSelector(selectStatus);
const metadataStatus = useSelector(selectPostStatus);
const segments = useAppSelector(selectSegments)
const tracks = useAppSelector(selectTracks)
const subtitles = useAppSelector(selectSubtitles)
const workflowStatus = useAppSelector(selectStatus);
const metadataStatus = useAppSelector(selectPostStatus);
const theme = useTheme();
const [metadataSaveStarted, setMetadataSaveStarted] = useState(false);

Expand Down
4 changes: 2 additions & 2 deletions src/main/Subtitle.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
import React from "react";
import SubtitleEditor from "./SubtitleEditor";
import SubtitleSelect from "./SubtitleSelect";
import { useSelector } from "react-redux";
import { useAppSelector } from "../redux/store";
import { selectIsDisplayEditView } from "../redux/subtitleSlice";

/**
* A container for the various subtitle views
*/
const Subtitle : React.FC = () => {

const displayEditView = useSelector(selectIsDisplayEditView)
const displayEditView = useAppSelector(selectIsDisplayEditView)

const render = () => {
return displayEditView ? <SubtitleEditor /> : <SubtitleSelect />;
Expand Down
Loading

0 comments on commit 60520b5

Please sign in to comment.