132 lines
5.4 KiB
JavaScript
132 lines
5.4 KiB
JavaScript
// ==UserScript==
|
||
// @name 复旦微加班时间统计
|
||
// @namespace http://start.fengbohan.com/
|
||
// @version 2025-07-19
|
||
// @description 统计加班总时间, 修复了周末加班时间统计的BUG
|
||
// @author bhfeng
|
||
// @match http://192.168.36.67:7888/shr/dynamic.do?uipk=com.kingdee.eas.hr.ats.app.WorkCalendarItem*
|
||
// @icon 
|
||
// @grant none
|
||
// ==/UserScript==
|
||
|
||
(function() {
|
||
'use strict';
|
||
function calculateTimeDifference(timeString, weekday) {
|
||
// 判断字符串是否为 "--"
|
||
if (timeString === '--') {
|
||
return 0;
|
||
}
|
||
|
||
// 按逗号分割字符串
|
||
const times = timeString.split(',');
|
||
|
||
// 解析时间并转换为毫秒
|
||
const parsedTimes = times.map(timeStr => {
|
||
const [hours, minutes, seconds] = timeStr.trim().split(':').map(Number);
|
||
return isNaN(hours) || isNaN(minutes) || isNaN(seconds) ? null : (hours * 3600 + minutes * 60 + seconds) * 1000;
|
||
});
|
||
|
||
// 过滤掉无效的时间
|
||
const validTimes = parsedTimes.filter(time => time !== null);
|
||
|
||
if (validTimes.length === 0) {
|
||
return 'No valid times provided';
|
||
}
|
||
|
||
// 计算最大值和最小值
|
||
const maxTime = Math.max(...validTimes);
|
||
const minTime = Math.min(...validTimes);
|
||
|
||
// 下午5点20分(17:20:00)的时间戳
|
||
const fiveTwentyPM = (17 * 3600 + 20 * 60) * 1000;
|
||
let timeDifferenceInHours;
|
||
|
||
if (weekday === "周六" || weekday == "周日") {
|
||
// 计算时间差(以小时为单位)
|
||
timeDifferenceInHours = (maxTime - minTime) / (1000 * 60 * 60);
|
||
} else {
|
||
// 计算时间差(以小时为单位)
|
||
if (maxTime >= fiveTwentyPM) {
|
||
timeDifferenceInHours = (maxTime - fiveTwentyPM) / (1000 * 60 * 60);
|
||
} else {
|
||
//timeDifferenceInHours = (fiveTwentyPM - maxTime) / (1000 * 60 * 60);
|
||
timeDifferenceInHours = 0;
|
||
}
|
||
}
|
||
|
||
return timeDifferenceInHours;
|
||
}
|
||
|
||
function sumOfSecondColumn(tableId) {
|
||
// 获取表格元素
|
||
var table = document.getElementById(tableId);
|
||
|
||
// 初始化总和
|
||
var totalSum = 0;
|
||
|
||
// 获取所有的行
|
||
var rows = table.getElementsByTagName('tr');
|
||
|
||
// 遍历每行
|
||
for (var i = 1; i < rows.length; i++) { // 从1开始跳过表头
|
||
var cells = rows[i].getElementsByTagName('td');
|
||
if (cells.length > 1) { // 确保该行至少有两列
|
||
var cellValue = cells[3].textContent;
|
||
var weekday = cells[2].textContent;
|
||
var difference = calculateTimeDifference(cellValue, weekday);
|
||
console.log(`第${i}行:${difference} 小时`);
|
||
totalSum += difference;
|
||
|
||
// 创建新的单元格
|
||
var newCell2 = cells[4];
|
||
newCell2.style="width:110px;";
|
||
newCell2.textContent = `${difference.toFixed(2)}H`;
|
||
rows[i].appendChild(newCell2);
|
||
}
|
||
}
|
||
|
||
return totalSum;
|
||
}
|
||
|
||
// 创建一个新的按钮元素
|
||
var button = document.createElement('button');
|
||
button.style.width = "90px"; //按钮宽度
|
||
button.style.height = "60px"; //按钮高度
|
||
button.style.align = "center"; //文本居中
|
||
button.style.color = "#e5e5e5"; //按钮文字颜色
|
||
button.style.background = "#b46300"; //按钮底色
|
||
button.style.borderRadius = "4px"; //按钮四个角弧度
|
||
|
||
|
||
// 设置按钮的文字
|
||
button.textContent = '点击我';
|
||
|
||
// 添加点击事件监听器
|
||
button.addEventListener('click', function() {
|
||
var message = sumOfSecondColumn('grid').toFixed(2);
|
||
|
||
// 使用 alert() 函数弹出提示框
|
||
alert(`你加班了${message}小时,幸苦了!`);
|
||
|
||
var table = document.querySelector("#gview_grid > div.ui-state-default.ui-jqgrid-hdiv > div > table > thead > tr")
|
||
var rows = table.getElementsByTagName('th');
|
||
|
||
// 添加表头
|
||
var newCell = rows[4]
|
||
newCell.textContent = '加班时间';
|
||
table.appendChild(newCell);
|
||
});
|
||
|
||
// 获取要将按钮添加到其中的容器
|
||
var container = document.getElementById('seclevelmenu'); // 假设页面上有id为'container'的元素
|
||
|
||
// 如果没有找到容器,则添加到body元素
|
||
if (!container) {
|
||
container = document.body;
|
||
}
|
||
|
||
// 将按钮添加到容器中
|
||
container.appendChild(button);
|
||
console.log("复旦微加班时间统计脚本已加载");
|
||
console.log("点击按钮后会统计加班时间");
|
||
})(); |