mirror of
https://github.com/flarum/framework.git
synced 2025-01-10 21:35:38 +08:00
c28307903b
HTMLBars goodness! Since there was some breakage and a lot of fiddling around to get some things working, I took this opportunity to do a big cleanup of the whole Ember app. I accidentally worked on some new features too :3 Note that the app is still broken right now, pending on https://github.com/emberjs/ember.js/issues/10401 Cleanup: - Restructuring of components - Consolidation of some stuff into mixins, cleanup of some APIs that will be public - Change all instances of .property() / .observes() / .on() to Ember.computed() / Ember.observer() / Ember.on() respectively (I think it is more readable) - More comments - Start conforming to a code style (2 spaces for indentation) New features: - Post hiding/restoring - Mark individual discussions as read by clicking - Clicking on a read discussion jumps to the end - Mark all discussions as read - Progressively mark the discussion as read as the page is scrolled - Unordered list post formatting - Post permalink popup Demo once that Ember regression is fixed!
38 lines
1.0 KiB
JavaScript
38 lines
1.0 KiB
JavaScript
import Ember from 'ember';
|
|
|
|
export default Ember.Mixin.create({
|
|
showComposer: function(buildComposerContent) {
|
|
var composer = this.get('composer');
|
|
if (this.get('composerContent') !== composer.get('content')) {
|
|
this.set('composerContent', buildComposerContent());
|
|
composer.switchContent(this.get('composerContent'));
|
|
}
|
|
composer.send('show');
|
|
},
|
|
|
|
saveAndDismissComposer: function(model) {
|
|
var composer = this.get('composer');
|
|
composer.set('content.loading', true);
|
|
this.get('alerts').send('clearAlerts');
|
|
|
|
return model.save().then(function(model) {
|
|
composer.send('hide');
|
|
return model;
|
|
}, function(reason) {
|
|
controller.showErrorsAsAlertMessages(reason.errors);
|
|
}).finally(function() {
|
|
composer.set('content.loading', false);
|
|
});
|
|
},
|
|
|
|
showErrorsAsAlertMessages: function(errors) {
|
|
for (var i in errors) {
|
|
var message = AlertMessage.create({
|
|
type: 'warning',
|
|
message: errors[i]
|
|
});
|
|
this.get('alerts').send('alert', message);
|
|
}
|
|
}
|
|
})
|