1
0
Fork 0
mirror of https://gitlab.com/bramw/baserow.git synced 2025-04-06 05:55:28 +00:00
bramw_baserow/web-frontend/modules/database/mixins/dateField.js
2022-08-05 13:52:33 +00:00

162 lines
4.7 KiB
JavaScript

import moment from '@baserow/modules/core/moment'
import {
getDateMomentFormat,
getTimeMomentFormat,
getDateHumanReadableFormat,
getTimeHumanReadableFormat,
} from '@baserow/modules/database/utils/date'
/**
* Mixin that introduces methods for the date field. This can both be used for a row
* and grid view field.
*/
export default {
data() {
return {
date: '',
time: '',
}
},
computed: {
/**
* We need to watch the value and the date/time formats. This can easily be done
* with a computed property.
*/
valueAndFormats() {
return `${this.value}|${this.field.date_format}|${this.field.date_time_format}`
},
},
watch: {
/**
* When the value or one of the date formats changes we need to update the date
* and time data with the correct values. This is because the date and time data
* are directly visible to the user and not the value like most other fields.
*/
valueAndFormats() {
if (!this.editing) {
this.setDateAndTime(this.field, this.value)
}
},
},
created() {
this.setDateAndTime(this.field, this.value)
},
methods: {
/**
* When the date part is updated we also need to update the copy data which
* contains the whole date(time) in the correct format. The copy contains the
* value that is actually going to be saved.
*/
updateDate(field, value) {
const dateFormat = getDateMomentFormat(field.date_format)
const newDate = moment.utc(value, dateFormat)
this.updateCopy(
field,
{
year: newDate.year(),
month: newDate.month(),
date: newDate.date(),
},
newDate
)
},
/**
* When the time part is updated we also need to update the copy data which
* contains the whole date(time) in the correct format. The copy contains the
* value that is actually going to be saved.
*/
updateTime(field, value) {
const newTime = moment.utc(value, ['h:m a', 'H:m'])
this.updateCopy(
field,
{
hour: newTime.hour(),
minute: newTime.minute(),
second: 0,
},
newTime
)
},
/**
* When the user uses the datapicker to choose a date, we also need to update
* date data and the copy so that the correct date is visible for the user.
*/
chooseDate(field, value) {
const dateFormat = getDateMomentFormat(field.date_format)
value = moment.utc(value).format(dateFormat)
this.date = value
this.updateDate(field, value)
},
/**
* When the user uses the time context to choose a time, we also need to update
* time data and the copy so that the correct time is visible for the user.
*/
chooseTime(field, value) {
this.updateTime(field, value)
this.time = value
},
/**
* A helper method that allows updating the copy data by only changing certain
* properties of a datetime. For example only the month could be updated.
*/
updateCopy(field, values, newDate) {
if (!newDate.isValid()) {
return
}
const existing = moment.utc(this.copy || undefined).seconds(0)
existing.set(values)
let newValue = existing.format()
if (!field.date_include_time) {
newValue = existing.format('YYYY-MM-DD')
}
this.copy = newValue
},
/**
* Updates the date and time data by converting the value to the correct formats.
*/
setDateAndTime(field, value) {
if (value === null) {
this.date = ''
this.time = ''
return
}
const existing = moment.utc(value || undefined).seconds(0)
const dateFormat = getDateMomentFormat(this.field.date_format)
const timeFormat = getTimeMomentFormat(this.field.date_time_format)
this.date = existing.format(dateFormat)
this.time = existing.format(timeFormat)
},
/**
* Returns a human readable date placeholder of the format for the input.
*/
getDatePlaceholder(field) {
return this.$t(
'humanDateFormat.' + getDateHumanReadableFormat(field.date_format)
)
},
/**
* Returns a human readable time placeholder of the format for the input.
*/
getTimePlaceholder(field) {
return getTimeHumanReadableFormat(field.date_time_format)
},
/**
* When the user focuses on one of the inputs the related context menu must
* also be opened.
*/
focus(context, event) {
context.toggle(event.currentTarget, 'bottom', 'left', 0)
},
/**
* When the user blurs one of the inputs the related context menu must also be
* hidden.
*/
blur(context, event) {
context.hide()
},
},
}