Fix changing text and jumping caret in PSM's date input

refs #5777
- adds new `gh-datetime-input` that takes a one-way-bound value and formats it, only triggering the supplied `update` action on focus-out
- fixes bug in PSM's `setPublishedAt` action if model's `published_at` is a Date object not a Moment object
This commit is contained in:
Kevin Ansfield 2015-12-08 09:58:32 +00:00
parent adfad93242
commit b858232369
4 changed files with 44 additions and 25 deletions

View File

@ -0,0 +1,32 @@
import Ember from 'ember';
import TextInputMixin from 'ghost/mixins/text-input';
import boundOneWay from 'ghost/utils/bound-one-way';
import {formatDate} from 'ghost/utils/date-formatting';
const {Component} = Ember;
export default Component.extend(TextInputMixin, {
tagName: 'span',
classNames: 'input-icon icon-calendar',
datetime: boundOneWay('value'),
inputClass: null,
inputId: null,
inputName: null,
didReceiveAttrs() {
let datetime = this.get('datetime') || moment();
if (!this.attrs.update) {
throw new Error(`You must provide an \`update\` action to \`{{${this.templateName}}}\`.`);
}
this.set('datetime', formatDate(datetime));
},
focusOut() {
let datetime = this.get('datetime');
this.attrs.update(datetime);
}
});

View File

@ -1,5 +1,5 @@
import Ember from 'ember';
import {parseDateString, formatDate} from 'ghost/utils/date-formatting';
import {parseDateString} from 'ghost/utils/date-formatting';
import SettingsMenuMixin from 'ghost/mixins/settings-menu-controller';
import SlugGenerator from 'ghost/models/slug-generator';
import boundOneWay from 'ghost/utils/bound-one-way';
@ -43,25 +43,6 @@ export default Controller.extend(SettingsMenuMixin, {
.create(deferred);
}),
/*jshint unused:false */
publishedAtValue: computed('model.published_at', {
get() {
let pubDate = this.get('model.published_at');
if (pubDate) {
return formatDate(pubDate);
}
return formatDate(moment());
},
set(key, value) {
// We're using a fake setter to reset
// the cache for this property
return formatDate(moment());
}
}),
/*jshint unused:true */
slugValue: boundOneWay('model.slug'),
// Lazy load the slug generator
@ -302,7 +283,7 @@ export default Controller.extend(SettingsMenuMixin, {
*/
setPublishedAt(userInput) {
let newPublishedAt = parseDateString(userInput);
let publishedAt = this.get('model.published_at');
let publishedAt = moment(this.get('model.published_at'));
let errMessage = '';
if (!userInput) {
@ -326,7 +307,6 @@ export default Controller.extend(SettingsMenuMixin, {
// If errors, notify and exit.
if (errMessage) {
this.get('model.errors').add('post-setting-date', errMessage);
return;
}

View File

@ -0,0 +1,5 @@
{{gh-input value=datetime
id=inputId
class=inputClass
name=inputName
stopEnterKeyDownPropagation="true"}}

View File

@ -28,9 +28,11 @@
{{#gh-form-group errors=model.errors property="post-setting-date"}}
<label for="post-setting-date">Publish Date</label>
<span class="input-icon icon-calendar">
{{gh-input class="post-setting-date" id="post-setting-date" value=publishedAtValue name="post-setting-date" focus-out="setPublishedAt" stopEnterKeyDownPropagation="true"}}
</span>
{{gh-datetime-input value=model.published_at
update=(action "setPublishedAt")
inputClass="post-setting-date"
inputId="post-setting-date"
inputName="post-setting-date"}}
{{gh-error-message errors=model.errors property="post-setting-date"}}
{{/gh-form-group}}