silverstripe-framework/admin/client/dist/js/LeftAndMain.Panel.js

175 lines
4.9 KiB
JavaScript
Raw Normal View History

(function (global, factory) {
2016-07-13 14:43:07 +12:00
if (typeof define === "function" && define.amd) {
define('ss.LeftAndMain.Panel', ['jQuery'], factory);
} else if (typeof exports !== "undefined") {
factory(require('jQuery'));
} else {
var mod = {
exports: {}
};
factory(global.jQuery);
global.ssLeftAndMainPanel = mod.exports;
}
})(this, function (_jQuery) {
2016-07-13 14:43:07 +12:00
'use strict';
2016-07-13 14:43:07 +12:00
var _jQuery2 = _interopRequireDefault(_jQuery);
2016-07-13 14:43:07 +12:00
function _interopRequireDefault(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
2016-07-13 14:43:07 +12:00
_jQuery2.default.entwine('ss', function ($) {
$.entwine.warningLevel = $.entwine.WARN_LEVEL_BESTPRACTISE;
2016-07-13 14:43:07 +12:00
$('.cms-panel').entwine({
2016-07-13 14:43:07 +12:00
WidthExpanded: null,
2016-07-13 14:43:07 +12:00
WidthCollapsed: null,
2016-07-13 14:43:07 +12:00
canSetCookie: function canSetCookie() {
return $.cookie !== void 0 && this.attr('id') !== void 0;
},
2016-07-13 14:43:07 +12:00
getPersistedCollapsedState: function getPersistedCollapsedState() {
var isCollapsed, cookieValue;
2016-07-13 14:43:07 +12:00
if (this.canSetCookie()) {
cookieValue = $.cookie('cms-panel-collapsed-' + this.attr('id'));
2016-07-13 14:43:07 +12:00
if (cookieValue !== void 0 && cookieValue !== null) {
isCollapsed = cookieValue === 'true';
}
}
2016-07-13 14:43:07 +12:00
return isCollapsed;
},
2016-07-13 14:43:07 +12:00
setPersistedCollapsedState: function setPersistedCollapsedState(newState) {
if (this.canSetCookie()) {
$.cookie('cms-panel-collapsed-' + this.attr('id'), newState, { path: '/', expires: 31 });
}
},
2016-07-13 14:43:07 +12:00
clearPersistedCollapsedState: function clearPersistedCollapsedState() {
if (this.canSetCookie()) {
$.cookie('cms-panel-collapsed-' + this.attr('id'), '', { path: '/', expires: -1 });
}
},
2016-07-13 14:43:07 +12:00
getInitialCollapsedState: function getInitialCollapsedState() {
var isCollapsed = this.getPersistedCollapsedState();
2016-07-13 14:43:07 +12:00
if (isCollapsed === void 0) {
isCollapsed = this.hasClass('collapsed');
}
2016-07-13 14:43:07 +12:00
return isCollapsed;
},
2016-07-13 14:43:07 +12:00
onadd: function onadd() {
var collapsedContent, container;
2016-07-13 14:43:07 +12:00
if (!this.find('.cms-panel-content').length) throw new Exception('Content panel for ".cms-panel" not found');
2016-07-13 14:43:07 +12:00
if (!this.find('.cms-panel-toggle').length) {
container = $("<div class='cms-panel-toggle south'></div>").append('<a class="toggle-expand" href="#"><span>&raquo;</span></a>').append('<a class="toggle-collapse" href="#"><span>&laquo;</span></a>');
2016-07-13 14:43:07 +12:00
this.append(container);
}
2016-07-13 14:43:07 +12:00
this.setWidthExpanded(this.find('.cms-panel-content').innerWidth());
2016-07-13 14:43:07 +12:00
collapsedContent = this.find('.cms-panel-content-collapsed');
this.setWidthCollapsed(collapsedContent.length ? collapsedContent.innerWidth() : this.find('.toggle-expand').innerWidth());
2016-07-13 14:43:07 +12:00
this.togglePanel(!this.getInitialCollapsedState(), true, false);
2016-07-13 14:43:07 +12:00
this._super();
},
2016-07-13 14:43:07 +12:00
togglePanel: function togglePanel(doExpand, silent, doSaveState) {
var newWidth, collapsedContent;
2016-07-13 14:43:07 +12:00
if (!silent) {
this.trigger('beforetoggle.sspanel', doExpand);
this.trigger(doExpand ? 'beforeexpand' : 'beforecollapse');
}
2016-07-13 14:43:07 +12:00
this.toggleClass('collapsed', !doExpand);
newWidth = doExpand ? this.getWidthExpanded() : this.getWidthCollapsed();
2016-07-13 14:43:07 +12:00
this.width(newWidth);
collapsedContent = this.find('.cms-panel-content-collapsed');
if (collapsedContent.length) {
this.find('.cms-panel-content')[doExpand ? 'show' : 'hide']();
this.find('.cms-panel-content-collapsed')[doExpand ? 'hide' : 'show']();
}
2016-07-13 14:43:07 +12:00
if (doSaveState !== false) {
this.setPersistedCollapsedState(!doExpand);
}
2016-07-13 14:43:07 +12:00
this.trigger('toggle', doExpand);
this.trigger(doExpand ? 'expand' : 'collapse');
},
2016-07-13 14:43:07 +12:00
expandPanel: function expandPanel(force) {
if (!force && !this.hasClass('collapsed')) return;
2016-07-13 14:43:07 +12:00
this.togglePanel(true);
},
2016-07-13 14:43:07 +12:00
collapsePanel: function collapsePanel(force) {
if (!force && this.hasClass('collapsed')) return;
2016-07-13 14:43:07 +12:00
this.togglePanel(false);
}
});
2016-07-13 14:43:07 +12:00
$('.cms-panel.collapsed .cms-panel-toggle').entwine({
onclick: function onclick(e) {
this.expandPanel();
e.preventDefault();
}
});
2016-07-13 14:43:07 +12:00
$('.cms-panel *').entwine({
getPanel: function getPanel() {
return this.parents('.cms-panel:first');
}
});
2016-07-13 14:43:07 +12:00
$('.cms-panel .toggle-expand').entwine({
onclick: function onclick(e) {
e.preventDefault();
e.stopPropagation();
2016-07-13 14:43:07 +12:00
this.getPanel().expandPanel();
2016-07-13 14:43:07 +12:00
this._super(e);
}
});
2016-07-13 14:43:07 +12:00
$('.cms-panel .toggle-collapse').entwine({
onclick: function onclick(e) {
e.preventDefault();
e.stopPropagation();
2016-07-13 14:43:07 +12:00
this.getPanel().collapsePanel();
2016-07-13 14:43:07 +12:00
this._super(e);
}
});
2016-07-13 14:43:07 +12:00
$('.cms-content-tools.collapsed').entwine({
onclick: function onclick(e) {
this.expandPanel();
this._super(e);
}
});
});
});