From bc8721fb6c704255fd8be9edc9372e4d17adaee9 Mon Sep 17 00:00:00 2001 From: Unknwon Date: Wed, 10 Dec 2014 16:37:54 -0500 Subject: [PATCH] Finish new UI for release page --- cmd/web.go | 13 +-- conf/locale/locale_en-US.ini | 24 ++++++ modules/auth/apiv1/miscellaneous.go | 2 +- modules/auth/repo_form.go | 1 - public/ng/css/gogs.css | 107 ++++++++++++++++++++++- public/ng/css/ui.css | 1 + public/ng/js/gogs.js | 25 ++++++ public/ng/js/min/gogs-min.js | 8 +- public/ng/less/gogs/repository.less | 108 ++++++++++++++++++++++- public/ng/less/ui/form.less | 1 + routers/api/v1/miscellaneous.go | 5 ++ routers/repo/release.go | 92 +++++++++++--------- templates/repo/home.tmpl | 2 +- templates/repo/release/edit.tmpl | 117 ++++++++++++------------- templates/repo/release/list.tmpl | 127 +++++++++++++++------------- templates/repo/release/new.tmpl | 126 ++++++++++++++------------- 16 files changed, 520 insertions(+), 239 deletions(-) diff --git a/cmd/web.go b/cmd/web.go index 9975fa237b..ba999dbf98 100644 --- a/cmd/web.go +++ b/cmd/web.go @@ -397,14 +397,17 @@ func runWeb(*cli.Context) { }) m.Post("/comment/:action", repo.Comment) - m.Get("/releases/new", repo.NewRelease) - m.Post("/releases/new", bindIgnErr(auth.NewReleaseForm{}), repo.NewReleasePost) - m.Get("/releases/edit/:tagname", repo.EditRelease) - m.Post("/releases/edit/:tagname", bindIgnErr(auth.EditReleaseForm{}), repo.EditReleasePost) + + m.Group("/releases", func() { + m.Get("/new", repo.NewRelease) + m.Post("/new", bindIgnErr(auth.NewReleaseForm{}), repo.NewReleasePost) + m.Get("/edit/:tagname", repo.EditRelease) + m.Post("/edit/:tagname", bindIgnErr(auth.EditReleaseForm{}), repo.EditReleasePost) + }, middleware.RepoRef()) }, reqSignIn, middleware.RepoAssignment(true)) m.Group("/:username/:reponame", func() { - m.Get("/releases", repo.Releases) + m.Get("/releases", middleware.RepoRef(), repo.Releases) m.Get("/issues", repo.Issues) m.Get("/issues/:index", repo.ViewIssue) m.Get("/issues/milestones", repo.Milestones) diff --git a/conf/locale/locale_en-US.ini b/conf/locale/locale_en-US.ini index 2b60811206..36430af75f 100644 --- a/conf/locale/locale_en-US.ini +++ b/conf/locale/locale_en-US.ini @@ -377,6 +377,30 @@ diff.stats_desc = %d changed files with %d additions%d commits to %s since this release +release.source_code = Source Code +release.tag_name = Tag name +release.target = Target +release.tag_helper = Choose an existing tag, or create a new tag on publish. +release.release_title = Release title +release.content_with_md = Content with Markdown +release.write = Write +release.preview = Preview +release.content_placeholder = Write some content +release.loading = Loading... +release.prerelease_desc = This is a pre-release +release.prerelease_helper = We’ll point out that this release is identified as non-production ready. +release.publish = Publish Release +release.save_draft = Save Draft +release.edit_release = Edit Release +release.tag_name_already_exist = Release with this tag name has already existed. + [org] org_name_holder = Organization Name org_name_helper = Great organization names are short and memorable. diff --git a/modules/auth/apiv1/miscellaneous.go b/modules/auth/apiv1/miscellaneous.go index 71f9541a9c..d470ff0e45 100644 --- a/modules/auth/apiv1/miscellaneous.go +++ b/modules/auth/apiv1/miscellaneous.go @@ -14,7 +14,7 @@ import ( ) type MarkdownForm struct { - Text string `form:"text" binding:"Required"` + Text string `form:"text"` Mode string `form:"mode"` Context string `form:"context"` } diff --git a/modules/auth/repo_form.go b/modules/auth/repo_form.go index 7901ce8777..41c0217a93 100644 --- a/modules/auth/repo_form.go +++ b/modules/auth/repo_form.go @@ -164,7 +164,6 @@ func (f *NewReleaseForm) Validate(ctx *macaron.Context, errs binding.Errors) bin } type EditReleaseForm struct { - Target string `form:"tag_target" binding:"Required"` Title string `form:"title" binding:"Required"` Content string `form:"content" binding:"Required"` Draft string `form:"draft"` diff --git a/public/ng/css/gogs.css b/public/ng/css/gogs.css index a052b3497d..56fe208a39 100644 --- a/public/ng/css/gogs.css +++ b/public/ng/css/gogs.css @@ -1072,7 +1072,8 @@ The register and sign-in page style text-overflow: clip; } #repo-content { - padding: 18px 0; + padding-top: 18px; + padding-bottom: 18px; } .repo-wide-wrapper { padding: 18px; @@ -1353,31 +1354,54 @@ The register and sign-in page style #repo-create-cancel { margin-left: 4em; } +#release-new-target-branch-list, #repo-create-owner-list { top: 30px; left: 0; width: auto; max-width: 300px; } +#release-new-target-branch-list .octicon, #repo-create-owner-list .octicon { margin-right: 12px; opacity: 0; } +#release-new-target-branch-list .avatar, #repo-create-owner-list .avatar { width: 20px; height: 20px; } +#release-new-target-branch-list li, #repo-create-owner-list li { white-space: nowrap; } +#release-new-target-branch-list li.checked .octicon, #repo-create-owner-list li.checked .octicon { opacity: 1; } +#release-new-target-branch-list li a, #repo-create-owner-list li a { text-overflow: ellipsis; -o-text-overflow: ellipsis; overflow: hidden; } +#release-new-target-branch-list { + margin-top: -1px; + min-width: 150px; +} +#release-new-title { + margin-top: 10px; +} +#release-new-content { + width: 100%; +} +#release-preview-btn .btn { + border-left: 0; +} +#release-preview.markdown { + margin-top: 5px; + background-color: transparent; +} .file-name { margin-left: 1em; } @@ -1622,6 +1646,87 @@ The register and sign-in page style margin-left: 44px; margin-top: -15px; } +#release h4 { + font-size: 18px; +} +#release h4 small { + font-weight: 400; + line-height: 1; + color: #999; +} +#release #release-head { + margin-top: 0; + margin-bottom: 0; + padding-bottom: 20px; + border-bottom: 1px solid #DDD; +} +#release #release-head .btn { + margin-left: 10px; +} +#release .release-item > div { + padding-top: 20px; + padding-bottom: 20px; +} +#release .release-item .label-green:hover { + background-color: #65ad4e; +} +#release .release-item .release-meta { + position: relative; + float: left; + padding-right: 15px; +} +#release .release-item .tag, +#release .release-item .commit { + display: block; + margin-top: 12px; + line-height: 20px; +} +#release .release-item .release-detail { + margin-top: -1px; + border-left: 1px solid #DDD; + position: relative; + float: left; + padding-left: 15px; +} +#release .release-item .title { + line-height: 25px; + margin-top: 0; +} +#release .release-item p.info { + line-height: 20px; + color: #666; + margin-bottom: 15px; +} +#release .release-item p.info > * { + margin-right: 10px; +} +#release .release-item .author img { + margin-top: -3px; +} +#release .release-item div.desc { + margin-bottom: 25px; +} +#release .release-item div.desc.markdown { + background-color: transparent; +} +#release .release-item .download a { + margin-right: 10px; +} +#release .release-item .dot { + width: 9px; + height: 9px; + background-color: #ccc; + z-index: 999; + position: absolute; + display: block; + left: -6px; + top: 27px; + border-radius: 6px; + border: 1px solid #FFF; +} +#release #release-new-form { + padding-top: 15px; +} #admin-wrapper, #setting-wrapper { padding-bottom: 100px; diff --git a/public/ng/css/ui.css b/public/ng/css/ui.css index a33d9a7a15..d4a8170ed0 100644 --- a/public/ng/css/ui.css +++ b/public/ng/css/ui.css @@ -379,6 +379,7 @@ dt { } .btn-large { font-size: 14.4px; + padding: .4em .9em; } .btn-green { background-color: #65ad4e; diff --git a/public/ng/js/gogs.js b/public/ng/js/gogs.js index b3749ca0dd..10bf20f0fc 100644 --- a/public/ng/js/gogs.js +++ b/public/ng/js/gogs.js @@ -403,6 +403,16 @@ function initRepo() { $clone_btn.tipsy({ fade: true }); + + // Markdown preview. + $('.markdown-preview').click(function() { + var $this = $(this); + $this.toggleAjax(function (resp) { + $($this.data("preview")).html(resp); + }, function () { + $($this.data("preview")).html("no content"); + }) + }); } // when user changes hook type, hide/show proper divs @@ -423,6 +433,13 @@ function initHookTypeChange() { }); } +function initRepoRelease() { + $('#release-new-target-branch-list li').click(function() { + $('#repo-branch-current').text($(this).text()); + $('#tag-target').val($(this).text()); + }) +} + function initRepoSetting() { // Options. // Confirmation of changing repository name. @@ -753,8 +770,12 @@ $(document).ready(function () { initRepoCreate(); } if ($('#repo-header').length) { + initTimeSwitch(); initRepo(); } + if ($('#release').length) { + initRepoRelease(); + } if ($('#repo-setting').length) { initRepoSetting(); } @@ -819,3 +840,7 @@ function homepage() { $('#promo-form').attr('action', Gogs.AppSubUrl + '/user/sign_up'); }); } + +String.prototype.endsWith = function (suffix) { + return this.indexOf(suffix, this.length - suffix.length) !== -1; +}; diff --git a/public/ng/js/min/gogs-min.js b/public/ng/js/min/gogs-min.js index 0d256ed7eb..bcc39f7e95 100644 --- a/public/ng/js/min/gogs-min.js +++ b/public/ng/js/min/gogs-min.js @@ -1,5 +1,5 @@ -function Tabs(e){function t(e){console.log("hide",e),e.removeClass("js-tab-nav-show"),$(e.data("tab-target")).removeClass("js-tab-show").hide()}function n(e){console.log("show",e),e.addClass("js-tab-nav-show"),$(e.data("tab-target")).addClass("js-tab-show").show()}var r=$(e);if(r.length){var i=r.find(".js-tab-nav-show");i.length&&$(i.data("tab-target")).addClass("js-tab-show"),r.on("click",".js-tab-nav",function(e){e.preventDefault();var o=$(this);o.hasClass("js-tab-nav-show")||(i=r.find(".js-tab-nav-show").eq(0),t(i),n(o))}),console.log("init tabs @",e)}}function Preview(e,t){function n(e){return e.find(".js-preview-input").eq(0)}function r(e){return e.hasClass("js-preview-container")?e:e.find(".js-preview-container").eq(0)}var i=$(e),o=$(t),a=n(o);if(!a.length)return void console.log("[preview]: no preview input");var s=r(o);return s.length?(i.on("click",function(){$.post("/api/v1/markdown",{text:a.val()},function(e){s.html(e)})}),void console.log("[preview]: init preview @",e,"&",t)):void console.log("[preview]: no preview container")}function initCore(){Gogs.renderMarkdown(),Gogs.renderCodeView(),$(".js-tab-nav").click(function(e){$(this).hasClass("js-tab-nav-show")||($(this).parent().find(".js-tab-nav-show").each(function(){$(this).removeClass("js-tab-nav-show"),$($(this).data("tab-target")).hide()}),$(this).addClass("js-tab-nav-show"),$($(this).data("tab-target")).show()),e.preventDefault()}),$(document).on("click",".popup-modal-dismiss",function(e){e.preventDefault(),$.magnificPopup.close()}),$(".collapse").hide(),$(".tipsy-tooltip").tipsy({fade:!0})}function initUserSetting(){var t=$("#username"),n=$("#user-profile-form");$("#change-username-btn").magnificPopup({modal:!0,callbacks:{open:function(){t.data("uname")==t.val()&&($.magnificPopup.close(),n.submit())}}}).click(function(){return t.data("uname")!=t.val()?(e.preventDefault(),!0):void 0}),$("#change-username-submit").click(function(){$.magnificPopup.close(),n.submit()}),$(".show-form-btn").click(function(){$($(this).data("target-form")).removeClass("hide")}),$("#delete-account-btn").magnificPopup({modal:!0}).click(function(e){return e.preventDefault(),!0}),$("#delete-account-submit").click(function(){$.magnificPopup.close(),$("#delete-account-form").submit()})}function initRepoCreate(){$("#repo-create-owner-list").on("click","li",function(){if(!$(this).hasClass("checked")){var e=$(this).data("uid");$("#repo-owner-id").val(e),$("#repo-owner-avatar").attr("src",$(this).find("img").attr("src")),$("#repo-owner-name").text($(this).text().trim()),$(this).parent().find(".checked").removeClass("checked"),$(this).addClass("checked"),console.log("set repo owner to uid :",e,$(this).text().trim())}}),$("#auth-button").click(function(e){$("#repo-migrate-auth").slideToggle("fast"),e.preventDefault()}),console.log("initRepoCreate")}function initRepo(){$("#repo-clone-ssh").click(function(){$(this).removeClass("btn-gray").addClass("btn-blue"),$("#repo-clone-https").removeClass("btn-blue").addClass("btn-gray"),$("#repo-clone-url").val($(this).data("link")),$(".clone-url").text($(this).data("link"))}),$("#repo-clone-https").click(function(){$(this).removeClass("btn-gray").addClass("btn-blue"),$("#repo-clone-ssh").removeClass("btn-blue").addClass("btn-gray"),$("#repo-clone-url").val($(this).data("link")),$(".clone-url").text($(this).data("link"))});var e=$("#repo-clone-copy");e.hover(function(){Gogs.bindCopy($(this))}),e.tipsy({fade:!0})}function initHookTypeChange(){$("select#hook-type").on("change",function(){hookTypes=["Gogs","Slack"];var e=$(this).val();hookTypes.forEach(function(t){e===t?$("div#"+t.toLowerCase()).toggleShow():$("div#"+t.toLowerCase()).toggleHide()})})}function initRepoSetting(){var t=$("#repo_name"),n=$("#repo-setting-form");$("#change-reponame-btn").magnificPopup({modal:!0,callbacks:{open:function(){t.data("repo-name")==t.val()&&($.magnificPopup.close(),n.submit())}}}).click(function(){return t.data("repo-name")!=t.val()?(e.preventDefault(),!0):void 0}),$("#change-reponame-submit").click(function(){$.magnificPopup.close(),n.submit()}),initHookTypeChange(),$("#transfer-repo-btn").magnificPopup({modal:!0}),$("#transfer-repo-submit").click(function(){$.magnificPopup.close(),$("#transfer-repo-form").submit()}),$("#delete-repo-btn").magnificPopup({modal:!0}),$("#delete-repo-submit").click(function(){$.magnificPopup.close(),$("#delete-repo-form").submit()}),$("#repo-collab-list hr:last-child").remove();var r=$("#repo-collaborator").next().next().find("ul");$("#repo-collaborator").on("keyup",function(){var e=$(this);return e.val()?void Gogs.searchUsers(e.val(),r):void r.toggleHide()}).on("focus",function(){$(this).val()?r.toggleShow():r.toggleHide()}).next().next().find("ul").on("click","li",function(){$("#repo-collaborator").val($(this).text()),r.toggleHide()})}function initOrgSetting(){var t=$("#orgname"),n=$("#org-setting-form");$("#change-orgname-btn").magnificPopup({modal:!0,callbacks:{open:function(){t.data("orgname")==t.val()&&($.magnificPopup.close(),n.submit())}}}).click(function(){return t.data("orgname")!=t.val()?(e.preventDefault(),!0):void 0}),$("#change-orgname-submit").click(function(){$.magnificPopup.close(),n.submit()}),$("#delete-org-btn").magnificPopup({modal:!0}).click(function(e){return e.preventDefault(),!0}),$("#delete-org-submit").click(function(){$.magnificPopup.close(),$("#delete-org-form").submit()}),initHookTypeChange()}function initInvite(){var e=$("#org-member-invite-list");$("#org-member-invite").on("keyup",function(){var t=$(this);return t.val()?void Gogs.searchUsers(t.val(),e):void e.toggleHide()}).on("focus",function(){$(this).val()?e.toggleShow():e.toggleHide()}).next().next().find("ul").on("click","li",function(){$("#org-member-invite").val($(this).text()),e.toggleHide()})}function initOrgTeamCreate(){$("#org-team-delete").magnificPopup({modal:!0}).click(function(e){return e.preventDefault(),!0}),$("#delete-team-submit").click(function(){$.magnificPopup.close();var e=$("#team-create-form");e.attr("action",e.data("delete-url"))})}function initTeamMembersList(){var e=$("#org-team-members-list");$("#org-team-members-add").on("keyup",function(){var t=$(this);return t.val()?void Gogs.searchUsers(t.val(),e):void e.toggleHide()}).on("focus",function(){$(this).val()?e.toggleShow():e.toggleHide()}).next().next().find("ul").on("click","li",function(){$("#org-team-members-add").val($(this).text()),e.toggleHide()})}function initTeamRepositoriesList(){var e=$("#org-team-repositories-list");$("#org-team-repositories-add").on("keyup",function(){var t=$(this);return t.val()?void Gogs.searchRepos(t.val(),e,"uid="+t.data("uid")):void e.toggleHide()}).on("focus",function(){$(this).val()?e.toggleShow():e.toggleHide()}).next().next().find("ul").on("click","li",function(){$("#org-team-repositories-add").val($(this).text()),e.toggleHide()})}function initAdmin(){$("#login-type").on("change",function(){var e=$(this).val();e.indexOf("0-")+1?($(".auth-name").toggleHide(),$(".pwd").find("input").attr("required","required").end().toggleShow()):($(".pwd").find("input").removeAttr("required").end().toggleHide(),$(".auth-name").toggleShow())}),$("#delete-account-btn").magnificPopup({modal:!0}).click(function(e){return e.preventDefault(),!0}),$("#delete-account-submit").click(function(){$.magnificPopup.close();var e=$("#user-profile-form");e.attr("action",e.data("delete-url"))}),$("#auth-type").on("change",function(){var e=$(this).val();2==e&&($(".ldap").toggleShow(),$(".smtp").toggleHide()),3==e&&($(".smtp").toggleShow(),$(".ldap").toggleHide())}),$("#delete-auth-btn").magnificPopup({modal:!0}).click(function(e){return e.preventDefault(),!0}),$("#delete-auth-submit").click(function(){$.magnificPopup.close();var e=$("#auth-setting-form");e.attr("action",e.data("delete-url"))})}function initInstall(){!function(){var e="127.0.0.1:3306",t="127.0.0.1:5432";$("#install-database").on("change",function(){var n=$(this).val();"SQLite3"!=n?($(".server-sql").show(),$(".sqlite-setting").addClass("hide"),"PostgreSQL"==n?($(".pgsql-setting").removeClass("hide"),$("#database-host").val()==e&&$("#database-host").val(t)):"MySQL"==n?($(".pgsql-setting").addClass("hide"),$("#database-host").val()==t&&$("#database-host").val(e)):$(".pgsql-setting").addClass("hide")):($(".server-sql").hide(),$(".pgsql-setting").hide(),$(".sqlite-setting").removeClass("hide"))})}()}function initProfile(){$("#profile-avatar").tipsy({fade:!0})}function initTimeSwitch(){$(".time-since[title]").on("click",function(){var e=$(this),t=e.attr("title"),n=e.text();e.text(t),e.attr("title",n)})}function initDiff(){$(".diff-detail-box>a").click(function(){$($(this).data("target")).slideToggle(100)});var e=$(".diff-counter");e.length<1||e.each(function(e,t){var n=$(t),r=n.find("span[data-line].add").data("line"),i=n.find("span[data-line].del").data("line"),o=parseFloat(r)/(parseFloat(r)+parseFloat(i))*100;n.find(".bar .add").css("width",o+"%")})}function homepage(){$("#promo-form").submit(function(e){return""===$("#username").val()?(e.preventDefault(),window.location.href=Gogs.AppSubUrl+"/user/login",!0):void 0}),$("#register-button").click(function(e){return""===$("#username").val()?(e.preventDefault(),window.location.href=Gogs.AppSubUrl+"/user/sign_up",!0):void $("#promo-form").attr("action",Gogs.AppSubUrl+"/user/sign_up")})}!function(e,t){"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(e,t){function n(e){var t=e.length,n=ot.type(e);return"function"===n||ot.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||0===t||"number"==typeof t&&t>0&&t-1 in e}function r(e,t,n){if(ot.isFunction(t))return ot.grep(e,function(e,r){return!!t.call(e,r,e)!==n});if(t.nodeType)return ot.grep(e,function(e){return e===t!==n});if("string"==typeof t){if(pt.test(t))return ot.filter(t,e,n);t=ot.filter(t,e)}return ot.grep(e,function(e){return ot.inArray(e,t)>=0!==n})}function i(e,t){do e=e[t];while(e&&1!==e.nodeType);return e}function o(e){var t=wt[e]={};return ot.each(e.match(xt)||[],function(e,n){t[n]=!0}),t}function a(){mt.addEventListener?(mt.removeEventListener("DOMContentLoaded",s,!1),e.removeEventListener("load",s,!1)):(mt.detachEvent("onreadystatechange",s),e.detachEvent("onload",s))}function s(){(mt.addEventListener||"load"===event.type||"complete"===mt.readyState)&&(a(),ot.ready())}function l(e,t,n){if(void 0===n&&1===e.nodeType){var r="data-"+t.replace($t,"-$1").toLowerCase();if(n=e.getAttribute(r),"string"==typeof n){try{n="true"===n?!0:"false"===n?!1:"null"===n?null:+n+""===n?+n:Tt.test(n)?ot.parseJSON(n):n}catch(i){}ot.data(e,t,n)}else n=void 0}return n}function c(e){var t;for(t in e)if(("data"!==t||!ot.isEmptyObject(e[t]))&&"toJSON"!==t)return!1;return!0}function u(e,t,n,r){if(ot.acceptData(e)){var i,o,a=ot.expando,s=e.nodeType,l=s?ot.cache:e,c=s?e[a]:e[a]&&a;if(c&&l[c]&&(r||l[c].data)||void 0!==n||"string"!=typeof t)return c||(c=s?e[a]=V.pop()||ot.guid++:a),l[c]||(l[c]=s?{}:{toJSON:ot.noop}),("object"==typeof t||"function"==typeof t)&&(r?l[c]=ot.extend(l[c],t):l[c].data=ot.extend(l[c].data,t)),o=l[c],r||(o.data||(o.data={}),o=o.data),void 0!==n&&(o[ot.camelCase(t)]=n),"string"==typeof t?(i=o[t],null==i&&(i=o[ot.camelCase(t)])):i=o,i}}function d(e,t,n){if(ot.acceptData(e)){var r,i,o=e.nodeType,a=o?ot.cache:e,s=o?e[ot.expando]:ot.expando;if(a[s]){if(t&&(r=n?a[s]:a[s].data)){ot.isArray(t)?t=t.concat(ot.map(t,ot.camelCase)):t in r?t=[t]:(t=ot.camelCase(t),t=t in r?[t]:t.split(" ")),i=t.length;for(;i--;)delete r[t[i]];if(n?!c(r):!ot.isEmptyObject(r))return}(n||(delete a[s].data,c(a[s])))&&(o?ot.cleanData([e],!0):rt.deleteExpando||a!=a.window?delete a[s]:a[s]=null)}}}function f(){return!0}function p(){return!1}function h(){try{return mt.activeElement}catch(e){}}function m(e){var t=Ht.split("|"),n=e.createDocumentFragment();if(n.createElement)for(;t.length;)n.createElement(t.pop());return n}function g(e,t){var n,r,i=0,o=typeof e.getElementsByTagName!==kt?e.getElementsByTagName(t||"*"):typeof e.querySelectorAll!==kt?e.querySelectorAll(t||"*"):void 0;if(!o)for(o=[],n=e.childNodes||e;null!=(r=n[i]);i++)!t||ot.nodeName(r,t)?o.push(r):ot.merge(o,g(r,t));return void 0===t||t&&ot.nodeName(e,t)?ot.merge([e],o):o}function v(e){Dt.test(e.type)&&(e.defaultChecked=e.checked)}function y(e,t){return ot.nodeName(e,"table")&&ot.nodeName(11!==t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function b(e){return e.type=(null!==ot.find.attr(e,"type"))+"/"+e.type,e}function x(e){var t=Zt.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function w(e,t){for(var n,r=0;null!=(n=e[r]);r++)ot._data(n,"globalEval",!t||ot._data(t[r],"globalEval"))}function C(e,t){if(1===t.nodeType&&ot.hasData(e)){var n,r,i,o=ot._data(e),a=ot._data(t,o),s=o.events;if(s){delete a.handle,a.events={};for(n in s)for(r=0,i=s[n].length;i>r;r++)ot.event.add(t,n,s[n][r])}a.data&&(a.data=ot.extend({},a.data))}}function k(e,t){var n,r,i;if(1===t.nodeType){if(n=t.nodeName.toLowerCase(),!rt.noCloneEvent&&t[ot.expando]){i=ot._data(t);for(r in i.events)ot.removeEvent(t,r,i.handle);t.removeAttribute(ot.expando)}"script"===n&&t.text!==e.text?(b(t).text=e.text,x(t)):"object"===n?(t.parentNode&&(t.outerHTML=e.outerHTML),rt.html5Clone&&e.innerHTML&&!ot.trim(t.innerHTML)&&(t.innerHTML=e.innerHTML)):"input"===n&&Dt.test(e.type)?(t.defaultChecked=t.checked=e.checked,t.value!==e.value&&(t.value=e.value)):"option"===n?t.defaultSelected=t.selected=e.defaultSelected:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}}function S(t,n){var r,i=ot(n.createElement(t)).appendTo(n.body),o=e.getDefaultComputedStyle&&(r=e.getDefaultComputedStyle(i[0]))?r.display:ot.css(i[0],"display");return i.detach(),o}function T(e){var t=mt,n=Jt[e];return n||(n=S(e,t),"none"!==n&&n||(Kt=(Kt||ot("