mirror of
https://github.com/flarum/framework.git
synced 2025-01-23 10:35:30 +08:00
2c46888db5
New stuff: - Signup + email confirmation. - Updated authentication strategy with remember cookies. closes #5 - New search system with some example gambits! This is cool - check out the source. Fulltext drivers will be implemented as decorators overriding the EloquentPostRepository’s findByContent method. - Lay down the foundation for bootstrapping the Ember app. - Update Web layer’s asset manager to properly publish CSS/JS files. - Console commands to run installation migrations and seeds. Refactoring: - New structure: move models, repositories, commands, and events into their own namespaces, rather than grouping by entity. - All events are classes. - Use L5 middleware and command bus implementations. - Clearer use of repositories and the Active Record pattern. Repositories are used only for retrieval of ActiveRecord objects, and then save/delete operations are called directly on those ActiveRecords. This way, we don’t over-abstract at the cost of Eloquent magic, but testing is still easy. - Refactor of Web layer so that it uses the Actions routing architecture. - “Actor” concept instead of depending on Laravel’s Auth. - General cleanup!
48 lines
1.2 KiB
JavaScript
48 lines
1.2 KiB
JavaScript
import Ember from 'ember';
|
|
import ApplicationRouteMixin from 'simple-auth/mixins/application-route-mixin';
|
|
|
|
import AlertMessage from 'flarum/components/ui/alert-message';
|
|
|
|
export default Ember.Route.extend(ApplicationRouteMixin, {
|
|
activate: function() {
|
|
if (!Ember.isEmpty(FLARUM_ALERT)) {
|
|
this.controllerFor('alerts').send('alert', AlertMessage.create(FLARUM_ALERT));
|
|
}
|
|
},
|
|
|
|
actions: {
|
|
login: function() {
|
|
this.controllerFor('login').set('error', null);
|
|
this.send('showModal', 'login');
|
|
},
|
|
|
|
signup: function() {
|
|
this.controllerFor('signup').set('error', null).set('welcomeUser', null);
|
|
this.send('showModal', 'signup');
|
|
},
|
|
|
|
showModal: function(name) {
|
|
this.render(name, {
|
|
into: 'application',
|
|
outlet: 'modal'
|
|
});
|
|
this.controllerFor('application').set('modalController', this.controllerFor(name));
|
|
},
|
|
|
|
closeModal: function() {
|
|
this.controllerFor('application').set('modalController', null);
|
|
},
|
|
|
|
destroyModal: function() {
|
|
this.disconnectOutlet({
|
|
outlet: 'modal',
|
|
parentView: 'application'
|
|
});
|
|
},
|
|
|
|
sessionChanged: function() {
|
|
this.refresh();
|
|
}
|
|
}
|
|
});
|