Вы не можете выбрать более 25 тем
Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
107 строки
3.9 KiB
107 строки
3.9 KiB
6 лет назад
|
/* Plugin: jSide Menu (Responsive Side Menu)
|
||
|
* Frameworks: jQuery 3.3.1 & Material Design Iconic Font 2.0
|
||
|
* Author: Asif Mughal
|
||
|
* GitHub: https://github.com/CodeHimBlog
|
||
|
* URL: https://www.codehim.com
|
||
|
* License: MIT License
|
||
|
* Copyright (c) 2018 - Asif Mughal
|
||
|
*/
|
||
|
/* File: jquery.jside.menu.js */
|
||
|
(function ($) {
|
||
|
$.fn.jSideMenu = function (options) {
|
||
|
var setting = $.extend({
|
||
|
jSidePosition: "position-left", //possible options position-left or position-right
|
||
|
jSideSticky: true, // menubar will be fixed on top, false to set static
|
||
|
jSideSkin: "default-skin", // to apply custom skin, just put its name in this string
|
||
|
|
||
|
}, options);
|
||
|
|
||
|
return this.each(function () {
|
||
|
var target, $headHeight,
|
||
|
$devHeight,
|
||
|
jSide,
|
||
|
arrow,
|
||
|
dimBackground;
|
||
|
target = $(this);
|
||
|
|
||
|
/* Accessing DOM */
|
||
|
jSide = $(".menu-container, .menu-head");
|
||
|
$devHeight = $(window).height();
|
||
|
$headHeight = $(".menu-head").height();
|
||
|
arrow = document.createElement("i");
|
||
|
dimBackground = $(".dim-overlay");
|
||
|
// Set the height of side menu according to the available height of device
|
||
|
$(target).css({
|
||
|
'height': $devHeight - $headHeight,
|
||
|
|
||
|
});
|
||
|
|
||
|
if (setting.jSideSticky == true) {
|
||
|
$(".menubar").addClass("sticky");
|
||
|
} else {
|
||
|
$(".menubar").removeClass("sticky");
|
||
|
}
|
||
|
|
||
|
$(".menubar").addClass(setting.jSideSkin);
|
||
|
$(jSide).addClass(setting.jSideSkin).addClass(setting.jSidePosition);
|
||
|
|
||
|
if ($(jSide).hasClass("position-left")) {
|
||
|
$(".menu-trigger").addClass("left").removeClass("right");
|
||
|
} else {
|
||
|
$(".menu-trigger").removeClass("left").addClass("right");
|
||
|
}
|
||
|
|
||
|
//Dropdown Arrow
|
||
|
$(arrow).addClass("zmdi zmdi-chevron-down arrow").appendTo(".dropdown-heading");
|
||
|
|
||
|
//Dropdowns
|
||
|
$(".dropdown-heading").click(function () {
|
||
|
var n = $(".has-sub").find("span:hover + ul li").length;
|
||
|
var h = $(".has-sub").find("span:hover + ul li").outerHeight();
|
||
|
var dropdown = h * n;
|
||
|
var todrop = $(".has-sub").find("span:hover + ul");
|
||
|
var nodrop = $(".has-sub ul");
|
||
|
|
||
|
$(todrop).animate({"height": dropdown}, 100);
|
||
|
$(this).find("i").toggleClass("arrowdown");
|
||
|
if ($(todrop).height() == dropdown) {
|
||
|
$(todrop).animate({"height": 0}, 100);
|
||
|
}
|
||
|
|
||
|
if ($(nodrop).height(dropdown)) {
|
||
|
$(nodrop).not(todrop).height(0);
|
||
|
$(".dropdown-heading").not(this).find("i").removeClass("arrowdown");
|
||
|
}
|
||
|
});
|
||
|
|
||
|
$(".menu-trigger").click(function () {
|
||
|
$(jSide).toggleClass("open");
|
||
|
$(dimBackground).show(500);
|
||
|
|
||
|
});
|
||
|
|
||
|
//close menu if user click outside of it
|
||
|
$(window).click(function (e) {
|
||
|
if ($(e.target).closest('.menu-trigger').length) {
|
||
|
return;
|
||
|
}
|
||
|
if ($(e.target).closest(jSide).length) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$(jSide).removeClass("open");
|
||
|
if (!$(jSide).hasClass("open")) {
|
||
|
$(dimBackground).hide(500);
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
};
|
||
|
|
||
|
})(jQuery);
|
||
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|