Skip to content

Commit

Permalink
feat(js): always keep panel open on detached mode
Browse files Browse the repository at this point in the history
  • Loading branch information
francoischalifour committed Feb 10, 2021
1 parent 5a9dcf2 commit 9014a41
Showing 1 changed file with 19 additions and 20 deletions.
39 changes: 19 additions & 20 deletions packages/autocomplete-js/src/autocomplete.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,24 @@ export function autocomplete<TItem extends BaseItem>(
AutocompleteOptions<TItem>['onStateChange']
>(undefined);
const props = reactive(() => getDefaultOptions(optionsRef.current));
const isTouch = reactive(
() => window.matchMedia(props.value.renderer.touchMediaQuery).matches
);
const shouldPanelOpen =
optionsRef.current.shouldPanelOpen ||
(({ state }) => {
const hasItems = getItemsCount(state) > 0;

if (!props.value.core.openOnFocus && !state.query) {
return hasItems;
}

const hasEmptyTemplate = Boolean(
hasEmptySourceTemplateRef.current || props.value.renderer.renderEmpty
);

return (!hasItems && hasEmptyTemplate) || hasItems;
});
const autocomplete = reactive(() =>
createAutocomplete<TItem>({
...props.value.core,
Expand All @@ -47,22 +65,7 @@ export function autocomplete<TItem extends BaseItem>(
onStateChangeRef.current?.(options as any);
props.value.core.onStateChange?.(options as any);
},
shouldPanelOpen:
optionsRef.current.shouldPanelOpen ||
(({ state }) => {
const hasItems = getItemsCount(state) > 0;

if (!props.value.core.openOnFocus && !state.query) {
return hasItems;
}

const hasEmptyTemplate = Boolean(
hasEmptySourceTemplateRef.current ||
props.value.renderer.renderEmpty
);

return (!hasItems && hasEmptyTemplate) || hasItems;
}),
shouldPanelOpen: isTouch ? () => true : shouldPanelOpen,
})
);
const lastStateRef = createRef<AutocompleteState<TItem>>({
Expand All @@ -76,10 +79,6 @@ export function autocomplete<TItem extends BaseItem>(
...props.value.core.initialState,
});

const isTouch = reactive(
() => window.matchMedia(props.value.renderer.touchMediaQuery).matches
);

const propGetters: AutocompletePropGetters<TItem> = {
getEnvironmentProps: props.value.renderer.getEnvironmentProps,
getFormProps: props.value.renderer.getFormProps,
Expand Down

0 comments on commit 9014a41

Please sign in to comment.