1
0
mirror of https://github.com/mattermost/focalboard.git synced 2025-01-11 18:13:52 +02:00
focalboard/webapp/src/store/globalTemplates.ts
2022-03-31 17:55:29 +05:30

39 lines
1.1 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import {createSlice, createAsyncThunk} from '@reduxjs/toolkit'
import {default as client} from '../octoClient'
import {Board} from '../blocks/board'
import {Constants} from "../constants"
import {RootState} from './index'
// ToDo: move this to team templates or simply templates
export const fetchGlobalTemplates = createAsyncThunk(
'globalTemplates/fetch',
async () => {
const templates = await client.getTeamTemplates(Constants.globalTeamId)
return templates.sort((a, b) => a.title.localeCompare(b.title))
},
)
const globalTemplatesSlice = createSlice({
name: 'globalTemplates',
initialState: {value: []} as {value: Board[]},
reducers: {},
extraReducers: (builder) => {
builder.addCase(fetchGlobalTemplates.fulfilled, (state, action) => {
state.value = action.payload || []
})
},
})
export const {reducer} = globalTemplatesSlice
export function getGlobalTemplates(state: RootState): Board[] {
return state.globalTemplates.value
}