diff --git a/ui/app/models/config-ui/message.js b/ui/app/models/config-ui/message.js index 56a95cf40eb7..0edabc4270b7 100644 --- a/ui/app/models/config-ui/message.js +++ b/ui/app/models/config-ui/message.js @@ -4,7 +4,7 @@ */ import Model, { attr } from '@ember-data/model'; import lazyCapabilities, { apiPath } from 'vault/macros/lazy-capabilities'; -import { isAfter, addDays, startOfDay, parseISO } from 'date-fns'; +import { isAfter, addDays, startOfDay, parseISO, isBefore } from 'date-fns'; import { withModelValidations } from 'vault/decorators/model-validations'; import { withFormFields } from 'vault/decorators/model-form-fields'; @@ -22,6 +22,28 @@ const validations = { message: 'Link title and url are required.', }, ], + startTime: [ + { + validator(model) { + if (!model.endTime) return true; + const start = new Date(model.startTime); + const end = new Date(model.endTime); + return isBefore(start, end); + }, + message: 'Start time is after end time.', + }, + ], + endTime: [ + { + validator(model) { + if (!model.endTime) return true; + const start = new Date(model.startTime); + const end = new Date(model.endTime); + return isAfter(end, start); + }, + message: 'End time is before start time.', + }, + ], }; @withModelValidations(validations) @@ -95,7 +117,7 @@ export default class MessageModel extends Model { @attr('object', { editType: 'kv', keyPlaceholder: 'Display text (e.g. Learn more)', - valuePlaceholder: 'Link URL (e.g. https://www.learnmore.com)', + valuePlaceholder: 'Link URL (e.g. https://www.hashicorp.com/)', label: 'Link (optional)', isSingleRow: true, allowWhiteSpace: true, diff --git a/ui/app/serializers/config-ui/message.js b/ui/app/serializers/config-ui/message.js index 2333eb247550..51479944e5fc 100644 --- a/ui/app/serializers/config-ui/message.js +++ b/ui/app/serializers/config-ui/message.js @@ -9,8 +9,6 @@ import ApplicationSerializer from '../application'; export default class MessageSerializer extends ApplicationSerializer { attrs = { active: { serialize: false }, - start_time: { serialize: false }, - end_time: { serialize: false }, }; normalizeResponse(store, primaryModelClass, payload, id, requestType) { diff --git a/ui/lib/config-ui/addon/components/messages/message-expiration-date-form.hbs b/ui/lib/config-ui/addon/components/messages/message-expiration-date-form.hbs index 60c81c555fcd..aabcd72e085d 100644 --- a/ui/lib/config-ui/addon/components/messages/message-expiration-date-form.hbs +++ b/ui/lib/config-ui/addon/components/messages/message-expiration-date-form.hbs @@ -30,7 +30,7 @@ id="specificDate" value="specificDate" @value="specificDate" - @onChange={{fn (mut @message.endTime) this.formDateTime}} + @onChange={{this.specificDateChange}} @groupValue={{this.groupValue}} /> diff --git a/ui/lib/config-ui/addon/components/messages/message-expiration-date-form.js b/ui/lib/config-ui/addon/components/messages/message-expiration-date-form.js index daaff91305cb..b85e7622a415 100644 --- a/ui/lib/config-ui/addon/components/messages/message-expiration-date-form.js +++ b/ui/lib/config-ui/addon/components/messages/message-expiration-date-form.js @@ -3,6 +3,7 @@ * SPDX-License-Identifier: BUSL-1.1 */ +import { action } from '@ember/object'; import Component from '@glimmer/component'; import { tracked } from '@glimmer/tracking'; import { datetimeLocalStringFormat } from 'core/utils/date-formatters'; @@ -20,14 +21,33 @@ import { datetimeLocalStringFormat } from 'core/utils/date-formatters'; export default class MessageExpirationDateForm extends Component { datetimeLocalStringFormat = datetimeLocalStringFormat; @tracked groupValue = 'never'; - @tracked formDateTime = ''; + @tracked messageEndTime = ''; constructor() { super(...arguments); if (this.args.message.endTime) { this.groupValue = 'specificDate'; - this.formDateTime = this.args.message.endTime; + this.messageEndTime = this.args.message.endTime; } } + + get validationError() { + const validations = this.args.modelValidations || {}; + const state = validations[this.args.attr.name]; + return state && !state.isValid ? state.errors.join(' ') : null; + } + + @action + specificDateChange() { + this.groupValue = 'specificDate'; + this.args.message.endTime = this.messageEndTime; + } + + @action + onFocusOut(e) { + this.messageEndTime = e.target.value; + this.args.message.endTime = this.messageEndTime; + this.groupValue = 'specificDate'; + } } diff --git a/ui/lib/config-ui/addon/components/messages/page/create-and-edit-message-form.hbs b/ui/lib/config-ui/addon/components/messages/page/create-and-edit-message-form.hbs index 6aeffedc4e22..4ea214ef6236 100644 --- a/ui/lib/config-ui/addon/components/messages/page/create-and-edit-message-form.hbs +++ b/ui/lib/config-ui/addon/components/messages/page/create-and-edit-message-form.hbs @@ -9,21 +9,21 @@ />