1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- (function ($) {
- var opt; $.fn.jqprint = function (options) {
- opt = $.extend({
- }, $.fn.jqprint.defaults, options); var $element = (this instanceof jQuery) ? this : $(this); if (opt.operaSupport && $.browser.opera) {
- var tab = window.open("", "jqPrint-preview"); tab.document.open(); var doc = tab.document;
- }
- else {
- var $iframe = $("<iframe />"); if (!opt.debug) {
- $iframe.css({
- position: "absolute", width: "0px", height: "0px", left: "-600px", top: "-600px"
- });
- }
- $iframe.appendTo("body"); var doc = $iframe[0].contentWindow.document;
- }
- if (opt.importCSS) {
- if ($("link[media=print]").length > 0) {
- $("link[media=print]").each(function () {
- doc.write("<link type='text/css' rel='stylesheet' href='" + $(this).attr("href") + "' media='print' />");
- });
- if (opt.portrait) {
- doc.write('<style> @page { size: landscape;}</style>');
- } else {
- doc.write('<style> @page { size: portrait;}</style>');
- }
- }
- else {
- $("link").each(function () {
- doc.write("<link type='text/css' rel='stylesheet' href='" + $(this).attr("href") + "' />");
- });
- if (opt.portrait) {
- doc.write('<style> @page { size: landscape;}</style>');
- } else {
- doc.write('<style> @page { size: portrait;}</style>');
- }
- }
- }
- if (opt.printContainer) {
- doc.write($element.outer());
- }
- else {
- $element.each(function () {
- doc.write($(this).html());
- });
- }
- doc.close(); (opt.operaSupport && $.browser.opera ? tab : $iframe[0].contentWindow).focus(); setTimeout(function () {
- (opt.operaSupport && $.browser.opera ? tab : $iframe[0].contentWindow).print();
- if (tab) {
- tab.close();
- }
- }, 1000);
- }
- $.fn.jqprint.defaults = {
- debug: false, importCSS: true, printContainer: true, operaSupport: true, portrait: true
- };
- jQuery.fn.outer = function () {
- return $($('<div></div>').html(this.clone())).html();
- }
- })(jQuery);
|