Skip to content

Commit

Permalink
feat(autocomplete): participate in routing (#4029)
Browse files Browse the repository at this point in the history
* feat(autocomplete): participate in routing

* feat(autocomplete): add placeholders to gWSP
  • Loading branch information
Haroenv authored and samouss committed Sep 17, 2019
1 parent 80d66cb commit 42ae4f7
Show file tree
Hide file tree
Showing 2 changed files with 147 additions and 5 deletions.
116 changes: 116 additions & 0 deletions src/connectors/autocomplete/__tests__/connectAutocomplete-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,34 @@ import { createSearchClient } from '../../../../test/mock/createSearchClient';
import { createSingleSearchResponse } from '../../../../test/mock/createAPIResponse';
import connectAutocomplete from '../connectAutocomplete';
import { TAG_PLACEHOLDER } from '../../../lib/escape-highlight';
import { Client } from 'algoliasearch/lite';

describe('connectAutocomplete', () => {
const getInitializedWidget = (config = {}) => {
const renderFn = jest.fn();
const makeWidget = connectAutocomplete(renderFn);
const widget = makeWidget({
...config,
});

const initialConfig = {};
const helper = algoliasearchHelper({} as Client, '', initialConfig);
helper.search = jest.fn();

widget.init!({
helper,
state: helper.state,
createURL: () => '#',
instantSearchInstance: undefined as any,
parent: undefined as any,
templatesConfig: undefined as any,
});

const { refine } = renderFn.mock.calls[0][0];

return [widget, helper, refine];
};

it('throws without render function', () => {
expect(() => {
// @ts-ignore
Expand Down Expand Up @@ -448,4 +474,94 @@ search.addWidgets([
expect(nextState.highlightPostTag).toBe('</mark>');
});
});

describe('getWidgetState', () => {
test('should give back the object unmodified if the default value is selected', () => {
const [widget, helper] = getInitializedWidget();
const uiStateBefore = {};
const uiStateAfter = widget.getWidgetState(uiStateBefore, {
searchParameters: helper.state,
helper,
});
expect(uiStateAfter).toBe(uiStateBefore);
});

test('should add an entry equal to the refinement', () => {
const [widget, helper, refine] = getInitializedWidget();
refine('some query');
const uiStateBefore = {};
const uiStateAfter = widget.getWidgetState(uiStateBefore, {
searchParameters: helper.state,
helper,
});
expect(uiStateAfter).toEqual({
query: 'some query',
});
});

test('should give back the same instance if the value is alreay in the uiState', () => {
const [widget, helper, refine] = getInitializedWidget();
refine('query');
const uiStateBefore = widget.getWidgetState(
{},
{
searchParameters: helper.state,
helper,
}
);
const uiStateAfter = widget.getWidgetState(uiStateBefore, {
searchParameters: helper.state,
helper,
});
expect(uiStateAfter).toBe(uiStateBefore);
});
});

describe('getWidgetSearchParameters', () => {
test('returns the `SearchParameters` with the value from `uiState`', () => {
const [widget, helper] = getInitializedWidget();

expect(helper.state).toEqual(
new SearchParameters({
index: '',
})
);

const actual = widget.getWidgetSearchParameters(helper.state, {
uiState: {
query: 'Apple',
},
});

expect(actual).toEqual(
new SearchParameters({
index: '',
query: 'Apple',
...TAG_PLACEHOLDER,
})
);
});

test('returns the `SearchParameters` with the default value', () => {
const [widget, helper] = getInitializedWidget();

expect(helper.state).toEqual(
new SearchParameters({
index: '',
})
);

const actual = widget.getWidgetSearchParameters(helper.state, {
uiState: {},
});

expect(actual).toEqual(
new SearchParameters({
index: '',
query: '',
...TAG_PLACEHOLDER,
})
);
});
});
});
36 changes: 31 additions & 5 deletions src/connectors/autocomplete/connectAutocomplete.ts
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,6 @@ search.addWidgets([
);

type ConnectorState = {
instantSearchInstance?: InstantSearch;
refine?: (query: string) => void;
};

Expand All @@ -118,7 +117,6 @@ search.addWidgets([
},

init({ instantSearchInstance, helper }) {
connectorState.instantSearchInstance = instantSearchInstance;
connectorState.refine = (query: string) => {
helper.setQuery(query).search();
};
Expand All @@ -129,13 +127,13 @@ search.addWidgets([
currentRefinement: helper.state.query || '',
indices: [],
refine: connectorState.refine,
instantSearchInstance: connectorState.instantSearchInstance,
instantSearchInstance,
},
true
);
},

render({ helper, scopedResults }) {
render({ helper, scopedResults, instantSearchInstance }) {
const indices = scopedResults.map(scopedResult => {
// We need to escape the hits because highlighting
// exposes HTML tags to the end-user.
Expand All @@ -156,12 +154,40 @@ search.addWidgets([
currentRefinement: helper.state.query || '',
indices,
refine: connectorState.refine!,
instantSearchInstance: connectorState.instantSearchInstance!,
instantSearchInstance,
},
false
);
},

getWidgetState(uiState, { searchParameters }) {
const query = searchParameters.query || '';

if (query === '' || (uiState && uiState.query === query)) {
return uiState;
}

return {
...uiState,
query,
};
},

getWidgetSearchParameters(searchParameters, { uiState }) {
const parameters = {
query: uiState.query || '',
};

if (!escapeHTML) {
return searchParameters.setQueryParameters(parameters);
}

return searchParameters.setQueryParameters({
...parameters,
...TAG_PLACEHOLDER,
});
},

dispose({ state }) {
unmountFn();

Expand Down

0 comments on commit 42ae4f7

Please sign in to comment.