@yext/search-headless
Version:
A library for powering UI components for Yext Search integrations
31 lines (27 loc) • 790 B
text/typescript
import { createSlice, PayloadAction, Slice } from '@reduxjs/toolkit';
import { SpellCheck } from '@yext/search-core';
import { SpellCheckState } from '../models/slices/spellcheck';
const initialState: SpellCheckState = {
enabled: true
};
const reducers = {
setResult: (state, action: PayloadAction<SpellCheck>) => {
return {
enabled: state.enabled,
...action.payload
};
},
setEnabled: (state, action: PayloadAction<boolean>) => {
state.enabled = action.payload;
},
};
/**
* Registers with Redux the slice of {@link State} pertaining to spellcheck.
*/
export default function createSpellCheckSlice(prefix: string): Slice<SpellCheckState, typeof reducers> {
return createSlice({
name: prefix + 'spellCheck',
initialState,
reducers
});
}