Standardize ASP filenames: remove underscores

Renamed 45 ASP files to follow lowercase concatenated naming convention:
- Direct handlers: save_machine_direct.asp -> savemachinedirect.asp
- USB files: checkin_usb.asp -> checkinusb.asp
- API files: api_usb.asp -> apiusb.asp
- Map files: network_map.asp -> networkmap.asp
- Printer files: printer_lookup.asp -> printerlookup.asp

Also:
- Updated 84+ internal references across all ASP and JS files
- Deleted 6 test/duplicate files (editmacine.asp, test_*.asp)
- Updated production migration guide with filename changes
- Added rename scripts for Linux (bash) and Windows (PowerShell)
This commit is contained in:
cproudlock
2025-12-10 20:40:05 -05:00
parent 6162db9fcf
commit 249bfbba8c
88 changed files with 683 additions and 595 deletions

399
printerinstallermap.asp Normal file
View File

@@ -0,0 +1,399 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!--#include file="./includes/header.asp"-->
<!--#include file="./includes/sql.asp"-->
<link rel="stylesheet" href="./leaflet/leaflet.css">
<script src="./leaflet/leaflet.js"></script>
</head>
<%
theme = Request.Cookies("theme")
IF theme = "" THEN
theme="bg-theme1"
END IF
%>
<body class="bg-theme <%Response.Write(theme)%>">
<!-- start loader -->
<div id="pageloader-overlay" class="visible incoming"><div class="loader-wrapper-outer"><div class="loader-wrapper-inner" ><div class="loader"></div></div></div></div>
<!-- end loader -->
<!-- Start wrapper-->
<div id="wrapper">
<!--#include file="./includes/leftsidebar.asp"-->
<!--Start topbar header-->
<!--#include file="./includes/topbarheader.asp"-->
<!--End topbar header-->
<div class="clearfix"></div>
<div class="content-wrapper">
<div class="row">
<div class="col-lg-8 col-xl-9">
<div class="card">
<div class="card-body" style="padding:0;">
<div style="padding:15px; border-bottom:1px solid #444;">
<h5 class="card-title" style="margin:0;">
<i class='zmdi zmdi-map'></i>&nbsp;&nbsp;Printer Installation Map
<span style="float:right; font-size:14px; font-weight:normal;">
<span id="selectedCount" style="color:#4fc3f7;">0</span> printer(s) selected
</span>
</h5>
</div>
<div id="map"></div>
</div>
</div>
</div>
<div class="col-lg-4 col-xl-3">
<div class="card">
<div class="card-header" style="background: linear-gradient(45deg, #667eea, #764ba2); color: white;">
<i class="zmdi zmdi-download"></i> Printer Installer
</div>
<div class="card-body">
<p style="font-size:13px; color:#aaa; margin-bottom:15px;">
Click printers on the map to select them. Selected printers will turn green.
</p>
<div id="selectedPrinters" style="margin-bottom:20px; max-height:300px; overflow-y:auto;">
<div style="color:#888; font-size:12px; text-align:center; padding:20px;">
No printers selected yet
</div>
</div>
<button id="installBtn" class="btn btn-primary btn-block" style="display:none;" onclick="downloadInstaller()">
<i class="zmdi zmdi-download"></i> Download Installer
</button>
<button class="btn btn-outline-secondary btn-block btn-sm" onclick="clearSelection()">
<i class="zmdi zmdi-close"></i> Clear Selection
</button>
<div style="margin-top:20px; padding:15px; background:#2a2a2a; border-radius:4px; font-size:12px;">
<strong style="color:#4fc3f7;">Legend:</strong>
<div style="margin-top:8px;">
<span style="display:inline-block; width:10px; height:10px; background:#888; border-radius:50%; margin-right:8px;"></span> Not Selected<br>
<span style="display:inline-block; width:10px; height:10px; background:#4caf50; border-radius:50%; margin-right:8px; margin-top:5px;"></span> Selected
</div>
</div>
</div>
</div>
</div>
</div><!--End Row-->
</div><!--End content-wrapper-->
<!--Start Back To Top Button-->
<a href="javaScript:void();" class="back-to-top"><i class="fa fa-angle-double-up"></i> </a>
<!--End Back To Top Button-->
<!--Start footer-->
<footer class="footer">
</div>
</footer>
<!--End footer-->
</div><!--End wrapper-->
<!-- Bootstrap core JavaScript-->
<script src="assets/js/jquery.min.js"></script>
<script src="assets/js/popper.min.js"></script>
<script src="assets/js/bootstrap.min.js"></script>
<script src="assets/plugins/simplebar/js/simplebar.js"></script>
<script src="assets/js/sidebar-menu.js"></script>
<script src="assets/js/app-script.js"></script>
<style>
#map {
width: 100%;
height: calc(100vh - 250px);
min-height: 600px;
background-color: #1a1a1a;
}
.leaflet-control-zoom a {
background-color: #2a2a2a !important;
color: #fff !important;
border-color: #444 !important;
}
.leaflet-control-zoom a:hover {
background-color: #3a3a3a !important;
}
.leaflet-bar {
border: 1px solid #444 !important;
}
.leaflet-popup-content-wrapper {
background: transparent !important;
color: #fff !important;
box-shadow: 0 3px 14px rgba(0,0,0,0.6) !important;
border-radius: 4px !important;
padding: 0 !important;
}
.leaflet-popup-content {
margin: 0 !important;
}
.leaflet-popup-tip-container {
display: none !important;
}
.leaflet-popup-close-button {
color: #fff !important;
font-size: 24px !important;
padding: 4px 8px 0 0 !important;
}
.leaflet-control-attribution {
display: none !important;
}
.selected-printer-item {
padding: 8px;
margin-bottom: 8px;
background: #2a2a2a;
border-left: 3px solid #4caf50;
border-radius: 3px;
font-size: 12px;
color: #fff;
}
.selected-printer-item .remove-btn {
float: right;
color: #f44336;
cursor: pointer;
font-size: 14px;
}
</style>
<script>
// Get current theme
var bodyClass = document.body.className;
var themeMatch = bodyClass.match(/bg-theme(\d+)/);
var theme = themeMatch ? 'bg-theme' + themeMatch[1] : 'bg-theme1';
var themeConfig = {
'bg-theme1': { bg: '#2a2a2a', filter: 'brightness(0.7) contrast(1.1)', gradient: 'linear-gradient(45deg, #3a3a3a, #4a4a4a)' },
'bg-theme7': { bg: '#0c675e', filter: 'brightness(0.8) contrast(1.1) hue-rotate(-10deg)', gradient: 'linear-gradient(45deg, #0c675e, #069e90)' },
'bg-theme11': { bg: '#1565C0', filter: 'brightness(0.85) contrast(1.05) hue-rotate(-5deg)', gradient: 'linear-gradient(45deg, #1565C0, #1E88E5)' }
};
var config = themeConfig[theme] || { bg: '#1a1a1a', filter: 'brightness(0.7) contrast(1.1)', gradient: 'linear-gradient(45deg, #667eea, #764ba2)' };
document.getElementById('map').style.backgroundColor = config.bg;
var map = L.map('map', {
crs: L.CRS.Simple,
minZoom: -3
});
var bounds = [[0,0], [2550,3300]];
var lightThemes = ['bg-theme11', 'bg-theme13'];
var mapImage = lightThemes.includes(theme) ? './images/sitemap2025-light.png' : './images/sitemap2025-dark.png';
var image = L.imageOverlay(mapImage, bounds);
image.on('load', function() {
var imgElement = this.getElement();
if (imgElement) {
imgElement.style.filter = config.filter;
}
});
image.addTo(map);
var center = [1275, 1650];
map.setView(center, -2.3);
// Store printer data and markers
var printerData = {};
var selectedPrinters = {};
<%
strSQL = "SELECT printers.mapleft, printers.maptop, machines.machinenumber, printers.printerid, " &_
"printers.printercsfname, printers.printerwindowsname, models.modelnumber, models.image, " &_
"printers.ipaddress, printers.fqdn, machines.alias, vendors.vendor " &_
"FROM machines, printers, models, vendors WHERE " &_
"printers.modelid = models.modelnumberid AND " &_
"models.vendorid = vendors.vendorid AND " &_
"printers.machineid != 1 AND " &_
"printers.machineid = machines.machineid AND " &_
"printers.isactive = 1 AND " &_
"printers.mapleft IS NOT NULL AND " &_
"printers.maptop IS NOT NULL AND " &_
"(vendors.vendor = 'HP' OR vendors.vendor = 'Xerox' OR vendors.vendor = 'HID')"
set rs = objconn.Execute(strSQL)
while not rs.eof
mapleft = rs("mapleft")
maptop = rs("maptop")
maptop = 2550-maptop
printerid = rs("printerid")
printercsfname = rs("printercsfname")
modelnumber = rs("modelnumber")
image = rs("image")
ipaddress = rs("ipaddress")
fqdn = rs("fqdn")
vendor = rs("vendor")
' Get machine name
if NOT IsNull(rs("alias")) AND rs("alias") <> "" THEN
machineName = rs("alias")
else
machineName = rs("machinenumber")
end if
location = machineName
if image = "" THEN
image = "Versalink-C7125.png"
end if
' Use standardized name from database (no need to generate - names are now standardized)
printerwindowsname = rs("printerwindowsname") & ""
%>
(function() {
var printerId = '<%Response.Write(printerid)%>';
var printerName = '<%Response.Write(printerwindowsname)%>';
var csfName = '<%Response.Write(printercsfname)%>';
var location = '<%Response.Write(location)%>';
printerData[printerId] = {
name: printerName,
csf: csfName,
location: location,
model: '<%Response.Write(modelnumber)%>',
ip: '<%Response.Write(ipaddress)%>',
fqdn: '<%Response.Write(fqdn)%>'
};
var normalIcon = L.icon({
iconUrl: './images/printers/<%Response.Write(image)%>',
iconSize: [60, 60],
iconAnchor: [30, 30],
popupAnchor: [0, -30],
className: 'printer-icon-normal'
});
var selectedIcon = L.icon({
iconUrl: './images/printers/<%Response.Write(image)%>',
iconSize: [70, 70],
iconAnchor: [35, 35],
popupAnchor: [0, -35],
className: 'printer-icon-selected'
});
var marker = L.marker([<%Response.Write(maptop)%>, <%Response.Write(mapleft)%>], {
title: printerName,
icon: normalIcon,
printerId: printerId
}).addTo(map);
printerData[printerId].marker = marker;
printerData[printerId].normalIcon = normalIcon;
printerData[printerId].selectedIcon = selectedIcon;
marker.on('click', function() {
togglePrinter(printerId);
});
marker.on('mouseover', function() {
this.openPopup();
});
marker.on('mouseout', function() {
this.closePopup();
});
var popupContent = '<div style="background:#1f1f1f; color:#fff; min-width:280px; border-radius:4px; overflow:hidden;">' +
'<div style="background:' + config.gradient + '; padding:10px 15px; border-bottom:1px solid #444;">' +
'<h6 style="margin:0; color:#fff; font-size:14px;"><%Response.Write(printerwindowsname)%></h6>' +
'</div>' +
'<div style="padding:10px 15px; font-size:12px;">' +
'<div style="margin:5px 0;"><strong style="color:#aaa;">CSF:</strong> <span style="color:#fff;"><%Response.Write(printercsfname)%></span></div>' +
'<div style="margin:5px 0;"><strong style="color:#aaa;">Location:</strong> <span style="color:#fff;"><%Response.Write(location)%></span></div>' +
'<div style="margin:5px 0;"><strong style="color:#aaa;">Model:</strong> <span style="color:#fff;"><%Response.Write(modelnumber)%></span></div>' +
'</div>' +
'</div>';
marker.bindPopup(popupContent);
})();
<%
rs.movenext
Wend
objConn.Close
%>
// Add CSS for selected markers
var style = document.createElement('style');
style.innerHTML = `
.printer-icon-selected {
filter: drop-shadow(0 0 10px #4caf50) brightness(1.3);
z-index: 1000 !important;
}
.printer-icon-normal {
filter: grayscale(50%) brightness(0.8);
}
`;
document.head.appendChild(style);
function togglePrinter(printerId) {
if (selectedPrinters[printerId]) {
// Deselect
delete selectedPrinters[printerId];
printerData[printerId].marker.setIcon(printerData[printerId].normalIcon);
} else {
// Select
selectedPrinters[printerId] = true;
printerData[printerId].marker.setIcon(printerData[printerId].selectedIcon);
}
updateSelectionUI();
}
function updateSelectionUI() {
var count = Object.keys(selectedPrinters).length;
document.getElementById('selectedCount').innerText = count;
var container = document.getElementById('selectedPrinters');
var installBtn = document.getElementById('installBtn');
if (count === 0) {
container.innerHTML = '<div style="color:#888; font-size:12px; text-align:center; padding:20px;">No printers selected yet</div>';
installBtn.style.display = 'none';
} else {
var html = '';
for (var printerId in selectedPrinters) {
var printer = printerData[printerId];
// Use CSF name if available, otherwise fall back to location
var displayName = (printer.csf && printer.csf !== '') ? printer.csf : printer.location;
html += '<div class="selected-printer-item">' +
'<span class="remove-btn" onclick="togglePrinter(\'' + printerId + '\')">×</span>' +
'<strong>' + displayName + '</strong><br>' +
'<span style="font-size:11px; color:#aaa;">' + printer.model + '</span>' +
'</div>';
}
container.innerHTML = html;
installBtn.style.display = 'block';
}
}
function clearSelection() {
for (var printerId in selectedPrinters) {
printerData[printerId].marker.setIcon(printerData[printerId].normalIcon);
}
selectedPrinters = {};
updateSelectionUI();
}
function downloadInstaller() {
var printerIds = [];
for (var printerId in selectedPrinters) {
printerIds.push(printerId);
}
if (printerIds.length === 0) {
alert('Please select at least one printer');
return;
}
// Pass printer IDs for reliable lookup (names are generated dynamically and may not match DB)
var printerParam = printerIds.join(',');
window.location.href = 'installprinter.asp?printerid=' + encodeURIComponent(printerParam);
}
</script>
</body>
</html>