mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 10:03:33 -06:00
* Add and configure eslint-plugin-import * Fix the lint:ts npm command * Autofix + prettier all the files * Manually fix remaining files * Move jquery code in jest-setup to external file to safely reorder imports * Resolve issue caused by circular dependencies within Prometheus * Update .betterer.results * Fix missing // @ts-ignore * ignore iconBundle.ts * Fix missing // @ts-ignore
57 lines
1.5 KiB
TypeScript
57 lines
1.5 KiB
TypeScript
import { createSlice, PayloadAction } from '@reduxjs/toolkit';
|
|
|
|
import { processAclItems } from 'app/core/utils/acl';
|
|
import { DashboardAclDTO, FolderDTO, FolderState } from 'app/types';
|
|
|
|
export const initialState: FolderState = {
|
|
id: 0,
|
|
uid: 'loading',
|
|
title: 'loading',
|
|
url: '',
|
|
canSave: false,
|
|
canDelete: false,
|
|
hasChanged: false,
|
|
version: 1,
|
|
permissions: [],
|
|
canViewFolderPermissions: false,
|
|
};
|
|
|
|
const folderSlice = createSlice({
|
|
name: 'folder',
|
|
initialState,
|
|
reducers: {
|
|
loadFolder: (state, action: PayloadAction<FolderDTO>): FolderState => {
|
|
return {
|
|
...state,
|
|
...action.payload,
|
|
hasChanged: false,
|
|
};
|
|
},
|
|
setFolderTitle: (state, action: PayloadAction<string>): FolderState => {
|
|
return {
|
|
...state,
|
|
title: action.payload,
|
|
hasChanged: action.payload.trim().length > 0,
|
|
};
|
|
},
|
|
loadFolderPermissions: (state, action: PayloadAction<DashboardAclDTO[]>): FolderState => {
|
|
return {
|
|
...state,
|
|
permissions: processAclItems(action.payload),
|
|
};
|
|
},
|
|
setCanViewFolderPermissions: (state, action: PayloadAction<boolean>): FolderState => {
|
|
state.canViewFolderPermissions = action.payload;
|
|
return state;
|
|
},
|
|
},
|
|
});
|
|
|
|
export const { loadFolderPermissions, loadFolder, setFolderTitle, setCanViewFolderPermissions } = folderSlice.actions;
|
|
|
|
export const folderReducer = folderSlice.reducer;
|
|
|
|
export default {
|
|
folder: folderReducer,
|
|
};
|