Subversion Repositories SmartDukaan

Rev

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> / <span
                                class="target-cell">$target.getTotalTarget()</span></td>
                        <td class="total-percent"></td>
                        <td><span class="achieved-cell">$target.getAchievedHid()</span> / <span
                                class="target-cell">$target.getHidTarget()</span></td>
                        <td class="hid-percent"></td>

                        <td><span class="achieved-cell">$target.getAchievedFastMoving()</span> / <span
                                class="target-cell">$target.getFastMovingTarget()</span></td>
                        <td class="fast-percent"></td>

                        <td><span class="achieved-cell">$target.getAchievedRunning()</span> / <span
                                class="target-cell">$target.getRunningTarget()</span></td>
                        <td class="run-percent"></td>

                        <td><span class="achieved-cell">$target.getAchievedSlowMoving()</span> / <span
                                class="target-cell">$target.getSlowMovingTarget()</span></td>
                        <td class="slow-percent"></td>

                        <td><span class="achieved-cell">$target.getAchievedOtherMoving()</span> / <span
                                class="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> / <span
                            class="target-cell">$totalTarget</span></td>
                    <td class="total-percent text-bold"></td>

                    <td class="text-bold"><span class="achieved-cell">$totalAchievedHid</span> / <span
                            class="target-cell">$totalTargetHid</span></td>
                    <td class="hid-percent text-bold"></td>

                    <td class="text-bold"><span class="achieved-cell">$totalAchievedFast</span> / <span
                            class="target-cell">$totalTargetFast</span></td>
                    <td class="fast-percent text-bold"></td>

                    <td class="text-bold"><span class="achieved-cell">$totalAchievedRunning</span> / <span
                            class="target-cell">$totalTargetRunning</span></td>
                    <td class="run-percent text-bold"></td>

                    <td class="text-bold"><span class="achieved-cell">$totalAchievedSlow</span> / <span
                            class="target-cell">$totalTargetSlow</span></td>
                    <td class="slow-percent text-bold"></td>

                    <td class="text-bold"><span class="achieved-cell">$totalAchievedOther</span> / <span
                            class="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 totals
                    if (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 lakh
                    if (!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 percentage
                        let 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 color
                        percentCell.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 name

            if (rbmName !== currentRbm) {
                // Apply border to the previous group
                if (rbmGroup.length > 0) {
                    applyBorderToGroup(rbmGroup);
                }

                // Reset for new RBM
                currentRbm = rbmName;
                rbmGroup = [];
            }

            // Add the row to the current group
            rbmGroup.push(row);

            // Apply border to the last group
            if (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 start
        group[group.length - 1].style.borderBottom = '2px solid #000'; // Black border for end
    }

    window.onload = function () {
        formatTargets(); // Format targets first
        groupRowsByRbm(); // Group rows by RBM
    };


</script>