2020-01-13 08:03:22 +01:00
|
|
|
import { createSlice, PayloadAction } from '@reduxjs/toolkit';
|
|
|
|
|
|
2023-05-24 10:41:03 +01:00
|
|
|
import { endpoints } from 'app/features/browse-dashboards/api/browseDashboardsAPI';
|
2023-10-31 14:23:37 +00:00
|
|
|
import { FolderDTO, FolderState } from 'app/types';
|
2018-09-10 21:49:04 +02:00
|
|
|
|
2020-01-13 08:03:22 +01:00
|
|
|
export const initialState: FolderState = {
|
2018-09-11 19:00:37 +02:00
|
|
|
id: 0,
|
2018-09-11 10:36:55 +02:00
|
|
|
uid: 'loading',
|
|
|
|
|
title: 'loading',
|
2018-09-11 15:07:03 +02:00
|
|
|
url: '',
|
2018-09-11 10:36:55 +02:00
|
|
|
canSave: false,
|
2022-03-03 15:18:27 +01:00
|
|
|
canDelete: false,
|
2018-09-11 10:36:55 +02:00
|
|
|
hasChanged: false,
|
2018-09-13 10:52:29 +02:00
|
|
|
version: 1,
|
2018-09-11 10:36:55 +02:00
|
|
|
};
|
2018-09-10 21:49:04 +02:00
|
|
|
|
2023-05-24 10:41:03 +01:00
|
|
|
const loadFolderReducer = (state: FolderState, action: PayloadAction<FolderDTO>): FolderState => {
|
|
|
|
|
return {
|
|
|
|
|
...state,
|
|
|
|
|
...action.payload,
|
|
|
|
|
hasChanged: false,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2020-01-13 08:03:22 +01:00
|
|
|
const folderSlice = createSlice({
|
|
|
|
|
name: 'folder',
|
|
|
|
|
initialState,
|
|
|
|
|
reducers: {
|
2023-05-24 10:41:03 +01:00
|
|
|
loadFolder: loadFolderReducer,
|
2020-01-13 08:03:22 +01:00
|
|
|
setFolderTitle: (state, action: PayloadAction<string>): FolderState => {
|
2018-09-11 17:36:23 +02:00
|
|
|
return {
|
|
|
|
|
...state,
|
|
|
|
|
title: action.payload,
|
2018-09-11 19:00:37 +02:00
|
|
|
hasChanged: action.payload.trim().length > 0,
|
2018-09-11 17:36:23 +02:00
|
|
|
};
|
2020-01-13 08:03:22 +01:00
|
|
|
},
|
|
|
|
|
},
|
2023-05-24 10:41:03 +01:00
|
|
|
extraReducers: (builder) => {
|
|
|
|
|
builder.addMatcher(endpoints.getFolder.matchFulfilled, loadFolderReducer);
|
|
|
|
|
},
|
2020-01-13 08:03:22 +01:00
|
|
|
});
|
|
|
|
|
|
2023-10-31 14:23:37 +00:00
|
|
|
export const { loadFolder, setFolderTitle } = folderSlice.actions;
|
2020-01-13 08:03:22 +01:00
|
|
|
|
|
|
|
|
export const folderReducer = folderSlice.reducer;
|
2018-09-10 21:49:04 +02:00
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
folder: folderReducer,
|
|
|
|
|
};
|