diff --git a/packages/nc-gui/components/cell/DatePicker.vue b/packages/nc-gui/components/cell/DatePicker.vue index f515e0873c..bb082b6f73 100644 --- a/packages/nc-gui/components/cell/DatePicker.vue +++ b/packages/nc-gui/components/cell/DatePicker.vue @@ -81,7 +81,7 @@ useSelectedCellKeyupListener(inject(ActiveCellInj, ref(false)), (e: KeyboardEven :placeholder="placeholder" :allow-clear="!readOnly && !localState && !isPk" :input-read-only="true" - :dropdown-class-name="`${randomClass} nc-picker-date`" + :dropdown-class-name="`${randomClass} nc-picker-date ${open ? 'active' : ''}`" :open="readOnly || (localState && isPk) ? false : open" @click="open = !open" > diff --git a/packages/nc-gui/components/cell/DateTimePicker.vue b/packages/nc-gui/components/cell/DateTimePicker.vue index 5c16909add..3acae997e3 100644 --- a/packages/nc-gui/components/cell/DateTimePicker.vue +++ b/packages/nc-gui/components/cell/DateTimePicker.vue @@ -15,6 +15,8 @@ const { isMysql } = useProject() const readOnly = inject(ReadonlyInj, ref(false)) +const active = inject(ActiveCellInj, ref(false)) + let isDateInvalid = $ref(false) const dateFormat = isMysql ? 'YYYY-MM-DD HH:mm:ss' : 'YYYY-MM-DD HH:mm:ssZ' @@ -57,7 +59,7 @@ watch( { flush: 'post' }, ) -useSelectedCellKeyupListener(inject(ActiveCellInj, ref(false)), (e: KeyboardEvent) => { +useSelectedCellKeyupListener(active, (e: KeyboardEvent) => { switch (e.key) { case 'Enter': e.stopPropagation() @@ -81,10 +83,10 @@ useSelectedCellKeyupListener(inject(ActiveCellInj, ref(false)), (e: KeyboardEven :placeholder="isDateInvalid ? 'Invalid date' : ''" :allow-clear="!readOnly && !localState && !isPk" :input-read-only="true" - :dropdown-class-name="`${randomClass} nc-picker-datetime`" - :open="readOnly || (localState && isPk) ? false : open" + :dropdown-class-name="`${randomClass} nc-picker-datetime ${open ? 'active' : ''}`" + :open="readOnly || (localState && isPk) ? false : open && active" :disabled="readOnly || (localState && isPk)" - @click="open = !open" + @click="open = active && !open" @ok="open = !open" > diff --git a/packages/nc-gui/components/cell/Rating.vue b/packages/nc-gui/components/cell/Rating.vue index 51aadec80d..44308292e6 100644 --- a/packages/nc-gui/components/cell/Rating.vue +++ b/packages/nc-gui/components/cell/Rating.vue @@ -37,11 +37,7 @@ useSelectedCellKeyupListener(inject(ActiveCellInj, ref(false)), (e: KeyboardEven