Explorar el Código

全院课程表导出为word

新疆体育高职分支
libo hace 1 año
padre
commit
308ace406f
Se han modificado 4 ficheros con 341 adiciones y 47 borrados
  1. +79
    -43
      Learun.Framework.Ultimate V7/Learun.Application.Web/Areas/PersonnelManagement/Views/TimeTable/IndexInEducation.cshtml
  2. +6
    -4
      Learun.Framework.Ultimate V7/Learun.Application.Web/Areas/PersonnelManagement/Views/TimeTable/IndexInEducation.js
  3. +172
    -0
      Learun.Framework.Ultimate V7/Learun.Application.Web/Content/js/FileSaver.js
  4. +84
    -0
      Learun.Framework.Ultimate V7/Learun.Application.Web/Content/js/jquery.wordexport.js

+ 79
- 43
Learun.Framework.Ultimate V7/Learun.Application.Web/Areas/PersonnelManagement/Views/TimeTable/IndexInEducation.cshtml Ver fichero

@@ -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>



+ 6
- 4
Learun.Framework.Ultimate V7/Learun.Application.Web/Areas/PersonnelManagement/Views/TimeTable/IndexInEducation.js Ver fichero

@@ -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; //声明为全局变量


+ 172
- 0
Learun.Framework.Ultimate V7/Learun.Application.Web/Content/js/FileSaver.js Ver fichero

@@ -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;
}

+ 84
- 0
Learun.Framework.Ultimate V7/Learun.Application.Web/Content/js/jquery.wordexport.js Ver fichero

@@ -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)");
}
}

Cargando…
Cancelar
Guardar