mirror of
https://github.com/flarum/framework.git
synced 2025-01-10 21:35:38 +08:00
1d6616a419
Mobile responsive design with a very native feel, all in pure CSS (no templating differences between versions — even though some things are in very different positions.) I’ve been working on this whole thing in my head for a while now, planning out how certain components will be laid out on the mobile version, and how to reason about them in the templates so that a substantially different layout can still be achieved by only using CSS. Today I finally wrote the CSS and it’s come together pretty damn perfectly. Still to come: - Swiping left or right on discussions to reveal controls - Tablet version
118 lines
4.1 KiB
JavaScript
118 lines
4.1 KiB
JavaScript
import Ember from 'ember';
|
|
|
|
import HasItemLists from 'flarum/mixins/has-item-lists';
|
|
import SearchInput from 'flarum/components/ui/search-input';
|
|
import UserDropdown from 'flarum/components/application/user-dropdown';
|
|
import ForumStatistic from 'flarum/components/application/forum-statistic';
|
|
import PoweredBy from 'flarum/components/application/powered-by';
|
|
|
|
var $ = Ember.$;
|
|
|
|
export default Ember.View.extend(HasItemLists, {
|
|
itemLists: ['headerPrimary', 'headerSecondary', 'footerPrimary', 'footerSecondary'],
|
|
|
|
title: Ember.computed.alias('controller.forumTitle'),
|
|
|
|
// When either the forum title or the page title changes, we want to
|
|
// refresh the document's title.
|
|
updateTitle: Ember.observer('controller.pageTitle', 'controller.forumTitle', function() {
|
|
var parts = [this.get('controller.forumTitle')];
|
|
var pageTitle = this.get('controller.pageTitle');
|
|
if (pageTitle) {
|
|
parts.unshift(pageTitle);
|
|
}
|
|
document.title = parts.join(' - ');
|
|
}),
|
|
|
|
modalShowingChanged: Ember.observer('controller.modalController', function() {
|
|
Ember.run.scheduleOnce('afterRender', this, function() {
|
|
this.$('#modal').modal(this.get('controller.modalController') ? 'show' : 'hide');
|
|
});
|
|
}),
|
|
|
|
drawerShowingChanged: Ember.observer('controller.drawerShowing', function() {
|
|
Ember.run.scheduleOnce('afterRender', this, function() {
|
|
$('body').toggleClass('drawer-open', this.get('controller.drawerShowing'));
|
|
});
|
|
}),
|
|
|
|
didInsertElement: function() {
|
|
// Add a class to the body when the window is scrolled down.
|
|
$(window).scroll(function() {
|
|
$('body').toggleClass('scrolled', $(window).scrollTop() > 0);
|
|
}).scroll();
|
|
|
|
// Resize the main content area so that the footer sticks to the
|
|
// bottom of the viewport.
|
|
// $(window).resize(function() {
|
|
// $('#main').css('min-height', $(window).height() - $('#header').outerHeight() - $('#footer').outerHeight(true));
|
|
// }).resize();
|
|
|
|
var view = this;
|
|
this.$('#modal').on('hide.bs.modal', function() {
|
|
view.get('controller').send('closeModal');
|
|
}).on('hidden.bs.modal', function() {
|
|
view.get('controller').send('destroyModal');
|
|
}).on('shown.bs.modal', function() {
|
|
view.get('controller.modalController').send('focus');
|
|
});
|
|
|
|
this.$().on('show.bs.dropdown', function() {
|
|
$('body').addClass('dropdown-open');
|
|
}).on('hide.bs.dropdown', function() {
|
|
$('body').removeClass('dropdown-open');
|
|
});
|
|
|
|
this.$('.global-content').click(function(e) {
|
|
if (view.get('controller.drawerShowing')) {
|
|
e.preventDefault();
|
|
view.set('controller.drawerShowing', false);
|
|
}
|
|
});
|
|
},
|
|
|
|
switchHeader: Ember.observer('controller.session.user', function() {
|
|
this.initItemList('headerPrimary');
|
|
this.initItemList('headerSecondary');
|
|
}),
|
|
|
|
populateHeaderSecondary: function(items) {
|
|
var controller = this.get('controller');
|
|
|
|
items.pushObjectWithTag(SearchInput.extend({
|
|
placeholder: 'Search Forum',
|
|
controller: controller,
|
|
valueBinding: Ember.Binding.oneWay('controller.searchQuery'),
|
|
activeBinding: Ember.Binding.oneWay('controller.searchActive'),
|
|
action: function(value) { controller.send('search', value); }
|
|
}), 'search');
|
|
|
|
if (this.get('controller.session.isAuthenticated')) {
|
|
items.pushObjectWithTag(UserDropdown.extend({
|
|
user: this.get('controller.session.user'),
|
|
logout: function() { controller.send('invalidateSession'); }
|
|
}), 'user');
|
|
} else {
|
|
this.addActionItem(items, 'signup', 'Sign Up').reopen({className: 'btn btn-link'});
|
|
this.addActionItem(items, 'login', 'Log In').reopen({className: 'btn btn-link'});
|
|
}
|
|
},
|
|
|
|
populateFooterPrimary: function(items) {
|
|
var addStatistic = function(label, number) {
|
|
items.pushObjectWithTag(ForumStatistic.extend({
|
|
label: label,
|
|
number: number
|
|
}), 'statistics.'+label);
|
|
};
|
|
// addStatistic('discussions', 12);
|
|
// addStatistic('posts', 12);
|
|
// addStatistic('users', 12);
|
|
// addStatistic('online', 12);
|
|
},
|
|
|
|
populateFooterSecondary: function(items) {
|
|
items.pushObjectWithTag(PoweredBy, 'poweredBy');
|
|
}
|
|
});
|