@@ -62,12 +62,12 @@ | |||
border-right: 1px solid #333; | |||
} | |||
.perWeek li { | |||
width: 12.5%; | |||
float: left; | |||
border-left: 1px solid #333; | |||
height: 100%; | |||
} | |||
.perWeek li { | |||
width: 12.5%; | |||
float: left; | |||
border-left: 1px solid #333; | |||
height: 100%; | |||
} | |||
.perFestivalsBox { | |||
border-left: 1px solid #333; | |||
@@ -76,29 +76,28 @@ | |||
text-align: center; | |||
} | |||
.perFestivalsBox table { | |||
display: block; | |||
width: 100%; | |||
text-align: center; | |||
} | |||
.perFestivalsBox td { | |||
border-left: 1px solid #333; | |||
border-top: 1px solid #333; | |||
padding: 1px; | |||
width: 12.5%; | |||
font-size: 12px; | |||
} | |||
.perFestivalsBox td div { | |||
min-height: 16px; | |||
line-height: 16px; | |||
} | |||
.perFestivalsBox td:first-child, .perWeek li:first-child { | |||
border-left: 0; | |||
} | |||
.perFestivalsBox table { | |||
display: block; | |||
width: 100%; | |||
text-align: center; | |||
} | |||
.perFestivalsBox td { | |||
border-left: 1px solid #333; | |||
border-top: 1px solid #333; | |||
padding: 1px; | |||
width: 12.5%; | |||
font-size: 12px; | |||
} | |||
.perFestivalsBox td div { | |||
min-height: 16px; | |||
line-height: 16px; | |||
} | |||
.perFestivalsBox td:first-child, .perWeek li:first-child { | |||
border-left: 0; | |||
} | |||
</style> | |||
<style> | |||
.lr-select { | |||
@@ -129,7 +128,9 @@ | |||
<div class="lr-layout-tool-item"> | |||
<a id="lr_search" class="btn btn-primary">查询</a> | |||
</div> | |||
<div class="lr-layout-tool-item"> | |||
<a id="wordExport" class="btn btn-primary">导出</a> | |||
</div> | |||
</div> | |||
<div class="lr-layout-tool-right"> | |||
<div class=" btn-group btn-group-sm"> | |||
@@ -147,21 +148,44 @@ | |||
</div> | |||
<div class="lr-layout-body" style="overflow: auto;"> | |||
<div class="warpper"> | |||
<div class="personalBox"> | |||
<div class="personalBox" id="printFiled"> | |||
<div class="personT"></div> | |||
<div class="perSemester"></div> | |||
<ul class="perWeek"> | |||
<li>节次/星期</li> | |||
<li>星期一</li> | |||
<li>星期二</li> | |||
<li>星期三</li> | |||
<li>星期四</li> | |||
<li>星期五</li> | |||
<li>星期六</li> | |||
<li>星期日</li> | |||
</ul> | |||
<div id="printshow" style="display:none;"> | |||
<div class="perSemester"></div> | |||
<ul class="perWeek"> | |||
<li>节次/星期</li> | |||
<li>星期一</li> | |||
<li>星期二</li> | |||
<li>星期三</li> | |||
<li>星期四</li> | |||
<li>星期五</li> | |||
<li>星期六</li> | |||
<li>星期日</li> | |||
</ul> | |||
</div> | |||
<div id="exportshow" style="margin-bottom:10px;"> | |||
<div class="perSemester" style="border-bottom:0;"></div> | |||
<table border="1" style="width:100%;height:40px;border-bottom:hidden;border-collapse:collapse;border-color:#dfdfdf;"> | |||
<tr> | |||
<th style="width:12.5%;text-align:center;color: #333;font-weight: normal;">节次/星期</th> | |||
<th style="width:12.5%;text-align:center;color: #333;font-weight: normal;">星期一</th> | |||
<th style="width:12.5%;text-align:center;color: #333;font-weight: normal;">星期二</th> | |||
<th style="width:12.5%;text-align:center;color: #333;font-weight: normal;">星期三</th> | |||
<th style="width:12.5%;text-align:center;color: #333;font-weight: normal;">星期四</th> | |||
<th style="width:12.5%;text-align:center;color: #333;font-weight: normal;">星期五</th> | |||
<th style="width:12.5%;text-align:center;color: #333;font-weight: normal;">星期六</th> | |||
<th style="width:12.5%;text-align:center;color: #333;font-weight: normal;">星期日</th> | |||
</tr> | |||
</table> | |||
</div> | |||
<div class="perFestivalsBox"> | |||
<table cellspacing="0" border="0"></table> | |||
@*<table cellspacing="0" border="0" style="width:100%;" ></table>*@ | |||
<table cellspacing="0" border="1" style="width:100%;border-collapse:collapse;border-color:#dfdfdf;border:0;"></table> | |||
</div> | |||
</div> | |||
</div> | |||
@@ -172,3 +196,15 @@ | |||
@Html.AppendJsFile("/Areas/PersonnelManagement/Views/TimeTable/IndexInEducation.js") | |||
<script src="~/Content/js/FileSaver.js"></script> | |||
<script src="~/Content/js/jquery.wordexport.js"></script> | |||
<script> | |||
$('#wordExport').on('click', function () { | |||
$('#printshow').hide(); | |||
$('#exportshow').show(); | |||
$('#printFiled').wordExport('filename'); | |||
}) | |||
</script> | |||
@@ -17,7 +17,7 @@ var bootstrap = function ($, learun) { | |||
(function (arg) { | |||
var args = arg - 1; | |||
var datas = flogs(arg, weekLists, 'time'); | |||
html += ' <tr><td>' + arg + '节</td>'; | |||
html += ' <tr><td style="width:12.5%;text-align:center;" >' + arg + '节</td>'; | |||
if (datas) { | |||
var lists = datas.list; | |||
html += tdHandles(lists); | |||
@@ -57,7 +57,7 @@ var bootstrap = function ($, learun) { | |||
function tdHandle() { | |||
var html = ''; | |||
for (var j = 0; j < 7; j++) { | |||
html += '<td><div></div><div></div><div></div><div></div></td>'; | |||
html += '<td style="width:12.5%;text-align:center;" ><div></div><div></div><div></div><div></div></td>'; | |||
} | |||
return html; | |||
} | |||
@@ -70,7 +70,7 @@ var bootstrap = function ($, learun) { | |||
var args = arg - 1; | |||
var datas = flogs2(arg, lists, 'day'); | |||
if (datas.length > 0) { | |||
html += '<td class="active">'; | |||
html += '<td class="active" style="width:12.5%;text-align:center;" >'; | |||
$.each(datas, function (i, item) { | |||
if (i > 0) { | |||
html += '<hr>'; | |||
@@ -144,7 +144,7 @@ var bootstrap = function ($, learun) { | |||
selectfn: function (begin, end) { | |||
startTime = begin; | |||
endTime = end; | |||
page.search(); | |||
//page.search(); | |||
} | |||
}); | |||
//查询 | |||
@@ -199,6 +199,8 @@ var bootstrap = function ($, learun) { | |||
//打印课程表 | |||
$('#perBtn').on('click', | |||
function () { | |||
$('#printshow').show(); | |||
$('#exportshow').hide(); | |||
AddPrintContent(); | |||
}); | |||
var LODOP, P_ID = "", TaskID1, TaskID2, t, waiting = false, c = 0, loop = 0; //声明为全局变量 | |||
@@ -0,0 +1,172 @@ | |||
/* | |||
* FileSaver.js | |||
* A saveAs() FileSaver implementation. | |||
* | |||
* By Eli Grey, http://eligrey.com | |||
* | |||
* License : https://github.com/eligrey/FileSaver.js/blob/master/LICENSE.md (MIT) | |||
* source : http://purl.eligrey.com/github/FileSaver.js | |||
*/ | |||
// The one and only way of getting global scope in all environments | |||
// https://stackoverflow.com/q/3277182/1008999 | |||
var _global = typeof window === 'object' && window.window === window | |||
? window : typeof self === 'object' && self.self === self | |||
? self : typeof global === 'object' && global.global === global | |||
? global | |||
: this | |||
function bom (blob, opts) { | |||
if (typeof opts === 'undefined') opts = { autoBom: false } | |||
else if (typeof opts !== 'object') { | |||
console.warn('Deprecated: Expected third argument to be a object') | |||
opts = { autoBom: !opts } | |||
} | |||
// prepend BOM for UTF-8 XML and text/* types (including HTML) | |||
// note: your browser will automatically convert UTF-16 U+FEFF to EF BB BF | |||
if (opts.autoBom && /^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(blob.type)) { | |||
return new Blob([String.fromCharCode(0xFEFF), blob], { type: blob.type }) | |||
} | |||
return blob | |||
} | |||
function download (url, name, opts) { | |||
var xhr = new XMLHttpRequest() | |||
xhr.open('GET', url) | |||
xhr.responseType = 'blob' | |||
xhr.onload = function () { | |||
saveAs(xhr.response, name, opts) | |||
} | |||
xhr.onerror = function () { | |||
console.error('could not download file') | |||
} | |||
xhr.send() | |||
} | |||
function corsEnabled (url) { | |||
var xhr = new XMLHttpRequest() | |||
// use sync to avoid popup blocker | |||
xhr.open('HEAD', url, false) | |||
try { | |||
xhr.send() | |||
} catch (e) {} | |||
return xhr.status >= 200 && xhr.status <= 299 | |||
} | |||
// `a.click()` doesn't work for all browsers (#465) | |||
function click (node) { | |||
try { | |||
node.dispatchEvent(new MouseEvent('click')) | |||
} catch (e) { | |||
var evt = document.createEvent('MouseEvents') | |||
evt.initMouseEvent('click', true, true, window, 0, 0, 0, 80, | |||
20, false, false, false, false, 0, null) | |||
node.dispatchEvent(evt) | |||
} | |||
} | |||
// Detect WebView inside a native macOS app by ruling out all browsers | |||
// We just need to check for 'Safari' because all other browsers (besides Firefox) include that too | |||
// https://www.whatismybrowser.com/guides/the-latest-user-agent/macos | |||
var isMacOSWebView = _global.navigator && /Macintosh/.test(navigator.userAgent) && /AppleWebKit/.test(navigator.userAgent) && !/Safari/.test(navigator.userAgent) | |||
var saveAs = _global.saveAs || ( | |||
// probably in some web worker | |||
(typeof window !== 'object' || window !== _global) | |||
? function saveAs () { /* noop */ } | |||
// Use download attribute first if possible (#193 Lumia mobile) unless this is a macOS WebView | |||
: ('download' in HTMLAnchorElement.prototype && !isMacOSWebView) | |||
? function saveAs (blob, name, opts) { | |||
var URL = _global.URL || _global.webkitURL | |||
// Namespace is used to prevent conflict w/ Chrome Poper Blocker extension (Issue #561) | |||
var a = document.createElementNS('http://www.w3.org/1999/xhtml', 'a') | |||
name = name || blob.name || 'download' | |||
a.download = name | |||
a.rel = 'noopener' // tabnabbing | |||
// TODO: detect chrome extensions & packaged apps | |||
// a.target = '_blank' | |||
if (typeof blob === 'string') { | |||
// Support regular links | |||
a.href = blob | |||
if (a.origin !== location.origin) { | |||
corsEnabled(a.href) | |||
? download(blob, name, opts) | |||
: click(a, a.target = '_blank') | |||
} else { | |||
click(a) | |||
} | |||
} else { | |||
// Support blobs | |||
a.href = URL.createObjectURL(blob) | |||
setTimeout(function () { URL.revokeObjectURL(a.href) }, 4E4) // 40s | |||
setTimeout(function () { click(a) }, 0) | |||
} | |||
} | |||
// Use msSaveOrOpenBlob as a second approach | |||
: 'msSaveOrOpenBlob' in navigator | |||
? function saveAs (blob, name, opts) { | |||
name = name || blob.name || 'download' | |||
if (typeof blob === 'string') { | |||
if (corsEnabled(blob)) { | |||
download(blob, name, opts) | |||
} else { | |||
var a = document.createElement('a') | |||
a.href = blob | |||
a.target = '_blank' | |||
setTimeout(function () { click(a) }) | |||
} | |||
} else { | |||
navigator.msSaveOrOpenBlob(bom(blob, opts), name) | |||
} | |||
} | |||
// Fallback to using FileReader and a popup | |||
: function saveAs (blob, name, opts, popup) { | |||
// Open a popup immediately do go around popup blocker | |||
// Mostly only available on user interaction and the fileReader is async so... | |||
popup = popup || open('', '_blank') | |||
if (popup) { | |||
popup.document.title = | |||
popup.document.body.innerText = 'downloading...' | |||
} | |||
if (typeof blob === 'string') return download(blob, name, opts) | |||
var force = blob.type === 'application/octet-stream' | |||
var isSafari = /constructor/i.test(_global.HTMLElement) || _global.safari | |||
var isChromeIOS = /CriOS\/[\d]+/.test(navigator.userAgent) | |||
if ((isChromeIOS || (force && isSafari) || isMacOSWebView) && typeof FileReader !== 'undefined') { | |||
// Safari doesn't allow downloading of blob URLs | |||
var reader = new FileReader() | |||
reader.onloadend = function () { | |||
var url = reader.result | |||
url = isChromeIOS ? url : url.replace(/^data:[^;]*;/, 'data:attachment/file;') | |||
if (popup) popup.location.href = url | |||
else location = url | |||
popup = null // reverse-tabnabbing #460 | |||
} | |||
reader.readAsDataURL(blob) | |||
} else { | |||
var URL = _global.URL || _global.webkitURL | |||
var url = URL.createObjectURL(blob) | |||
if (popup) popup.location = url | |||
else location.href = url | |||
popup = null // reverse-tabnabbing #460 | |||
setTimeout(function () { URL.revokeObjectURL(url) }, 4E4) // 40s | |||
} | |||
} | |||
) | |||
_global.saveAs = saveAs.saveAs = saveAs | |||
if (typeof module !== 'undefined') { | |||
module.exports = saveAs; | |||
} |
@@ -0,0 +1,84 @@ | |||
if (typeof jQuery !== "undefined" && typeof saveAs !== "undefined") { | |||
(function($) { | |||
$.fn.wordExport = function(fileName) { | |||
fileName = typeof fileName !== 'undefined' ? fileName : "jQuery-Word-Export"; | |||
var static = { | |||
mhtml: { | |||
top: "Mime-Version: 1.0\nContent-Base: " + location.href + "\nContent-Type: Multipart/related; boundary=\"NEXT.ITEM-BOUNDARY\";type=\"text/html\"\n\n--NEXT.ITEM-BOUNDARY\nContent-Type: text/html; charset=\"utf-8\"\nContent-Location: " + location.href + "\n\n<!DOCTYPE html>\n<html>\n_html_</html>", | |||
head: "<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\n<style>\n_styles_\n</style>\n</head>\n", | |||
body: "<body>_body_</body>" | |||
} | |||
}; | |||
var options = { | |||
maxWidth: 624 | |||
}; | |||
// Clone selected element before manipulating it | |||
var markup = $(this).clone(); | |||
// Remove hidden elements from the output | |||
markup.each(function() { | |||
var self = $(this); | |||
if (self.is(':hidden')) | |||
self.remove(); | |||
}); | |||
// Embed all images using Data URLs | |||
var images = Array(); | |||
var img = markup.find('img'); | |||
for (var i = 0; i < img.length; i++) { | |||
// Calculate dimensions of output image | |||
var w = Math.min(img[i].width, options.maxWidth); | |||
var h = img[i].height * (w / img[i].width); | |||
// Create canvas for converting image to data URL | |||
var canvas = document.createElement("CANVAS"); | |||
canvas.width = w; | |||
canvas.height = h; | |||
// Draw image to canvas | |||
var context = canvas.getContext('2d'); | |||
context.drawImage(img[i], 0, 0, w, h); | |||
// Get data URL encoding of image | |||
var uri = canvas.toDataURL("image/png"); | |||
$(img[i]).attr("src", img[i].src); | |||
img[i].width = w; | |||
img[i].height = h; | |||
// Save encoded image to array | |||
images[i] = { | |||
type: uri.substring(uri.indexOf(":") + 1, uri.indexOf(";")), | |||
encoding: uri.substring(uri.indexOf(";") + 1, uri.indexOf(",")), | |||
location: $(img[i]).attr("src"), | |||
data: uri.substring(uri.indexOf(",") + 1) | |||
}; | |||
} | |||
// Prepare bottom of mhtml file with image data | |||
var mhtmlBottom = "\n"; | |||
for (var i = 0; i < images.length; i++) { | |||
mhtmlBottom += "--NEXT.ITEM-BOUNDARY\n"; | |||
mhtmlBottom += "Content-Location: " + images[i].location + "\n"; | |||
mhtmlBottom += "Content-Type: " + images[i].type + "\n"; | |||
mhtmlBottom += "Content-Transfer-Encoding: " + images[i].encoding + "\n\n"; | |||
mhtmlBottom += images[i].data + "\n\n"; | |||
} | |||
mhtmlBottom += "--NEXT.ITEM-BOUNDARY--"; | |||
//TODO: load css from included stylesheet | |||
var styles = ""; | |||
// Aggregate parts of the file together | |||
var fileContent = static.mhtml.top.replace("_html_", static.mhtml.head.replace("_styles_", styles) + static.mhtml.body.replace("_body_", markup.html())) + mhtmlBottom; | |||
// Create a Blob with the file contents | |||
var blob = new Blob([fileContent], { | |||
type: "application/msword;charset=utf-8" | |||
}); | |||
saveAs(blob, fileName + ".doc"); | |||
}; | |||
})(jQuery); | |||
} else { | |||
if (typeof jQuery === "undefined") { | |||
console.error("jQuery Word Export: missing dependency (jQuery)"); | |||
} | |||
if (typeof saveAs === "undefined") { | |||
console.error("jQuery Word Export: missing dependency (FileSaver.js)"); | |||
} | |||
} |