/* ** sudyfocus */ ! function($) { $.fn.sudyfocus = function(opts) { function setfoucs(a) { $.each(a, function(a, b) { if ("img_meta" in o.json[a] && !$.isEmptyObject(o.json[a].img_meta)) { var c = $(b).find("img").eq(0), d = o.json[a].img_meta.focusWidth, e = o.json[a].img_meta.focusHeight, f = d / e, g = o.json[a].img_meta.realWidth, h = o.json[a].img_meta.realHeight, i = g / h, j = { X: o.json[a].img_meta.left, Y: o.json[a].img_meta.top }, k = j.X, l = j.Y; j.X = g > 2 * k + d ? 0 : 2 * k + d - g, j.Y = h > 2 * l + e ? 0 : 2 * l + e - h, d = 0 == j.X ? d + 2 * k: g - j.X, e = 0 == j.Y ? e + 2 * l: h - j.Y, f = d / e; var m, n = {}; r > f ? (m = zW / d, g = m * g, h = g / i, d = zW, e = d / f, n.X = m * j.X + d / 2, n.Y = m * j.Y + e / 2) : (m = zH / e, h = m * h, g = h * i, e = zH, d = e * f, n.X = m * j.X + d / 2, n.Y = m * j.Y + e / 2), c.css({ display: "block", width: g + "px", height: h + "px", position: "absolute", left: zW / 2 - n.X + "px", top: zH / 2 - n.Y + "px" }) } }) } var defaults = { p: null, json: [], title: { active: !0, isAutoWidth: !1, href: !1, prefix: "", suffix: "" }, text: { active: !1, isAutoHeight: !1, href: !1 }, href: !0, zWidth: 420, zHeight: 270, response: !0, navigation: !0, isNavHover: !0, pagination: !1, effect: "slide", speed: 500, crossfade: !0, start: 1, autoPlay: !0, interval: 5e3, trigger: "mouseenter", callback: function(){} }, o = $.extend(!0, {}, defaults, opts), zW = o.zWidth, zH = o.zHeight, r = zW / zH; return null !== o.p && "function" == eval("typeof getImgJson") && (o.json = getImgJson(o.p).concat(o.json)), this.each(function() { function n() { a.css({ width: zW + "px", height: zH + "px" }).addClass("focus-box"), d.css({ width: zW + "px", height: zH + "px", visibility: "visible" }) } function u() { g.hide(), h.hide(), "slide" == o.effect ? t.slide() : "fade" == o.effect ? t.fade() : t.show(), k.removeClass("focus-page-active").eq(q).addClass("focus-page-active"); km.removeClass("focus-page-active").eq(q).addClass("focus-page-active"); var a = o.title.prefix + $.trim(o.json[q].title || "") + o.title.suffix, b = $.trim(o.json[q].text || ""); if ($url = $.trim(o.json[q].url || ""), "" !== $url && "#" !== $url) { var c = $(''); o.href && e.eq(q).find("a").length < 1 && e.eq(q).wrapInner(c), o.title.href && "" !== a && (a = c.clone().html(a)), o.text.href && "" !== b && (b = c.clone().html(b)) } "" !== a && (g.show(), l.html(a)), "" !== b && (h.show(), m.html(b)), o.title.isAutoWidth && l.parent().css("width", l.outerWidth()), o.text.isAutoHeight && m.parent().parent().css("height", m.outerHeight()), s = q; if(typeof o.callback === "function"){ o.callback.call(this, q, o); } } function v() { q++, q > f - 1 && (q = 0), u() } function w() { q--, 0 > q && (q = f - 1), u() } function x() { var b; a.hover(function() { clearInterval(b) }, function() { b = setInterval(function() { v() }, o.interval) }).trigger("mouseleave") } var a = $(this), b = a.children(), c = []; if ($.each(b, function(a, b) { var d = {}; d.title = $(b).attr("data-focus-title") || "", d.url = $(b).attr("data-focus-url") || "", d.text = $(b).attr("data-focus-text") || "", c.push(d) }), a.html(function(a, b) { return $.each(o.json, function() { b += '' }), b }), o.json = c.concat(o.json), o.json.length < 1) return a.html("\u7a97\u53e3\u672a\u7ed1\u5b9a\u6216\u65e0\u6587\u7ae0"); a.children().wrap('
').end().wrapInner('
'); var fimg = $(".focus-item", a), d = $(".focus-container", a), e = $(".focus-item", d).hide(), f = e.length; o.title.active && $('

').appendTo(a), o.text.active && $('

').appendTo(a), o.navigation && f > 1 && $('<>').appendTo(a), o.pagination && f > 1 && a.append(function() { var a, b, c = $('
'); for (a = 0; f > a; a++) b = a + 1, c.append(''); return c //$(".focus-pagination").children("a").wrapAll('
>
'); }); o.pagination && f > 1 && a.append(function() { var a, b, c = $('
'); for (a = 0; f > a; a++) b = a + 1, c.append('
'+ o.json[a].time +'
'); return c }); a.append("
"); $(".focus-pagination1").find(".focus-time").each(function(){ var fyue = $(this).find(".yue").text(); var date = fyue.split("-"), m = date[0], d = date[1]; m = getMonthEN(m); $(this).find(".yue").before('
' + m +' '+ d + '
'); }); function getMonthEN(n) { var num = parseInt(n, 10), month = ""; if (num == 1) { month = "Jan" } if (num == 2) { month = "Feb" } if (num == 3) { month = "Mar" } if (num == 4) { month = "Apr" } if (num == 5) { month = "May" } if (num == 6) { month = "Jun" } if (num == 7) { month = "Jul" } if (num == 8) { month = "Aug" } if (num == 9) { month = "Sep" } if (num == 10) { month = "Oct" } if (num == 11) { month = "Nov" } if (num == 12) { month = "Dec" } return month; } $(".focus-title-bar,.focus-pagination,.focus-pagination1,.focus-bg").wrapAll('
'); $(".focus-page").wrapAll('
').wrapAll('
'); $(".focus-pagination").append('
>>
'); var linum= $('.btn-ms').children("a").length; var width= $('.btn-ms').children("a").width(); var btns = true; $(".focus-pagination").children(".btns").on("click",function(){ if(btns){ $(this).text("<<"); $(this).parent().find(".btn-ms").stop(true,true).animate({left:-(width+10)*linum/2},1000); btns = false; }else{ $(this).text(">>"); $(this).parent().find(".btn-ms").stop(true,true).animate({left:0},1000); btns = true; } }); var g = $(".focus-title-bar", a), h = $(".focus-text-box", a), i = $(".focus-navigation", a), j = $(".focus-pagination", a), jm = $(".focus-pagination1", a), k = $(".focus-page", j), km = $(".focus-time", jm), l = $(".focus-title", g), m = $(".focus-text", h); if (o.isNavHover && (i.hide(), a.hover(function() { i.show() }, function() { i.hide() })), o.response) { var p = a.parent().width(); zW = p, zH = zW / r, $(window).resize(function() { p = a.parent().width(), zW = p, zH = zW / r, n(), setfoucs(e) }) } n(), setfoucs(e); var q = o.start > f ? f - 1 : o.start - 1, s = q, t = { show: function() { e.eq(s).hide().end().eq(q).show() }, slide: function() { function a() { e.eq(q).css({ left: "100%" }), e.eq(s).stop(!0, !0).animate({ left: "-100%" }, o.speed), e.eq(q).stop(!0, !1).animate({ left: "0%" }, o.speed) } function b() { e.eq(q).css({ left: "-100%" }), e.eq(s).stop(!0, !0).animate({ left: "100%" }, o.speed), e.eq(q).stop(!0, !1).animate({ left: "0%" }, o.speed) } e.eq(s).show().end().eq(q).show(), f > 1 && (0 == s && q == f - 1 || s == f - 1 && 0 == q ? (0 == s && q == f - 1 && b(), s == f - 1 && 0 == q && a()) : (q > s && a(), s > q && b())) }, fade: function() { o.crossfade ? e.eq(s).stop().fadeOut(o.speed).end().eq(q).fadeIn(o.speed) : e.eq(s).stop().hide().end().eq(q).fadeIn(o.speed) } }; o.autoPlay && x(); var y = $(".focus-prev", a), z = $(".focus-next", a); y.click(function() { w() }), z.click(function() { v() }), k.on(o.trigger, function() { q = $(this).index(), u() }), $.fn.sudyTouch && d.sudyTouch({ swipeStart: function() { a.trigger("mouseenter") }, swipeLeft: function() { v() }, swipeRight: function() { w() }, swipeEnd: function() { a.trigger("mouseleave") } }), u() }) } } (jQuery);