palantir/blueprint

DateInput handles blur and key down Enter on the input field differently.

Open

#2,550 建立於 2018年5月29日

在 GitHub 查看
 (1 留言) (0 反應) (0 負責人)TypeScript (20,263 star) (2,167 fork)batch import
Package: datetimeType: enhancementhelp wanted

描述

Environment

  • Package version(s): blueprintjs/datetime@2.0.0
  • Browser and OS versions: Chrome

Steps to reproduce

  1. With
<DateInput
  minDate={new Date('2018-01-01T00:00:00Z')}
  maxDate={new Date('2019-01-01T00:00:00Z')}
  onChange={val => console.log('onChange', val)}
  onError={val => console.log('onError', val)}
/>
  1. On filling in 05/29/3018 into the input as string and blurring the input, you see onError Fri May 29 3018 09:00:00 GMT+0200 (CEST)
  2. On filling in 05/29/3018 and then hitting Enter, you can see onChange Fri May 29 3018 09:00:00 GMT+0200 (CEST)

Actual behavior

Expected behavior

I would expect that whether input is blurred or whether I hit Enter, both ways will trigger the same handler, which according to documentation should be onError as date is out of range.

Possible solution

On handleInputBlur there is correct code that calls onChange or onError depending on the validity of the value but in handleDateChange which is called in handleInputKeyDown this is not implemented and onChange is called with invalid inputs.

貢獻者指南