Files
FM-OHS/main.js
2025-07-19 16:01:14 +08:00

132 lines
5.4 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

// ==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("点击按钮后会统计加班时间");
})();