Rev 33997 | Blame | Compare with Previous | Last modification | View Log | RSS feed
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css"integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous"><link rel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-daterangepicker/3.1.0/daterangepicker.min.css"/><style>table th {text-align: center;}#rbm-arr-table td, #rbm-arr-table th {padding: 0.35rem;font-size: 18px;}.text-bold {font-weight: bold !important;}.text-bold span {font-weight: bold;}.rb-name {font-size: 16px;font-weight: bold;}#rbm-arr-table td {text-align: center;background-size: 100% 100%;background-repeat: no-repeat;color: #000; /* Ensure text remains visible */font-weight: 400;}</style><section class="wrapper"><div class="row"><div class="col-lg-12"><table id="rbm-arr-table" class="table table-border table-condensed table-bordered" style="width:100%"><tr><th>RBM</th><th>Total (ACH/TGT)</th><th>%</th><th>HID (ACH/TGT)</th><th>%</th><th>FAST (ACH/TGT)</th><th>%</th><th>RUN (ACH/TGT)</th><th>%</th><th>SLOW (ACH/TGT)</th><th>%</th><th>Other (ACH/TGT)</th><th>%</th></tr>#foreach($target in $rbmTargetAndAchievementsModels)<tr><td>$target.getRbmName()- $target.getWarehouseName()</td><td><span class="achieved-cell">$target.getTotalAchievemnt()</span> / <spanclass="target-cell">$target.getTotalTarget()</span></td><td class="total-percent"></td><td><span class="achieved-cell">$target.getAchievedHid()</span> / <spanclass="target-cell">$target.getHidTarget()</span></td><td class="hid-percent"></td><td><span class="achieved-cell">$target.getAchievedFastMoving()</span> / <spanclass="target-cell">$target.getFastMovingTarget()</span></td><td class="fast-percent"></td><td><span class="achieved-cell">$target.getAchievedRunning()</span> / <spanclass="target-cell">$target.getRunningTarget()</span></td><td class="run-percent"></td><td><span class="achieved-cell">$target.getAchievedSlowMoving()</span> / <spanclass="target-cell">$target.getSlowMovingTarget()</span></td><td class="slow-percent"></td><td><span class="achieved-cell">$target.getAchievedOtherMoving()</span> / <spanclass="target-cell">$target.getOtherMovingTarget()</span></td><td class="other-percent"></td></tr>#end<!-- Add a row for totals --><tr><td><strong>Total</strong></td><td class="text-bold"><span class="achieved-cell">$totalAchieved </span> / <spanclass="target-cell">$totalTarget</span></td><td class="total-percent text-bold"></td><td class="text-bold"><span class="achieved-cell">$totalAchievedHid</span> / <spanclass="target-cell">$totalTargetHid</span></td><td class="hid-percent text-bold"></td><td class="text-bold"><span class="achieved-cell">$totalAchievedFast</span> / <spanclass="target-cell">$totalTargetFast</span></td><td class="fast-percent text-bold"></td><td class="text-bold"><span class="achieved-cell">$totalAchievedRunning</span> / <spanclass="target-cell">$totalTargetRunning</span></td><td class="run-percent text-bold"></td><td class="text-bold"><span class="achieved-cell">$totalAchievedSlow</span> / <spanclass="target-cell">$totalTargetSlow</span></td><td class="slow-percent text-bold"></td><td class="text-bold"><span class="achieved-cell">$totalAchievedOther</span> / <spanclass="target-cell">$totalTargetOther</span></td><td class="other-percent text-bold"></td></tr></table></div></div></section><script>function formatValueInLakh(value) {return (value / 100000).toFixed(1) + 'L';}function formatTargets() {const rows = document.querySelectorAll('#rbm-arr-table tbody tr');let totalAchieved = 0, totalTarget = 0;let totalAchievedHid = 0, totalTargetHid = 0;let totalAchievedFast = 0, totalTargetFast = 0;let totalAchievedRunning = 0, totalTargetRunning = 0;let totalAchievedSlow = 0, totalTargetSlow = 0;let totalAchievedOther = 0, totalTargetOther = 0;rows.forEach(row => {const cells = row.querySelectorAll('td');cells.forEach((cell, index) => {const achievedSpan = cell.querySelector('.achieved-cell');const targetSpan = cell.querySelector('.target-cell');if (achievedSpan && targetSpan) {const achievedValue = parseFloat(achievedSpan.textContent.replace(/[^\d.-]/g, ''));const targetValue = parseFloat(targetSpan.textContent.replace(/[^\d.-]/g, ''));// Add to totalsif (index === 1) {totalAchieved += achievedValue || 0;totalTarget += targetValue || 0;} else if (index === 3) {totalAchievedHid += achievedValue || 0;totalTargetHid += targetValue || 0;} else if (index === 5) {totalAchievedFast += achievedValue || 0;totalTargetFast += targetValue || 0;} else if (index === 7) {totalAchievedRunning += achievedValue || 0;totalTargetRunning += targetValue || 0;} else if (index === 9) {totalAchievedSlow += achievedValue || 0;totalTargetSlow += targetValue || 0;} else if (index === 11) {totalAchievedOther += achievedValue || 0;totalTargetOther += targetValue || 0;}// Format values in lakhif (!isNaN(achievedValue)) achievedSpan.textContent = formatValueInLakh(achievedValue);if (!isNaN(targetValue)) targetSpan.textContent = formatValueInLakh(targetValue);const percentCell = cell.nextElementSibling;if (percentCell && targetValue > 0) {const percentage = ((achievedValue / targetValue) * 100).toFixed(1);percentCell.textContent = percentage + '%';// Determine background color based on percentagelet color;if (percentage <= 1) {percentCell.style.color = `red`}if (percentage <= 40) {color = '#F56983FF'; // Orange for <= 40%} else if (percentage > 40 && percentage <= 75) {color = '#f2c947e8'; // Yellow for 41% - 75%} else {color = '#82ef8299'; // Green for > 75%}// Apply gradient background with the colorpercentCell.style.background = `linear-gradient(to right, ${color} ${percentage}%, transparent ${percentage}%)`;} else if (percentCell) {percentCell.textContent = "-";percentCell.style.background = 'none';}}});});}function groupRowsByRbm() {const rows = document.querySelectorAll('#rbm-arr-table tbody tr');let currentRbm = null;let rbmGroup = [];rows.forEach((row, index) => {const rbmCell = row.cells[0];if (!rbmCell) return;const rbmName = rbmCell.textContent.split('-')[0].trim(); // Extract RBM nameif (rbmName !== currentRbm) {// Apply border to the previous groupif (rbmGroup.length > 0) {applyBorderToGroup(rbmGroup);}// Reset for new RBMcurrentRbm = rbmName;rbmGroup = [];}// Add the row to the current grouprbmGroup.push(row);// Apply border to the last groupif (index === rows.length - 1 && rbmGroup.length > 0) {applyBorderToGroup(rbmGroup);}});}function applyBorderToGroup(group) {if (group.length === 0) return;// Add border styles to the first and last rows in the group//group[0].style.borderTop = '2px solid #000'; // Black border for startgroup[group.length - 1].style.borderBottom = '2px solid #000'; // Black border for end}window.onload = function () {formatTargets(); // Format targets firstgroupRowsByRbm(); // Group rows by RBM};</script>