Created
July 21, 2025 21:51
-
-
Save jeremiahfish/84c17b35ca2ed7640019b03c6e902c8d to your computer and use it in GitHub Desktop.
4-20ma Calc
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE html> | |
<html lang="en"> | |
<head> | |
<meta charset="UTF-8"> | |
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no, shrink-to-fit=no"> | |
<title>CTi 4-20mA Calculator</title> | |
<!-- PWA Meta Tags --> | |
<meta name="apple-mobile-web-app-capable" content="yes"> | |
<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent"> | |
<meta name="apple-mobile-web-app-title" content="4-20mA Calc"> | |
<meta name="theme-color" content="#facc15"> | |
<meta name="description" content="Professional 4-20mA loop calculator with gas sensor presets"> | |
<!-- Web App Manifest --> | |
<link rel="manifest" href="manifest.json"> | |
<link rel="apple-touch-icon" href=""> | |
<link rel="icon" href=""> | |
<style> | |
* { | |
margin: 0; | |
padding: 0; | |
box-sizing: border-box; | |
} | |
body { | |
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; | |
background: linear-gradient(135deg, #d1d5db 0%, #e5e7eb 50%, #d1d5db 100%); | |
min-height: 100vh; | |
padding: 24px; | |
touch-action: manipulation; | |
-webkit-touch-callout: none; | |
-webkit-user-select: none; | |
-khtml-user-select: none; | |
-moz-user-select: none; | |
-ms-user-select: none; | |
user-select: none; | |
/* Prevent zoom on iOS */ | |
-webkit-text-size-adjust: 100%; | |
-ms-text-size-adjust: 100%; | |
text-size-adjust: 100%; | |
zoom: 1; | |
} | |
@font-face { | |
font-family: 'Segment'; | |
src: url('seg.otf') format('opentype'); | |
} | |
.container { | |
max-width: 384px; | |
margin: 0 auto; | |
position: relative; | |
} | |
/* Preset Overlay */ | |
.preset-overlay { | |
position: fixed; | |
top: 0; | |
left: 0; | |
right: 0; | |
bottom: 0; | |
background: rgba(0, 0, 0, 0.5); | |
z-index: 50; | |
display: none; | |
align-items: center; | |
justify-content: center; | |
padding: 16px; | |
} | |
.preset-modal { | |
background: white; | |
border-radius: 8px; | |
box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25); | |
max-width: 384px; | |
width: 100%; | |
max-height: 80vh; | |
overflow: hidden; | |
} | |
.preset-header { | |
background: #facc15; | |
padding: 16px; | |
border-bottom: 1px solid #e5e7eb; | |
} | |
.preset-header h3 { | |
font-weight: bold; | |
color: black; | |
text-align: center; | |
} | |
.preset-list { | |
overflow-y: auto; | |
max-height: 60vh; | |
padding: 8px; | |
} | |
.preset-item { | |
text-align: left; | |
padding: 8px 12px; | |
border: none; | |
background: none; | |
width: 100%; | |
border-bottom: 1px solid #f3f4f6; | |
cursor: pointer; | |
transition: background-color 0.2s; | |
} | |
.preset-item:hover { | |
background: #f3f4f6; | |
} | |
.preset-row { | |
display: flex; | |
align-items: center; | |
gap: 12px; | |
} | |
.preset-sensor { | |
font-family: monospace; | |
font-weight: bold; | |
font-size: 13px; | |
color: black; | |
flex-shrink: 0; | |
min-width: 100px; | |
} | |
.preset-details { | |
display: flex; | |
align-items: center; | |
justify-content: flex-end; | |
gap: 8px; | |
flex-grow: 1; | |
font-size: 11px; | |
color: #6b7280; | |
} | |
.preset-range { | |
color: #6b7280; | |
} | |
.preset-uom { | |
color: #9ca3af; | |
font-size: 10px; | |
} | |
.gas-group { | |
margin-bottom: 8px; | |
} | |
.gas-group-header { | |
background: #f3f4f6; | |
color: #374151; | |
font-weight: bold; | |
font-size: 12px; | |
padding: 6px 12px; | |
border-bottom: 1px solid #e5e7eb; | |
text-transform: uppercase; | |
letter-spacing: 0.5px; | |
} | |
.gas-group:last-child { | |
margin-bottom: 0; | |
} | |
.preset-footer { | |
padding: 16px; | |
border-top: 1px solid #e5e7eb; | |
background: #f9fafb; | |
} | |
.close-btn { | |
width: 100%; | |
background: #4b5563; | |
color: white; | |
border: none; | |
padding: 8px 16px; | |
border-radius: 4px; | |
cursor: pointer; | |
font-weight: 500; | |
} | |
.close-btn:hover { | |
background: #374151; | |
} | |
/* Main Device */ | |
.fluke-body { | |
background: linear-gradient(135deg, rgba(255,255,255,0.2) 0%, transparent 50%), linear-gradient(to bottom, #eece2b, #facc15, #eab308); | |
border-radius: 24px 24px 0 0; | |
padding: 24px; | |
box-shadow: 0 20px 40px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.3), inset 0 -1px 0 rgba(0,0,0,0.2); | |
border: 4px solid #111827; | |
position: relative; | |
} | |
/* LCD Bezel */ | |
.lcd-bezel { | |
background: linear-gradient(to bottom, #1f2937, #111827); | |
border-radius: 12px; | |
padding: 16px; | |
margin-bottom: 24px; | |
box-shadow: inset 0 4px 8px rgba(0,0,0,0.6), 0 2px 4px rgba(0,0,0,0.3); | |
border: 2px solid #000; | |
} | |
/* Modern LCD Screen */ | |
.lcd-screen { | |
background: linear-gradient(to bottom, #e6eff8, #dae1f0); | |
border-radius: 8px; | |
padding: 14px 24px; | |
position: relative; | |
overflow: hidden; | |
min-height: 220px; | |
border: 2px solid #d1d5db; | |
box-shadow: inset 0 2px 4px rgba(0,0,0,0.1), 0 1px 2px rgba(255,255,255,0.8); | |
} | |
.lcd-content { | |
position: relative; | |
z-index: 10; | |
} | |
.header-bar { | |
display: flex; | |
justify-content: space-between; | |
align-items: center; | |
font-size: 14px; | |
padding: 8px 16px; | |
border-radius: 2px; | |
background: #374151; | |
color: white; | |
font-weight: 500; | |
margin-bottom: 16px; | |
} | |
.main-reading { | |
text-align: center; | |
padding: 10px 0; | |
} | |
.reading-value { | |
font-size: 64px; | |
font-weight: bold; | |
font-family: 'Segment', monospace; | |
letter-spacing: 2px; | |
color: black; | |
margin-bottom: 8px; | |
} | |
.percentage { | |
font-size: 18px; | |
color: #6b7280; | |
font-weight: 500; | |
} | |
.scale-container { | |
padding: 0 8px; | |
margin-bottom: 16px; | |
} | |
.scale-labels { | |
display: flex; | |
justify-content: space-between; | |
font-size: 14px; | |
margin-bottom: 8px; | |
color: #6b7280; | |
font-weight: 500; | |
} | |
.progress-bar { | |
width: 100%; | |
height: 8px; | |
border-radius: 0px; | |
background: #e5e7eb; | |
border: 1px solid #d1d5db; | |
position: relative; | |
overflow: hidden; | |
} | |
.progress-fill { | |
height: 100%; | |
border-radius: 0px; | |
background: #9ca3af; | |
transition: width 0.7s ease; | |
width: 0%; | |
-webkit-mask-image: repeating-linear-gradient(to right, black 0, black 5px, transparent 5px, transparent 6px); | |
mask-image: repeating-linear-gradient(to right, black 0, black 5px, transparent 5px, transparent 6px); | |
} | |
.range-display { | |
text-align: center; | |
font-size: 14px; | |
padding: 1px 8px 4px 8px; | |
border-radius: 2px; | |
background: #7f81870b; | |
border: 1px solid #d1d5db; | |
color: #374151; | |
font-weight: 500; | |
display: none; | |
} | |
.power-off { | |
display: flex; | |
align-items: center; | |
justify-content: center; | |
height: 100%; | |
text-align: center; | |
} | |
.power-off-text { | |
font-size: 32px; | |
font-family: monospace; | |
color: #9ca3af; | |
font-weight: bold; | |
} | |
.power-off-label { | |
font-size: 14px; | |
margin-top: 8px; | |
font-weight: 500; | |
color: #6b7280; | |
} | |
.lcd-reflection { | |
position: absolute; | |
top: 0; | |
left: 0; | |
right: 0; | |
bottom: 0; | |
background: linear-gradient(45deg, transparent 30%, rgba(255,255,255,0.3) 50%, transparent 70%); | |
opacity: 0.2; | |
pointer-events: none; | |
} | |
/* Buttons */ | |
.button-row { | |
display: grid; | |
grid-template-columns: 1fr 1fr 1fr; | |
gap: 12px; | |
margin-bottom: 0px; | |
} | |
.btn { | |
height: 42px; | |
font-weight: bold; | |
font-size: 14px; | |
border: 2px solid #111827; | |
border-radius: 4px; | |
cursor: pointer; | |
transition: all 0.15s; | |
display: flex; | |
align-items: center; | |
justify-content: center; | |
gap: 4px; | |
touch-action: manipulation; | |
} | |
.btn:active { | |
box-shadow: inset 0 4px 8px rgba(0,0,0,0.4); | |
transform: translateY(1px); | |
} | |
.btn.power { | |
background: linear-gradient(to bottom, #ef4444, #dc2626); | |
color: white; | |
box-shadow: 0 6px 12px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.2); | |
} | |
.btn.power.off { | |
background: linear-gradient(to bottom, #22c55e, #16a34a); | |
} | |
.btn.power:hover { | |
background: linear-gradient(to bottom, #dc2626, #b91c1c); | |
} | |
.btn.power.off:hover { | |
background: linear-gradient(to bottom, #16a34a, #15803d); | |
} | |
.btn.clear, .btn.preset-btn { | |
background: linear-gradient(to bottom, #4b5563, #1f2937); | |
color: #facc15; | |
box-shadow: 0 6px 12px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.1); | |
} | |
.btn.clear:hover, .btn.preset-btn:hover { | |
background: linear-gradient(to bottom, #6b7280, #374151); | |
} | |
.btn.test { | |
background: linear-gradient(to bottom, #3b82f6, #1d4ed8); | |
color: white; | |
box-shadow: 0 6px 12px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.2); | |
} | |
.btn.test:hover { | |
background: linear-gradient(to bottom, #2563eb, #1e40af); | |
} | |
/* Lower Case */ | |
.lower-case { | |
background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 50%), linear-gradient(to bottom, #374151, #1f2937, #111827); | |
border-radius: 0 0 24px 24px; | |
padding: 24px; | |
box-shadow: 0 20px 40px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.1); | |
border: 4px solid #111827; | |
border-top: none; | |
position: relative; | |
} | |
.input-group { | |
margin-bottom: 16px; | |
} | |
.input-row { | |
display: grid; | |
grid-template-columns: 1fr 1fr; | |
gap: 16px; | |
} | |
.input-label { | |
display: block; | |
color: #facc15; | |
font-size: 14px; | |
font-weight: bold; | |
margin-bottom: 8px; | |
letter-spacing: 1px; | |
text-shadow: 0 1px 2px rgba(0,0,0,0.5); | |
text-align: center; | |
} | |
.input-label.secondary { | |
color: #d1d5db; | |
font-size: 12px; | |
text-align: center; | |
} | |
.input-label.tertiary { | |
color: #9ca3af; | |
text-align: center; | |
} | |
.input-field { | |
height: 64px; | |
font-size: 20px; | |
text-align: center; | |
font-family: monospace; | |
letter-spacing: 1px; | |
background: linear-gradient(to bottom, #000, #1f2937); | |
border: 2px solid #facc15; | |
color: #facc15; | |
border-radius: 4px; | |
box-shadow: inset 0 2px 4px rgba(0,0,0,0.6), 0 1px 0 rgba(255,255,255,0.1); | |
transition: all 0.2s; | |
width: 100%; | |
touch-action: manipulation; | |
/* Prevent iOS zoom */ | |
-webkit-text-size-adjust: 100%; | |
text-size-adjust: 100%; | |
transform: scale(1); | |
transform-origin: center; | |
} | |
.input-field.small { | |
height: 48px; | |
font-size: 14px; | |
border: 1px solid #6b7280; | |
color: #d1d5db; | |
} | |
.input-field.tertiary { | |
border: 1px solid #4b5563; | |
color: #9ca3af; | |
} | |
.input-field:focus { | |
outline: none; | |
border-color: #fde047; | |
box-shadow: inset 0 2px 4px rgba(0,0,0,0.6), 0 0 0 4px rgba(253, 224, 71, 0.2); | |
} | |
.input-field:disabled { | |
opacity: 0.5; | |
cursor: not-allowed; | |
} | |
/* Hide default browser stepper controls */ | |
.input-field::-webkit-outer-spin-button, | |
.input-field::-webkit-inner-spin-button { | |
-webkit-appearance: none; | |
margin: 0; | |
} | |
.input-field[type=number] { | |
-moz-appearance: textfield; | |
} | |
.input-wrapper { | |
position: relative; | |
display: flex; | |
align-items: center; | |
gap: 8px; | |
} | |
.stepper-btn { | |
width: 48px; | |
height: 64px; | |
font-size: 24px; | |
font-weight: bold; | |
border: 2px solid #facc15; | |
border-radius: 4px; | |
cursor: pointer; | |
transition: all 0.15s; | |
display: flex; | |
align-items: center; | |
justify-content: center; | |
background: linear-gradient(to bottom, #4b5563, #1f2937); | |
color: #facc15; | |
box-shadow: 0 6px 12px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.1); | |
user-select: none; | |
touch-action: manipulation; | |
} | |
.stepper-btn.small { | |
height: 48px; | |
font-size: 18px; | |
border: 1px solid #6b7280; | |
color: #d1d5db; | |
} | |
.stepper-btn:hover { | |
background: linear-gradient(to bottom, #6b7280, #374151); | |
} | |
.stepper-btn:active { | |
box-shadow: inset 0 4px 8px rgba(0,0,0,0.4); | |
transform: translateY(1px); | |
} | |
.stepper-btn:disabled { | |
opacity: 0.5; | |
cursor: not-allowed; | |
} | |
.input-wrapper .input-field { | |
flex: 1; | |
} | |
.input-wrapper.small .stepper-btn { | |
width: 40px; | |
height: 48px; | |
font-size: 18px; | |
} | |
.info-panel { | |
margin-top: 24px; | |
padding-top: 16px; | |
border-top: 1px solid #4b5563; | |
background: linear-gradient(to right, transparent, rgba(55, 65, 81, 0.3), transparent); | |
border-radius: 4px; | |
padding: 8px; | |
} | |
.info-text { | |
text-align: center; | |
font-size: 11px; | |
color: #9ca3af; | |
font-family: monospace; | |
letter-spacing: 0px; | |
} | |
.hidden { | |
display: none !important; | |
} | |
/* Help Modal Styles */ | |
.help-modal { | |
position: fixed; | |
top: 0px; | |
left: 0px; | |
right: 0px; | |
bottom: 0px; | |
background: rgba(0,0,0,0.5); | |
z-index: 9999999; | |
transition: all 0.2s ease; | |
pointer-events: none; | |
opacity: 0; | |
visibility: hidden; | |
} | |
.help-modal.show { | |
opacity: 1; | |
visibility: visible; | |
pointer-events: auto; | |
} | |
.help-msgbox { | |
position: absolute; | |
top: 0; | |
bottom: 0; | |
left: 0; | |
right: 0; | |
width: 90%; | |
max-width: 600px; | |
margin: auto; | |
pointer-events: auto; | |
font-size: 18px; | |
line-height: 1.5; | |
} | |
.help-msgbox-inner { | |
position: relative; | |
top: 10%; | |
background: white; | |
border-radius: 5px; | |
padding: 30px; | |
box-shadow: 0 19px 38px rgba(0,0,0,0.20), 0 15px 19px rgba(0,0,0,0.22); | |
} | |
.help-modal h1 { | |
font-size: 21px; | |
font-weight: 700; | |
margin-bottom: 20px; | |
color: #115EA3; | |
} | |
.help-modal .button { | |
background: #115EA3; | |
color: white; | |
border: none; | |
padding: 10px 20px; | |
border-radius: 4px; | |
cursor: pointer; | |
font-size: 16px; | |
font-weight: 500; | |
} | |
.help-modal .button:hover { | |
background: #0d4a7a; | |
} | |
</style> | |
</head> | |
<body> | |
<div class="container"> | |
<!-- Help Modal --> | |
<div id="help-modal" class="help-modal" onclick="closeHelp()"> | |
<div class="help-msgbox"> | |
<div class="help-msgbox-inner" style="line-height: 1.5;" onclick="event.stopPropagation()"> | |
<h1>Conversions</h1> | |
<b>Convert 40/200mV to Unit of Measure:</b><br> | |
<svg style="margin-top: 10px; margin-left: 17px;" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="258.301213pt" height="13.522849pt" viewBox="-.504138 -.301849 258.301213 13.522849"> | |
<defs> | |
<path id="g2-40" d="M3.88543 2.905106C3.88543 2.86924 3.88543 2.84533 3.682192 2.642092C2.486675 1.43462 1.817186-.537983 1.817186-2.976837C1.817186-5.296139 2.379078-7.292653 3.765878-8.703362C3.88543-8.810959 3.88543-8.834869 3.88543-8.870735C3.88543-8.942466 3.825654-8.966376 3.777833-8.966376C3.622416-8.966376 2.642092-8.105604 2.056289-6.933998C1.446575-5.726526 1.171606-4.447323 1.171606-2.976837C1.171606-1.912827 1.338979-.490162 1.960648 .789041C2.666002 2.223661 3.646326 3.000747 3.777833 3.000747C3.825654 3.000747 3.88543 2.976837 3.88543 2.905106Z"></path> | |
<path id="g2-41" d="M3.371357-2.976837C3.371357-3.88543 3.251806-5.36787 2.582316-6.75467C1.876961-8.18929 .896638-8.966376 .765131-8.966376C.71731-8.966376 .657534-8.942466 .657534-8.870735C.657534-8.834869 .657534-8.810959 .860772-8.607721C2.056289-7.400249 2.725778-5.427646 2.725778-2.988792C2.725778-.669489 2.163885 1.327024 .777086 2.737733C.657534 2.84533 .657534 2.86924 .657534 2.905106C.657534 2.976837 .71731 3.000747 .765131 3.000747C.920548 3.000747 1.900872 2.139975 2.486675 .968369C3.096389-.251059 3.371357-1.542217 3.371357-2.976837Z"></path> | |
<path id="g2-43" d="M4.770112-2.761644H8.069738C8.237111-2.761644 8.452304-2.761644 8.452304-2.976837C8.452304-3.203985 8.249066-3.203985 8.069738-3.203985H4.770112V-6.503611C4.770112-6.670984 4.770112-6.886177 4.554919-6.886177C4.327771-6.886177 4.327771-6.682939 4.327771-6.503611V-3.203985H1.028144C.860772-3.203985 .645579-3.203985 .645579-2.988792C.645579-2.761644 .848817-2.761644 1.028144-2.761644H4.327771V.537983C4.327771 .705355 4.327771 .920548 4.542964 .920548C4.770112 .920548 4.770112 .71731 4.770112 .537983V-2.761644Z"></path> | |
<path id="g2-48" d="M5.355915-3.825654C5.355915-4.817933 5.296139-5.786301 4.865753-6.694894C4.375592-7.687173 3.514819-7.950187 2.929016-7.950187C2.235616-7.950187 1.3868-7.603487 .944458-6.611208C.609714-5.858032 .490162-5.116812 .490162-3.825654C.490162-2.666002 .573848-1.793275 1.004234-.944458C1.470486-.035866 2.295392 .251059 2.917061 .251059C3.957161 .251059 4.554919-.37061 4.901619-1.06401C5.332005-1.960648 5.355915-3.132254 5.355915-3.825654ZM2.917061 .011955C2.534496 .011955 1.75741-.203238 1.530262-1.506351C1.398755-2.223661 1.398755-3.132254 1.398755-3.969116C1.398755-4.94944 1.398755-5.834122 1.590037-6.539477C1.793275-7.340473 2.402989-7.711083 2.917061-7.711083C3.371357-7.711083 4.064757-7.436115 4.291905-6.40797C4.447323-5.726526 4.447323-4.782067 4.447323-3.969116C4.447323-3.16812 4.447323-2.259527 4.315816-1.530262C4.088667-.215193 3.335492 .011955 2.917061 .011955Z"></path> | |
<path id="g2-49" d="M3.443088-7.663263C3.443088-7.938232 3.443088-7.950187 3.203985-7.950187C2.917061-7.627397 2.319303-7.185056 1.08792-7.185056V-6.838356C1.362889-6.838356 1.960648-6.838356 2.618182-7.149191V-.920548C2.618182-.490162 2.582316-.3467 1.530262-.3467H1.159651V0C1.482441-.02391 2.642092-.02391 3.036613-.02391S4.578829-.02391 4.901619 0V-.3467H4.531009C3.478954-.3467 3.443088-.490162 3.443088-.920548V-7.663263Z"></path> | |
<path id="g2-52" d="M4.315816-7.782814C4.315816-8.009963 4.315816-8.069738 4.148443-8.069738C4.052802-8.069738 4.016936-8.069738 3.921295-7.926276L.32279-2.343213V-1.996513H3.466999V-.908593C3.466999-.466252 3.443088-.3467 2.570361-.3467H2.331258V0C2.606227-.02391 3.550685-.02391 3.88543-.02391S5.176588-.02391 5.451557 0V-.3467H5.212453C4.351681-.3467 4.315816-.466252 4.315816-.908593V-1.996513H5.523288V-2.343213H4.315816V-7.782814ZM3.526775-6.850311V-2.343213H.621669L3.526775-6.850311Z"></path> | |
<path id="g2-54" d="M1.470486-4.160399C1.470486-7.185056 2.940971-7.663263 3.58655-7.663263C4.016936-7.663263 4.447323-7.531756 4.674471-7.173101C4.531009-7.173101 4.076712-7.173101 4.076712-6.682939C4.076712-6.419925 4.25604-6.192777 4.566874-6.192777C4.865753-6.192777 5.068991-6.372105 5.068991-6.718804C5.068991-7.340473 4.614695-7.950187 3.574595-7.950187C2.068244-7.950187 .490162-6.40797 .490162-3.777833C.490162-.490162 1.924782 .251059 2.940971 .251059C4.244085 .251059 5.355915-.884682 5.355915-2.438854C5.355915-4.028892 4.244085-5.092902 3.048568-5.092902C1.984558-5.092902 1.590037-4.172354 1.470486-3.837609V-4.160399ZM2.940971-.071731C2.187796-.071731 1.829141-.74122 1.721544-.992279C1.613948-1.303113 1.494396-1.888917 1.494396-2.725778C1.494396-3.670237 1.924782-4.853798 3.000747-4.853798C3.658281-4.853798 4.004981-4.411457 4.184309-4.004981C4.375592-3.56264 4.375592-2.964882 4.375592-2.450809C4.375592-1.841096 4.375592-1.303113 4.148443-.848817C3.849564-.274969 3.419178-.071731 2.940971-.071731Z"></path> | |
<path id="g2-61" d="M8.069738-3.873474C8.237111-3.873474 8.452304-3.873474 8.452304-4.088667C8.452304-4.315816 8.249066-4.315816 8.069738-4.315816H1.028144C.860772-4.315816 .645579-4.315816 .645579-4.100623C.645579-3.873474 .848817-3.873474 1.028144-3.873474H8.069738ZM8.069738-1.649813C8.237111-1.649813 8.452304-1.649813 8.452304-1.865006C8.452304-2.092154 8.249066-2.092154 8.069738-2.092154H1.028144C.860772-2.092154 .645579-2.092154 .645579-1.876961C.645579-1.649813 .848817-1.649813 1.028144-1.649813H8.069738Z"></path> | |
<path id="g0-0" d="M7.878456-2.749689C8.081694-2.749689 8.296887-2.749689 8.296887-2.988792S8.081694-3.227895 7.878456-3.227895H1.41071C1.207472-3.227895 .992279-3.227895 .992279-2.988792S1.207472-2.749689 1.41071-2.749689H7.878456Z"></path> | |
<path id="g0-3" d="M3.287671-5.104857C3.299626-5.272229 3.299626-5.559153 2.988792-5.559153C2.797509-5.559153 2.642092-5.403736 2.677958-5.248319V-5.092902L2.84533-3.239851L1.315068-4.351681C1.207472-4.411457 1.183562-4.435367 1.099875-4.435367C.932503-4.435367 .777086-4.267995 .777086-4.100623C.777086-3.90934 .896638-3.861519 1.016189-3.801743L2.713823-2.988792L1.06401-2.187796C.872727-2.092154 .777086-2.044334 .777086-1.865006S.932503-1.530262 1.099875-1.530262C1.183562-1.530262 1.207472-1.530262 1.506351-1.75741L2.84533-2.725778L2.666002-.71731C2.666002-.466252 2.881196-.406476 2.976837-.406476C3.120299-.406476 3.299626-.490162 3.299626-.71731L3.120299-2.725778L4.65056-1.613948C4.758157-1.554172 4.782067-1.530262 4.865753-1.530262C5.033126-1.530262 5.188543-1.697634 5.188543-1.865006C5.188543-2.044334 5.080946-2.10411 4.937484-2.175841C4.220174-2.534496 4.196264-2.534496 3.251806-2.976837L4.901619-3.777833C5.092902-3.873474 5.188543-3.921295 5.188543-4.100623S5.033126-4.435367 4.865753-4.435367C4.782067-4.435367 4.758157-4.435367 4.459278-4.208219L3.120299-3.239851L3.287671-5.104857Z"></path> | |
<path id="g1-61" d="M5.128767-8.524035C5.128767-8.53599 5.200498-8.715318 5.200498-8.739228C5.200498-8.88269 5.080946-8.966376 4.985305-8.966376C4.925529-8.966376 4.817933-8.966376 4.722291-8.703362L.71731 2.546451C.71731 2.558406 .645579 2.737733 .645579 2.761644C.645579 2.905106 .765131 2.988792 .860772 2.988792C.932503 2.988792 1.0401 2.976837 1.123786 2.725778L5.128767-8.524035Z"></path> | |
<path id="g1-82" d="M4.399502-7.352428C4.507098-7.79477 4.554919-7.81868 5.021171-7.81868H5.881943C6.910087-7.81868 7.675218-7.507846 7.675218-6.575342C7.675218-5.965629 7.364384-4.208219 4.961395-4.208219H3.610461L4.399502-7.352428ZM6.06127-4.064757C7.543711-4.387547 8.703362-5.34396 8.703362-6.372105C8.703362-7.304608 7.758904-8.16538 6.097136-8.16538H2.857285C2.618182-8.16538 2.510585-8.16538 2.510585-7.938232C2.510585-7.81868 2.594271-7.81868 2.82142-7.81868C3.53873-7.81868 3.53873-7.723039 3.53873-7.591532C3.53873-7.567621 3.53873-7.49589 3.490909-7.316563L1.876961-.884682C1.769365-.466252 1.745455-.3467 .920548-.3467C.645579-.3467 .561893-.3467 .561893-.119552C.561893 0 .6934 0 .729265 0C.944458 0 1.195517-.02391 1.422665-.02391H2.833375C3.048568-.02391 3.299626 0 3.514819 0C3.610461 0 3.741968 0 3.741968-.227148C3.741968-.3467 3.634371-.3467 3.455044-.3467C2.725778-.3467 2.725778-.442341 2.725778-.561893C2.725778-.573848 2.725778-.657534 2.749689-.753176L3.550685-3.969116H4.985305C6.121046-3.969116 6.336239-3.251806 6.336239-2.857285C6.336239-2.677958 6.216687-2.211706 6.133001-1.900872C6.001494-1.350934 5.965629-1.219427 5.965629-.992279C5.965629-.143462 6.659029 .251059 7.460025 .251059C8.428394 .251059 8.846824-.932503 8.846824-1.099875C8.846824-1.183562 8.787049-1.219427 8.715318-1.219427C8.619676-1.219427 8.595766-1.147696 8.571856-1.052055C8.284932-.203238 7.79477 .011955 7.49589 .011955S7.005729-.119552 7.005729-.657534C7.005729-.944458 7.149191-2.032379 7.161146-2.092154C7.220922-2.534496 7.220922-2.582316 7.220922-2.677958C7.220922-3.550685 6.515567-3.921295 6.06127-4.064757Z"></path> | |
<path id="g1-83" d="M7.591532-8.308842C7.591532-8.416438 7.507846-8.416438 7.483935-8.416438C7.436115-8.416438 7.424159-8.404483 7.280697-8.225156C7.208966-8.141469 6.718804-7.519801 6.706849-7.507846C6.312329-8.284932 5.523288-8.416438 5.021171-8.416438C3.502864-8.416438 2.12802-7.029639 2.12802-5.678705C2.12802-4.782067 2.666002-4.25604 3.251806-4.052802C3.383313-4.004981 4.088667-3.813699 4.447323-3.730012C5.057036-3.56264 5.212453-3.514819 5.463512-3.251806C5.511333-3.19203 5.750436-2.917061 5.750436-2.355168C5.750436-1.243337 4.722291-.095641 3.526775-.095641C2.546451-.095641 1.458531-.514072 1.458531-1.853051C1.458531-2.080199 1.506351-2.367123 1.542217-2.486675C1.542217-2.52254 1.554172-2.582316 1.554172-2.606227C1.554172-2.654047 1.530262-2.713823 1.43462-2.713823C1.327024-2.713823 1.315068-2.689913 1.267248-2.486675L.657534-.035866C.657534-.02391 .609714 .131507 .609714 .143462C.609714 .251059 .705355 .251059 .729265 .251059C.777086 .251059 .789041 .239103 .932503 .059776L1.482441-.657534C1.769365-.227148 2.391034 .251059 3.502864 .251059C5.045081 .251059 6.455791-1.243337 6.455791-2.737733C6.455791-3.239851 6.336239-3.682192 5.881943-4.124533C5.630884-4.375592 5.415691-4.435367 4.315816-4.722291C3.514819-4.937484 3.407223-4.97335 3.19203-5.164633C2.988792-5.36787 2.833375-5.654795 2.833375-6.06127C2.833375-7.065504 3.849564-8.093649 4.985305-8.093649C6.156912-8.093649 6.706849-7.376339 6.706849-6.240598C6.706849-5.929763 6.647073-5.606974 6.647073-5.559153C6.647073-5.451557 6.742715-5.451557 6.77858-5.451557C6.886177-5.451557 6.898132-5.487422 6.945953-5.678705L7.591532-8.308842Z"></path> | |
<path id="g1-86" d="M7.400249-6.838356C7.806725-7.483935 8.177335-7.770859 8.787049-7.81868C8.9066-7.830635 9.002242-7.830635 9.002242-8.045828C9.002242-8.093649 8.978331-8.16538 8.870735-8.16538C8.655542-8.16538 8.141469-8.141469 7.926276-8.141469C7.579577-8.141469 7.220922-8.16538 6.886177-8.16538C6.790535-8.16538 6.670984-8.16538 6.670984-7.938232C6.670984-7.830635 6.77858-7.81868 6.826401-7.81868C7.268742-7.782814 7.316563-7.567621 7.316563-7.424159C7.316563-7.244832 7.149191-6.969863 7.137235-6.957908L3.383313-1.004234L2.546451-7.44807C2.546451-7.79477 3.16812-7.81868 3.299626-7.81868C3.478954-7.81868 3.58655-7.81868 3.58655-8.045828C3.58655-8.16538 3.455044-8.16538 3.419178-8.16538C3.21594-8.16538 2.976837-8.141469 2.773599-8.141469H2.10411C1.231382-8.141469 .872727-8.16538 .860772-8.16538C.789041-8.16538 .645579-8.16538 .645579-7.950187C.645579-7.81868 .729265-7.81868 .920548-7.81868C1.530262-7.81868 1.566127-7.711083 1.601993-7.412204L2.558406-.035866C2.594271 .215193 2.594271 .251059 2.761644 .251059C2.905106 .251059 2.964882 .215193 3.084433 .02391L7.400249-6.838356Z"></path> | |
<path id="g1-90" d="M8.368618-7.79477C8.440349-7.878456 8.500125-7.950187 8.500125-8.069738C8.500125-8.153425 8.488169-8.16538 8.2132-8.16538H3.275716C3.000747-8.16538 2.988792-8.153425 2.917061-7.938232L2.259527-5.786301C2.223661-5.66675 2.223661-5.642839 2.223661-5.618929C2.223661-5.571108 2.259527-5.499377 2.343213-5.499377C2.438854-5.499377 2.462765-5.547198 2.510585-5.702615C2.952927-6.993773 3.53873-7.81868 5.427646-7.81868H7.388294L.836862-.406476C.729265-.274969 .681445-.227148 .681445-.095641C.681445 0 .74122 0 .968369 0H6.073225C6.348194 0 6.360149-.011955 6.43188-.227148L7.268742-2.86924C7.280697-2.905106 7.304608-2.988792 7.304608-3.036613C7.304608-3.096389 7.256787-3.156164 7.185056-3.156164C7.089415-3.156164 7.07746-3.144209 6.981818-2.84533C6.479701-1.303113 5.953674-.37061 3.873474-.37061H1.80523L8.368618-7.79477Z"></path> | |
<path id="g1-109" d="M2.462765-3.502864C2.486675-3.574595 2.785554-4.172354 3.227895-4.554919C3.53873-4.841843 3.945205-5.033126 4.411457-5.033126C4.889664-5.033126 5.057036-4.674471 5.057036-4.196264C5.057036-4.124533 5.057036-3.88543 4.913574-3.323537L4.614695-2.092154C4.519054-1.733499 4.291905-.848817 4.267995-.71731C4.220174-.537983 4.148443-.227148 4.148443-.179328C4.148443-.011955 4.27995 .119552 4.459278 .119552C4.817933 .119552 4.877709-.155417 4.985305-.585803L5.702615-3.443088C5.726526-3.53873 6.348194-5.033126 7.663263-5.033126C8.141469-5.033126 8.308842-4.674471 8.308842-4.196264C8.308842-3.526775 7.84259-2.223661 7.579577-1.506351C7.47198-1.219427 7.412204-1.06401 7.412204-.848817C7.412204-.310834 7.782814 .119552 8.356663 .119552C9.468493 .119552 9.886924-1.637858 9.886924-1.709589C9.886924-1.769365 9.839103-1.817186 9.767372-1.817186C9.659776-1.817186 9.647821-1.78132 9.588045-1.578082C9.313076-.621669 8.870735-.119552 8.392528-.119552C8.272976-.119552 8.081694-.131507 8.081694-.514072C8.081694-.824907 8.225156-1.207472 8.272976-1.338979C8.488169-1.912827 9.026152-3.323537 9.026152-4.016936C9.026152-4.734247 8.607721-5.272229 7.699128-5.272229C6.898132-5.272229 6.252553-4.817933 5.774346-4.112578C5.738481-4.758157 5.34396-5.272229 4.447323-5.272229C3.383313-5.272229 2.82142-4.519054 2.606227-4.220174C2.570361-4.901619 2.080199-5.272229 1.554172-5.272229C1.207472-5.272229 .932503-5.104857 .705355-4.65056C.490162-4.220174 .32279-3.490909 .32279-3.443088S.37061-3.335492 .454296-3.335492C.549938-3.335492 .561893-3.347447 .633624-3.622416C.812951-4.327771 1.0401-5.033126 1.518306-5.033126C1.793275-5.033126 1.888917-4.841843 1.888917-4.483188C1.888917-4.220174 1.769365-3.753923 1.685679-3.383313L1.350934-2.092154C1.303113-1.865006 1.171606-1.327024 1.111831-1.111831C1.028144-.800996 .896638-.239103 .896638-.179328C.896638-.011955 1.028144 .119552 1.207472 .119552C1.350934 .119552 1.518306 .047821 1.613948-.131507C1.637858-.191283 1.745455-.609714 1.80523-.848817L2.068244-1.924782L2.462765-3.502864Z"></path> | |
</defs> | |
<g id="page1" transform="matrix(1.13 0 0 1.13 -141.234384 -80.795)"> | |
<use x="123.873654" y="80.199253" xlink:href="#g1-86"></use> | |
<use x="136.620163" y="80.199253" xlink:href="#g2-61"></use> | |
<use x="149.045644" y="80.199253" xlink:href="#g2-40"></use> | |
<use x="153.597969" y="80.199253" xlink:href="#g2-40"></use> | |
<use x="158.150295" y="80.199253" xlink:href="#g1-82"></use> | |
<use x="169.815474" y="80.199253" xlink:href="#g0-0"></use> | |
<use x="181.770634" y="80.199253" xlink:href="#g2-52"></use> | |
<use x="187.623625" y="80.199253" xlink:href="#g2-48"></use> | |
<use x="193.476615" y="80.199253" xlink:href="#g1-109"></use> | |
<use x="203.715882" y="80.199253" xlink:href="#g1-86"></use> | |
<use x="213.141561" y="80.199253" xlink:href="#g2-41"></use> | |
<use x="219.686365" y="80.199253" xlink:href="#g1-61"></use> | |
<use x="225.539355" y="80.199253" xlink:href="#g2-49"></use> | |
<use x="231.392346" y="80.199253" xlink:href="#g2-54"></use> | |
<use x="237.245336" y="80.199253" xlink:href="#g2-48"></use> | |
<use x="243.098326" y="80.199253" xlink:href="#g1-109"></use> | |
<use x="253.337593" y="80.199253" xlink:href="#g1-86"></use> | |
<use x="262.763272" y="80.199253" xlink:href="#g2-41"></use> | |
<use x="269.97225" y="80.199253" xlink:href="#g0-3"></use> | |
<use x="278.60652" y="80.199253" xlink:href="#g2-40"></use> | |
<use x="283.158846" y="80.199253" xlink:href="#g1-83"></use> | |
<use x="293.710833" y="80.199253" xlink:href="#g0-0"></use> | |
<use x="305.665993" y="80.199253" xlink:href="#g1-90"></use> | |
<use x="314.536815" y="80.199253" xlink:href="#g2-41"></use> | |
<use x="321.745789" y="80.199253" xlink:href="#g2-43"></use> | |
<use x="333.507104" y="80.199253" xlink:href="#g1-90"></use> | |
</g> | |
</svg> | |
<br> | |
<br> | |
<b>Convert Unit of Measure to 40/200mV:</b><br> | |
<svg style="margin-top: 10px; margin-left: 17px;" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="248.047934pt" height="13.522849pt" viewBox="-.523074 -.301849 248.047934 13.522849"> | |
<defs> | |
<path id="g2-40" d="M3.88543 2.905106C3.88543 2.86924 3.88543 2.84533 3.682192 2.642092C2.486675 1.43462 1.817186-.537983 1.817186-2.976837C1.817186-5.296139 2.379078-7.292653 3.765878-8.703362C3.88543-8.810959 3.88543-8.834869 3.88543-8.870735C3.88543-8.942466 3.825654-8.966376 3.777833-8.966376C3.622416-8.966376 2.642092-8.105604 2.056289-6.933998C1.446575-5.726526 1.171606-4.447323 1.171606-2.976837C1.171606-1.912827 1.338979-.490162 1.960648 .789041C2.666002 2.223661 3.646326 3.000747 3.777833 3.000747C3.825654 3.000747 3.88543 2.976837 3.88543 2.905106Z"></path> | |
<path id="g2-41" d="M3.371357-2.976837C3.371357-3.88543 3.251806-5.36787 2.582316-6.75467C1.876961-8.18929 .896638-8.966376 .765131-8.966376C.71731-8.966376 .657534-8.942466 .657534-8.870735C.657534-8.834869 .657534-8.810959 .860772-8.607721C2.056289-7.400249 2.725778-5.427646 2.725778-2.988792C2.725778-.669489 2.163885 1.327024 .777086 2.737733C.657534 2.84533 .657534 2.86924 .657534 2.905106C.657534 2.976837 .71731 3.000747 .765131 3.000747C.920548 3.000747 1.900872 2.139975 2.486675 .968369C3.096389-.251059 3.371357-1.542217 3.371357-2.976837Z"></path> | |
<path id="g2-43" d="M4.770112-2.761644H8.069738C8.237111-2.761644 8.452304-2.761644 8.452304-2.976837C8.452304-3.203985 8.249066-3.203985 8.069738-3.203985H4.770112V-6.503611C4.770112-6.670984 4.770112-6.886177 4.554919-6.886177C4.327771-6.886177 4.327771-6.682939 4.327771-6.503611V-3.203985H1.028144C.860772-3.203985 .645579-3.203985 .645579-2.988792C.645579-2.761644 .848817-2.761644 1.028144-2.761644H4.327771V.537983C4.327771 .705355 4.327771 .920548 4.542964 .920548C4.770112 .920548 4.770112 .71731 4.770112 .537983V-2.761644Z"></path> | |
<path id="g2-48" d="M5.355915-3.825654C5.355915-4.817933 5.296139-5.786301 4.865753-6.694894C4.375592-7.687173 3.514819-7.950187 2.929016-7.950187C2.235616-7.950187 1.3868-7.603487 .944458-6.611208C.609714-5.858032 .490162-5.116812 .490162-3.825654C.490162-2.666002 .573848-1.793275 1.004234-.944458C1.470486-.035866 2.295392 .251059 2.917061 .251059C3.957161 .251059 4.554919-.37061 4.901619-1.06401C5.332005-1.960648 5.355915-3.132254 5.355915-3.825654ZM2.917061 .011955C2.534496 .011955 1.75741-.203238 1.530262-1.506351C1.398755-2.223661 1.398755-3.132254 1.398755-3.969116C1.398755-4.94944 1.398755-5.834122 1.590037-6.539477C1.793275-7.340473 2.402989-7.711083 2.917061-7.711083C3.371357-7.711083 4.064757-7.436115 4.291905-6.40797C4.447323-5.726526 4.447323-4.782067 4.447323-3.969116C4.447323-3.16812 4.447323-2.259527 4.315816-1.530262C4.088667-.215193 3.335492 .011955 2.917061 .011955Z"></path> | |
<path id="g2-49" d="M3.443088-7.663263C3.443088-7.938232 3.443088-7.950187 3.203985-7.950187C2.917061-7.627397 2.319303-7.185056 1.08792-7.185056V-6.838356C1.362889-6.838356 1.960648-6.838356 2.618182-7.149191V-.920548C2.618182-.490162 2.582316-.3467 1.530262-.3467H1.159651V0C1.482441-.02391 2.642092-.02391 3.036613-.02391S4.578829-.02391 4.901619 0V-.3467H4.531009C3.478954-.3467 3.443088-.490162 3.443088-.920548V-7.663263Z"></path> | |
<path id="g2-52" d="M4.315816-7.782814C4.315816-8.009963 4.315816-8.069738 4.148443-8.069738C4.052802-8.069738 4.016936-8.069738 3.921295-7.926276L.32279-2.343213V-1.996513H3.466999V-.908593C3.466999-.466252 3.443088-.3467 2.570361-.3467H2.331258V0C2.606227-.02391 3.550685-.02391 3.88543-.02391S5.176588-.02391 5.451557 0V-.3467H5.212453C4.351681-.3467 4.315816-.466252 4.315816-.908593V-1.996513H5.523288V-2.343213H4.315816V-7.782814ZM3.526775-6.850311V-2.343213H.621669L3.526775-6.850311Z"></path> | |
<path id="g2-54" d="M1.470486-4.160399C1.470486-7.185056 2.940971-7.663263 3.58655-7.663263C4.016936-7.663263 4.447323-7.531756 4.674471-7.173101C4.531009-7.173101 4.076712-7.173101 4.076712-6.682939C4.076712-6.419925 4.25604-6.192777 4.566874-6.192777C4.865753-6.192777 5.068991-6.372105 5.068991-6.718804C5.068991-7.340473 4.614695-7.950187 3.574595-7.950187C2.068244-7.950187 .490162-6.40797 .490162-3.777833C.490162-.490162 1.924782 .251059 2.940971 .251059C4.244085 .251059 5.355915-.884682 5.355915-2.438854C5.355915-4.028892 4.244085-5.092902 3.048568-5.092902C1.984558-5.092902 1.590037-4.172354 1.470486-3.837609V-4.160399ZM2.940971-.071731C2.187796-.071731 1.829141-.74122 1.721544-.992279C1.613948-1.303113 1.494396-1.888917 1.494396-2.725778C1.494396-3.670237 1.924782-4.853798 3.000747-4.853798C3.658281-4.853798 4.004981-4.411457 4.184309-4.004981C4.375592-3.56264 4.375592-2.964882 4.375592-2.450809C4.375592-1.841096 4.375592-1.303113 4.148443-.848817C3.849564-.274969 3.419178-.071731 2.940971-.071731Z"></path> | |
<path id="g2-61" d="M8.069738-3.873474C8.237111-3.873474 8.452304-3.873474 8.452304-4.088667C8.452304-4.315816 8.249066-4.315816 8.069738-4.315816H1.028144C.860772-4.315816 .645579-4.315816 .645579-4.100623C.645579-3.873474 .848817-3.873474 1.028144-3.873474H8.069738ZM8.069738-1.649813C8.237111-1.649813 8.452304-1.649813 8.452304-1.865006C8.452304-2.092154 8.249066-2.092154 8.069738-2.092154H1.028144C.860772-2.092154 .645579-2.092154 .645579-1.876961C.645579-1.649813 .848817-1.649813 1.028144-1.649813H8.069738Z"></path> | |
<path id="g0-0" d="M7.878456-2.749689C8.081694-2.749689 8.296887-2.749689 8.296887-2.988792S8.081694-3.227895 7.878456-3.227895H1.41071C1.207472-3.227895 .992279-3.227895 .992279-2.988792S1.207472-2.749689 1.41071-2.749689H7.878456Z"></path> | |
<path id="g0-3" d="M3.287671-5.104857C3.299626-5.272229 3.299626-5.559153 2.988792-5.559153C2.797509-5.559153 2.642092-5.403736 2.677958-5.248319V-5.092902L2.84533-3.239851L1.315068-4.351681C1.207472-4.411457 1.183562-4.435367 1.099875-4.435367C.932503-4.435367 .777086-4.267995 .777086-4.100623C.777086-3.90934 .896638-3.861519 1.016189-3.801743L2.713823-2.988792L1.06401-2.187796C.872727-2.092154 .777086-2.044334 .777086-1.865006S.932503-1.530262 1.099875-1.530262C1.183562-1.530262 1.207472-1.530262 1.506351-1.75741L2.84533-2.725778L2.666002-.71731C2.666002-.466252 2.881196-.406476 2.976837-.406476C3.120299-.406476 3.299626-.490162 3.299626-.71731L3.120299-2.725778L4.65056-1.613948C4.758157-1.554172 4.782067-1.530262 4.865753-1.530262C5.033126-1.530262 5.188543-1.697634 5.188543-1.865006C5.188543-2.044334 5.080946-2.10411 4.937484-2.175841C4.220174-2.534496 4.196264-2.534496 3.251806-2.976837L4.901619-3.777833C5.092902-3.873474 5.188543-3.921295 5.188543-4.100623S5.033126-4.435367 4.865753-4.435367C4.782067-4.435367 4.758157-4.435367 4.459278-4.208219L3.120299-3.239851L3.287671-5.104857Z"></path> | |
<path id="g1-61" d="M5.128767-8.524035C5.128767-8.53599 5.200498-8.715318 5.200498-8.739228C5.200498-8.88269 5.080946-8.966376 4.985305-8.966376C4.925529-8.966376 4.817933-8.966376 4.722291-8.703362L.71731 2.546451C.71731 2.558406 .645579 2.737733 .645579 2.761644C.645579 2.905106 .765131 2.988792 .860772 2.988792C.932503 2.988792 1.0401 2.976837 1.123786 2.725778L5.128767-8.524035Z"></path> | |
<path id="g1-82" d="M4.399502-7.352428C4.507098-7.79477 4.554919-7.81868 5.021171-7.81868H5.881943C6.910087-7.81868 7.675218-7.507846 7.675218-6.575342C7.675218-5.965629 7.364384-4.208219 4.961395-4.208219H3.610461L4.399502-7.352428ZM6.06127-4.064757C7.543711-4.387547 8.703362-5.34396 8.703362-6.372105C8.703362-7.304608 7.758904-8.16538 6.097136-8.16538H2.857285C2.618182-8.16538 2.510585-8.16538 2.510585-7.938232C2.510585-7.81868 2.594271-7.81868 2.82142-7.81868C3.53873-7.81868 3.53873-7.723039 3.53873-7.591532C3.53873-7.567621 3.53873-7.49589 3.490909-7.316563L1.876961-.884682C1.769365-.466252 1.745455-.3467 .920548-.3467C.645579-.3467 .561893-.3467 .561893-.119552C.561893 0 .6934 0 .729265 0C.944458 0 1.195517-.02391 1.422665-.02391H2.833375C3.048568-.02391 3.299626 0 3.514819 0C3.610461 0 3.741968 0 3.741968-.227148C3.741968-.3467 3.634371-.3467 3.455044-.3467C2.725778-.3467 2.725778-.442341 2.725778-.561893C2.725778-.573848 2.725778-.657534 2.749689-.753176L3.550685-3.969116H4.985305C6.121046-3.969116 6.336239-3.251806 6.336239-2.857285C6.336239-2.677958 6.216687-2.211706 6.133001-1.900872C6.001494-1.350934 5.965629-1.219427 5.965629-.992279C5.965629-.143462 6.659029 .251059 7.460025 .251059C8.428394 .251059 8.846824-.932503 8.846824-1.099875C8.846824-1.183562 8.787049-1.219427 8.715318-1.219427C8.619676-1.219427 8.595766-1.147696 8.571856-1.052055C8.284932-.203238 7.79477 .011955 7.49589 .011955S7.005729-.119552 7.005729-.657534C7.005729-.944458 7.149191-2.032379 7.161146-2.092154C7.220922-2.534496 7.220922-2.582316 7.220922-2.677958C7.220922-3.550685 6.515567-3.921295 6.06127-4.064757Z"></path> | |
<path id="g1-83" d="M7.591532-8.308842C7.591532-8.416438 7.507846-8.416438 7.483935-8.416438C7.436115-8.416438 7.424159-8.404483 7.280697-8.225156C7.208966-8.141469 6.718804-7.519801 6.706849-7.507846C6.312329-8.284932 5.523288-8.416438 5.021171-8.416438C3.502864-8.416438 2.12802-7.029639 2.12802-5.678705C2.12802-4.782067 2.666002-4.25604 3.251806-4.052802C3.383313-4.004981 4.088667-3.813699 4.447323-3.730012C5.057036-3.56264 5.212453-3.514819 5.463512-3.251806C5.511333-3.19203 5.750436-2.917061 5.750436-2.355168C5.750436-1.243337 4.722291-.095641 3.526775-.095641C2.546451-.095641 1.458531-.514072 1.458531-1.853051C1.458531-2.080199 1.506351-2.367123 1.542217-2.486675C1.542217-2.52254 1.554172-2.582316 1.554172-2.606227C1.554172-2.654047 1.530262-2.713823 1.43462-2.713823C1.327024-2.713823 1.315068-2.689913 1.267248-2.486675L.657534-.035866C.657534-.02391 .609714 .131507 .609714 .143462C.609714 .251059 .705355 .251059 .729265 .251059C.777086 .251059 .789041 .239103 .932503 .059776L1.482441-.657534C1.769365-.227148 2.391034 .251059 3.502864 .251059C5.045081 .251059 6.455791-1.243337 6.455791-2.737733C6.455791-3.239851 6.336239-3.682192 5.881943-4.124533C5.630884-4.375592 5.415691-4.435367 4.315816-4.722291C3.514819-4.937484 3.407223-4.97335 3.19203-5.164633C2.988792-5.36787 2.833375-5.654795 2.833375-6.06127C2.833375-7.065504 3.849564-8.093649 4.985305-8.093649C6.156912-8.093649 6.706849-7.376339 6.706849-6.240598C6.706849-5.929763 6.647073-5.606974 6.647073-5.559153C6.647073-5.451557 6.742715-5.451557 6.77858-5.451557C6.886177-5.451557 6.898132-5.487422 6.945953-5.678705L7.591532-8.308842Z"></path> | |
<path id="g1-86" d="M7.400249-6.838356C7.806725-7.483935 8.177335-7.770859 8.787049-7.81868C8.9066-7.830635 9.002242-7.830635 9.002242-8.045828C9.002242-8.093649 8.978331-8.16538 8.870735-8.16538C8.655542-8.16538 8.141469-8.141469 7.926276-8.141469C7.579577-8.141469 7.220922-8.16538 6.886177-8.16538C6.790535-8.16538 6.670984-8.16538 6.670984-7.938232C6.670984-7.830635 6.77858-7.81868 6.826401-7.81868C7.268742-7.782814 7.316563-7.567621 7.316563-7.424159C7.316563-7.244832 7.149191-6.969863 7.137235-6.957908L3.383313-1.004234L2.546451-7.44807C2.546451-7.79477 3.16812-7.81868 3.299626-7.81868C3.478954-7.81868 3.58655-7.81868 3.58655-8.045828C3.58655-8.16538 3.455044-8.16538 3.419178-8.16538C3.21594-8.16538 2.976837-8.141469 2.773599-8.141469H2.10411C1.231382-8.141469 .872727-8.16538 .860772-8.16538C.789041-8.16538 .645579-8.16538 .645579-7.950187C.645579-7.81868 .729265-7.81868 .920548-7.81868C1.530262-7.81868 1.566127-7.711083 1.601993-7.412204L2.558406-.035866C2.594271 .215193 2.594271 .251059 2.761644 .251059C2.905106 .251059 2.964882 .215193 3.084433 .02391L7.400249-6.838356Z"></path> | |
<path id="g1-90" d="M8.368618-7.79477C8.440349-7.878456 8.500125-7.950187 8.500125-8.069738C8.500125-8.153425 8.488169-8.16538 8.2132-8.16538H3.275716C3.000747-8.16538 2.988792-8.153425 2.917061-7.938232L2.259527-5.786301C2.223661-5.66675 2.223661-5.642839 2.223661-5.618929C2.223661-5.571108 2.259527-5.499377 2.343213-5.499377C2.438854-5.499377 2.462765-5.547198 2.510585-5.702615C2.952927-6.993773 3.53873-7.81868 5.427646-7.81868H7.388294L.836862-.406476C.729265-.274969 .681445-.227148 .681445-.095641C.681445 0 .74122 0 .968369 0H6.073225C6.348194 0 6.360149-.011955 6.43188-.227148L7.268742-2.86924C7.280697-2.905106 7.304608-2.988792 7.304608-3.036613C7.304608-3.096389 7.256787-3.156164 7.185056-3.156164C7.089415-3.156164 7.07746-3.144209 6.981818-2.84533C6.479701-1.303113 5.953674-.37061 3.873474-.37061H1.80523L8.368618-7.79477Z"></path> | |
<path id="g1-109" d="M2.462765-3.502864C2.486675-3.574595 2.785554-4.172354 3.227895-4.554919C3.53873-4.841843 3.945205-5.033126 4.411457-5.033126C4.889664-5.033126 5.057036-4.674471 5.057036-4.196264C5.057036-4.124533 5.057036-3.88543 4.913574-3.323537L4.614695-2.092154C4.519054-1.733499 4.291905-.848817 4.267995-.71731C4.220174-.537983 4.148443-.227148 4.148443-.179328C4.148443-.011955 4.27995 .119552 4.459278 .119552C4.817933 .119552 4.877709-.155417 4.985305-.585803L5.702615-3.443088C5.726526-3.53873 6.348194-5.033126 7.663263-5.033126C8.141469-5.033126 8.308842-4.674471 8.308842-4.196264C8.308842-3.526775 7.84259-2.223661 7.579577-1.506351C7.47198-1.219427 7.412204-1.06401 7.412204-.848817C7.412204-.310834 7.782814 .119552 8.356663 .119552C9.468493 .119552 9.886924-1.637858 9.886924-1.709589C9.886924-1.769365 9.839103-1.817186 9.767372-1.817186C9.659776-1.817186 9.647821-1.78132 9.588045-1.578082C9.313076-.621669 8.870735-.119552 8.392528-.119552C8.272976-.119552 8.081694-.131507 8.081694-.514072C8.081694-.824907 8.225156-1.207472 8.272976-1.338979C8.488169-1.912827 9.026152-3.323537 9.026152-4.016936C9.026152-4.734247 8.607721-5.272229 7.699128-5.272229C6.898132-5.272229 6.252553-4.817933 5.774346-4.112578C5.738481-4.758157 5.34396-5.272229 4.447323-5.272229C3.383313-5.272229 2.82142-4.519054 2.606227-4.220174C2.570361-4.901619 2.080199-5.272229 1.554172-5.272229C1.207472-5.272229 .932503-5.104857 .705355-4.65056C.490162-4.220174 .32279-3.490909 .32279-3.443088S.37061-3.335492 .454296-3.335492C.549938-3.335492 .561893-3.347447 .633624-3.622416C.812951-4.327771 1.0401-5.033126 1.518306-5.033126C1.793275-5.033126 1.888917-4.841843 1.888917-4.483188C1.888917-4.220174 1.769365-3.753923 1.685679-3.383313L1.350934-2.092154C1.303113-1.865006 1.171606-1.327024 1.111831-1.111831C1.028144-.800996 .896638-.239103 .896638-.179328C.896638-.011955 1.028144 .119552 1.207472 .119552C1.350934 .119552 1.518306 .047821 1.613948-.131507C1.637858-.191283 1.745455-.609714 1.80523-.848817L2.068244-1.924782L2.462765-3.502864Z"></path> | |
</defs> | |
<g id="page1" transform="matrix(1.13 0 0 1.13 -140.009481 -80.795)"> | |
<use x="122.877406" y="80.199253" xlink:href="#g1-82"></use> | |
<use x="135.20675" y="80.199253" xlink:href="#g2-61"></use> | |
<use x="147.632231" y="80.199253" xlink:href="#g2-40"></use> | |
<use x="152.184557" y="80.199253" xlink:href="#g2-40"></use> | |
<use x="156.736883" y="80.199253" xlink:href="#g1-86"></use> | |
<use x="168.819225" y="80.199253" xlink:href="#g0-0"></use> | |
<use x="180.774386" y="80.199253" xlink:href="#g1-90"></use> | |
<use x="189.645207" y="80.199253" xlink:href="#g2-41"></use> | |
<use x="196.190008" y="80.199253" xlink:href="#g1-61"></use> | |
<use x="204.035496" y="80.199253" xlink:href="#g2-40"></use> | |
<use x="208.587821" y="80.199253" xlink:href="#g1-83"></use> | |
<use x="219.139808" y="80.199253" xlink:href="#g0-0"></use> | |
<use x="231.094968" y="80.199253" xlink:href="#g1-90"></use> | |
<use x="239.96579" y="80.199253" xlink:href="#g2-41"></use> | |
<use x="244.5181" y="80.199253" xlink:href="#g2-41"></use> | |
<use x="251.72709" y="80.199253" xlink:href="#g0-3"></use> | |
<use x="260.36136" y="80.199253" xlink:href="#g2-49"></use> | |
<use x="266.21435" y="80.199253" xlink:href="#g2-54"></use> | |
<use x="272.067341" y="80.199253" xlink:href="#g2-48"></use> | |
<use x="277.920331" y="80.199253" xlink:href="#g1-109"></use> | |
<use x="288.159598" y="80.199253" xlink:href="#g1-86"></use> | |
<use x="300.24194" y="80.199253" xlink:href="#g2-43"></use> | |
<use x="312.003255" y="80.199253" xlink:href="#g2-52"></use> | |
<use x="317.856245" y="80.199253" xlink:href="#g2-48"></use> | |
<use x="323.709236" y="80.199253" xlink:href="#g1-109"></use> | |
<use x="333.948503" y="80.199253" xlink:href="#g1-86"></use> | |
</g> | |
</svg> | |
<br> | |
<br> | |
Where:<br> | |
<b>V</b> = Value in Unit of Measure<br> | |
<b>R</b> = Test points in mV (40mV = 4 mA)<br> | |
<b>S</b> = Span in Unit of Measure<br> | |
<b>Z</b> = Zero in Unit of Measure<br> | |
<div style="text-align: center; margin-top: 50px; "> | |
<input type="button" class="close-btn" value="Close" onclick="closeHelp()" style="width:30%;"> | |
</div> | |
</div> | |
</div> | |
</div> | |
<!-- Preset Overlay --> | |
<div class="preset-overlay" id="presetOverlay"> | |
<div class="preset-modal"> | |
<div class="preset-header"> | |
<h3>CTi Sensors</h3> | |
</div> | |
<div class="preset-list" id="presetList"> | |
</div> | |
<div class="preset-footer"> | |
<button class="close-btn" onclick="closePresets()">Close</button> | |
</div> | |
</div> | |
</div> | |
<!-- Main Device --> | |
<div class="fluke-body"> | |
<!-- LCD Display --> | |
<div class="lcd-bezel"> | |
<div class="lcd-screen"> | |
<div class="lcd-content" id="lcdContent"> | |
</div> | |
<div class="lcd-reflection"></div> | |
</div> | |
</div> | |
<!-- Function Buttons --> | |
<div class="button-row"> | |
<button class="btn power" id="powerBtn" onclick="clearAll()" style="padding-top:4px"> | |
<span><svg xmlns="http://www.w3.org/2000/svg" x="0px" y="0px" width="30" height="30" viewBox="0,0,256,256"> | |
<g fill="#ffffff" fill-rule="nonzero" stroke="none" stroke-width="1" stroke-linecap="butt" stroke-linejoin="miter" stroke-miterlimit="10" stroke-dasharray="" stroke-dashoffset="0" font-family="none" font-weight="none" font-size="none" text-anchor="none" style="mix-blend-mode: normal"><g transform="scale(8.53333,8.53333)"><path d="M27,6h-18.448c-0.989,0 -1.913,0.486 -2.472,1.301l-4.904,7.133c-0.234,0.341 -0.234,0.792 0,1.133l4.904,7.133c0.559,0.814 1.483,1.3 2.472,1.3h18.448c1.103,0 2,-0.897 2,-2v-14c0,-1.103 -0.897,-2 -2,-2zM21.707,18.293c0.391,0.391 0.391,1.023 0,1.414c-0.195,0.195 -0.451,0.293 -0.707,0.293c-0.256,0 -0.512,-0.098 -0.707,-0.293l-3.293,-3.293l-3.293,3.293c-0.195,0.195 -0.451,0.293 -0.707,0.293c-0.256,0 -0.512,-0.098 -0.707,-0.293c-0.391,-0.391 -0.391,-1.023 0,-1.414l3.293,-3.293l-3.293,-3.293c-0.391,-0.391 -0.391,-1.023 0,-1.414c0.391,-0.391 1.023,-0.391 1.414,0l3.293,3.293l3.293,-3.293c0.391,-0.391 1.023,-0.391 1.414,0c0.391,0.391 0.391,1.023 0,1.414l-3.293,3.293z"></path></g></g> | |
</svg></span> | |
</button> | |
<button class="btn preset-btn" onclick="showHelp()"> | |
<svg xmlns="http://www.w3.org/2000/svg" x="0px" y="0px" width="24" height="24" viewBox="0,0,256,256"> | |
<g fill="#ffffff" fill-rule="nonzero" stroke="none" stroke-width="1" stroke-linecap="butt" stroke-linejoin="miter" stroke-miterlimit="10" stroke-dasharray="" stroke-dashoffset="0" font-family="none" font-weight="none" font-size="none" text-anchor="none" style="mix-blend-mode: normal"><g transform="scale(10.66667,10.66667)"><path d="M12,2c-5.52,0 -10,4.48 -10,10c0,5.52 4.48,10 10,10c5.52,0 10,-4.48 10,-10c0,-5.52 -4.48,-10 -10,-10zM13,19h-2v-2h2zM15.07,11.25l-0.9,0.92c-0.72,0.73 -1.17,1.33 -1.17,2.83h-2v-0.5c0,-1.1 0.45,-2.1 1.17,-2.83l1.24,-1.26c0.37,-0.36 0.59,-0.86 0.59,-1.41c0,-1.1 -0.9,-2 -2,-2c-1.1,0 -2,0.9 -2,2h-2c0,-2.21 1.79,-4 4,-4c2.21,0 4,1.79 4,4c0,0.88 -0.36,1.68 -0.93,2.25z"></path></g></g> | |
</svg> | |
</button> | |
<button class="btn test" onclick="showPresets()" style="padding-top:1px"> | |
PRESET | |
<span>▼</span> | |
</button> | |
</div> | |
</div> | |
<!-- Lower Case --> | |
<div class="lower-case"> | |
<!-- Process Value Input --> | |
<div class="input-group"> | |
<label class="input-label"> | |
VALUE IN UOM | |
</label> | |
<div class="input-wrapper"> | |
<button class="stepper-btn" | |
onmousedown="startHold('valueInput', -1)" | |
onmouseup="stopHold()" | |
onmouseleave="stopHold()" | |
ontouchstart="startHold('valueInput', -1)" | |
ontouchend="stopHold()"><</button> | |
<input type="number" class="input-field" id="valueInput" placeholder="Value" oninput="calculateFromValue()"> | |
<button class="stepper-btn" | |
onmousedown="startHold('valueInput', 1)" | |
onmouseup="stopHold()" | |
onmouseleave="stopHold()" | |
ontouchstart="startHold('valueInput', 1)" | |
ontouchend="stopHold()">></button> | |
</div> | |
</div> | |
<!-- Milliamp Input --> | |
<div class="input-group"> | |
<label class="input-label"> | |
TEST POINTS mV | |
</label> | |
<div class="input-wrapper"> | |
<button class="stepper-btn" | |
onmousedown="startHold('mvInput', -1)" | |
onmouseup="stopHold()" | |
onmouseleave="stopHold()" | |
ontouchstart="startHold('mvInput', -1)" | |
ontouchend="stopHold()"><</button> | |
<input type="number" class="input-field" id="mvInput" placeholder="mV" oninput="calculateFromMv()"> | |
<button class="stepper-btn" | |
onmousedown="startHold('mvInput', 1)" | |
onmouseup="stopHold()" | |
onmouseleave="stopHold()" | |
ontouchstart="startHold('mvInput', 1)" | |
ontouchend="stopHold()">></button> | |
</div> | |
</div> | |
<!-- Zero and Span --> | |
<div class="input-group"> | |
<div class="input-row"> | |
<div> | |
<label class="input-label secondary">ZERO</label> | |
<div class="input-wrapper small"> | |
<button class="stepper-btn small" | |
onmousedown="startHold('zeroInput', -1)" | |
onmouseup="stopHold()" | |
onmouseleave="stopHold()" | |
ontouchstart="startHold('zeroInput', -1)" | |
ontouchend="stopHold()"><</button> | |
<input type="number" class="input-field small" id="zeroInput" value="0" oninput="calculateFromValue()"> | |
<button class="stepper-btn small" | |
onmousedown="startHold('zeroInput', 1)" | |
onmouseup="stopHold()" | |
onmouseleave="stopHold()" | |
ontouchstart="startHold('zeroInput', 1)" | |
ontouchend="stopHold()">></button> | |
</div> | |
</div> | |
<div> | |
<label class="input-label secondary">SPAN</label> | |
<div class="input-wrapper small"> | |
<button class="stepper-btn small" | |
onmousedown="startHold('spanInput', -1)" | |
onmouseup="stopHold()" | |
onmouseleave="stopHold()" | |
ontouchstart="startHold('spanInput', -1)" | |
ontouchend="stopHold()"><</button> | |
<input type="number" class="input-field small" id="spanInput" value="100" oninput="calculateFromValue()"> | |
<button class="stepper-btn small" | |
onmousedown="startHold('spanInput', 1)" | |
onmouseup="stopHold()" | |
onmouseleave="stopHold()" | |
ontouchstart="startHold('spanInput', 1)" | |
ontouchend="stopHold()">></button> | |
</div> | |
</div> | |
</div> | |
</div> | |
<!-- Test Resistance --> | |
<div class="input-group hidden"> | |
<label class="input-label tertiary">Test R (mV) • 40mV = 4mA</label> | |
<input type="number" class="input-field small tertiary" id="resistanceInput" value="1"> | |
</div> | |
<!-- Info Panel --> | |
<div class="info-panel"> | |
<div class="info-text"></div> | |
</div> | |
</div> | |
</div> | |
<script> | |
// State | |
let isOn = true; | |
let result = null; | |
let currentUom = '%'; | |
let currentSensor = ''; | |
let currentGasShort = ''; | |
let lastInput = 'value'; | |
// Presets data | |
const presets = [ | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 50, | |
"uom": "PPM", | |
"sensor": "GG-NH3-50" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 100, | |
"uom": "PPM", | |
"sensor": "GG-NH3-100" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 150, | |
"uom": "PPM", | |
"sensor": "GG-NH3-150" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 200, | |
"uom": "PPM", | |
"sensor": "GG-NH3-200" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 250, | |
"uom": "PPM", | |
"sensor": "GG-NH3-250" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 300, | |
"uom": "PPM", | |
"sensor": "GG-NH3-300" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-NH3-500" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-NH3-1000" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 10000, | |
"uom": "PPM", | |
"sensor": "GG-NH3-1%" | |
}, | |
{ | |
"gas_name": "Ammonia", | |
"gas_short": "NH3", | |
"zero": 0, | |
"span": 20000, | |
"uom": "PPM", | |
"sensor": "GG-NH3-2%" | |
}, | |
{ | |
"gas_name": "Carbon Dioxide", | |
"gas_short": "CO2", | |
"zero": 0, | |
"span": 10000, | |
"uom": "%", | |
"sensor": "GG-CO2-1%" | |
}, | |
{ | |
"gas_name": "Carbon Dioxide", | |
"gas_short": "CO2", | |
"zero": 0, | |
"span": 30000, | |
"uom": "%", | |
"sensor": "GG-CO2-3%" | |
}, | |
{ | |
"gas_name": "Carbon Dioxide", | |
"gas_short": "CO2", | |
"zero": 0, | |
"span": 50000, | |
"uom": "%", | |
"sensor": "GG-CO2-5%" | |
}, | |
{ | |
"gas_name": "Carbon Dioxide", | |
"gas_short": "CO2", | |
"zero": 0, | |
"span": 20000, | |
"uom": "%", | |
"sensor": "GG-CO2-20%" | |
}, | |
{ | |
"gas_name": "Carbon Dioxide", | |
"gas_short": "CO2", | |
"zero": 0, | |
"span": 100000, | |
"uom": "%", | |
"sensor": "GG-CO2-100%" | |
}, | |
{ | |
"gas_name": "Carbon Monoxide", | |
"gas_short": "CO", | |
"zero": 0, | |
"span": 200, | |
"uom": "PPM", | |
"sensor": "GG-CO-200" | |
}, | |
{ | |
"gas_name": "Chlorine", | |
"gas_short": "CL2", | |
"zero": 0, | |
"span": 5, | |
"uom": "PPM", | |
"sensor": "GG-CL2-B-5" | |
}, | |
{ | |
"gas_name": "Hydrogen", | |
"gas_short": "H2", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-H2-EC-1000" | |
}, | |
{ | |
"gas_name": "Hydrogen", | |
"gas_short": "H2", | |
"zero": 0, | |
"span": 2000, | |
"uom": "PPM", | |
"sensor": "GG-H2-EC-2000" | |
}, | |
{ | |
"gas_name": "Hydrogen", | |
"gas_short": "H2", | |
"zero": 0, | |
"span": 10000, | |
"uom": "PPM", | |
"sensor": "GG-H2-EC-10000" | |
}, | |
{ | |
"gas_name": "Hydrogen Sulfide", | |
"gas_short": "H2S", | |
"zero": 0, | |
"span": 50, | |
"uom": "PPM", | |
"sensor": "GG-H2S-50" | |
}, | |
{ | |
"gas_name": "Hydrogen Sulfide", | |
"gas_short": "H2S", | |
"zero": 0, | |
"span": 200, | |
"uom": "PPM", | |
"sensor": "GG-H2S-200" | |
}, | |
{ | |
"gas_name": "Nitrogen Dioxide", | |
"gas_short": "NO2", | |
"zero": 0, | |
"span": 10, | |
"uom": "PPM", | |
"sensor": "GG-NO2-B-10" | |
}, | |
{ | |
"gas_name": "Oxygen", | |
"gas_short": "O2", | |
"zero": 0, | |
"span": 25, | |
"uom": "%", | |
"sensor": "GG-O2-C0" | |
}, | |
{ | |
"gas_name": "Oxygen", | |
"gas_short": "O2", | |
"zero": 15, | |
"span": 25, | |
"uom": "%", | |
"sensor": "GG-O2-C15" | |
}, | |
{ | |
"gas_name": "Ozone", | |
"gas_short": "O3", | |
"zero": 0, | |
"span": 1, | |
"uom": "PPM", | |
"sensor": "GG-O3-A-1" | |
}, | |
{ | |
"gas_name": "R11", | |
"gas_short": "R11", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R11-1000" | |
}, | |
{ | |
"gas_name": "R123", | |
"gas_short": "R123", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R123-500" | |
}, | |
{ | |
"gas_name": "R123", | |
"gas_short": "R123", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R123-1000" | |
}, | |
{ | |
"gas_name": "R123A", | |
"gas_short": "R123A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R123A-500" | |
}, | |
{ | |
"gas_name": "R123A", | |
"gas_short": "R123A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R123A-1000" | |
}, | |
{ | |
"gas_name": "R134A", | |
"gas_short": "R134A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R134A-500" | |
}, | |
{ | |
"gas_name": "R134A", | |
"gas_short": "R134A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R134A-1000" | |
}, | |
{ | |
"gas_name": "R22", | |
"gas_short": "R22", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R22-500" | |
}, | |
{ | |
"gas_name": "R22", | |
"gas_short": "R22", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R22-1000" | |
}, | |
{ | |
"gas_name": "R404A", | |
"gas_short": "R404A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R404A-500" | |
}, | |
{ | |
"gas_name": "R404A", | |
"gas_short": "R404A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R404A-1000" | |
}, | |
{ | |
"gas_name": "R407A", | |
"gas_short": "R407A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R407A-500" | |
}, | |
{ | |
"gas_name": "R407A", | |
"gas_short": "R407A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R407A-1000" | |
}, | |
{ | |
"gas_name": "R407C", | |
"gas_short": "R407C", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R407C-500" | |
}, | |
{ | |
"gas_name": "R407F", | |
"gas_short": "R407F", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R407F-500" | |
}, | |
{ | |
"gas_name": "R407F", | |
"gas_short": "R407F", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R407F-1000" | |
}, | |
{ | |
"gas_name": "R410A", | |
"gas_short": "R410A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R410A-500" | |
}, | |
{ | |
"gas_name": "R410A", | |
"gas_short": "R410A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R410A-1000" | |
}, | |
{ | |
"gas_name": "R422A", | |
"gas_short": "R422A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R422A-500" | |
}, | |
{ | |
"gas_name": "R422D", | |
"gas_short": "R422D", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R422D-500" | |
}, | |
{ | |
"gas_name": "R434A", | |
"gas_short": "R434A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R434A-500" | |
}, | |
{ | |
"gas_name": "R438A", | |
"gas_short": "R438A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R438A-500" | |
}, | |
{ | |
"gas_name": "R448A", | |
"gas_short": "R448A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R448A-500" | |
}, | |
{ | |
"gas_name": "R448A", | |
"gas_short": "R448A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R448A-1000" | |
}, | |
{ | |
"gas_name": "R449A", | |
"gas_short": "R449A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R449A-500" | |
}, | |
{ | |
"gas_name": "R449A", | |
"gas_short": "R449A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R449A-1000" | |
}, | |
{ | |
"gas_name": "R507A", | |
"gas_short": "R507A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R507A-500" | |
}, | |
{ | |
"gas_name": "R507A", | |
"gas_short": "R507A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R507A-1000" | |
}, | |
{ | |
"gas_name": "R513A", | |
"gas_short": "R513A", | |
"zero": 0, | |
"span": 500, | |
"uom": "PPM", | |
"sensor": "GG-R513A-500" | |
}, | |
{ | |
"gas_name": "R514A", | |
"gas_short": "R514A", | |
"zero": 0, | |
"span": 1000, | |
"uom": "PPM", | |
"sensor": "GG-R514A-500" | |
}, | |
{ | |
"gas_name": "Sulfur Dioxide", | |
"gas_short": "SO2", | |
"zero": 0, | |
"span": 20, | |
"uom": "PPM", | |
"sensor": "GG-SO2-20" | |
}, | |
{ | |
"gas_name": "Temperature", | |
"gas_short": "TEMP", | |
"zero": -60, | |
"span": 160, | |
"uom": "F", | |
"sensor": "Temp Sensor TS2" | |
} | |
]; | |
// Initialize | |
document.addEventListener('DOMContentLoaded', function() { | |
populatePresets(); | |
updateDisplay(); | |
calculateFromValue(); | |
}); | |
// Calculate 4-20mA conversion from Process Value | |
function calculateFromValue() { | |
if (!isOn) { | |
result = null; | |
updateDisplay(); | |
return; | |
} | |
lastInput = 'value'; | |
const zero = parseFloat(document.getElementById('zeroInput').value) || 0; | |
const upperValue = parseFloat(document.getElementById('spanInput').value) || 100; | |
const value = parseFloat(document.getElementById('valueInput').value); | |
const span = upperValue - zero; | |
if (!isNaN(value) && span !== 0) { | |
const percentage = (value - zero) / span; | |
const milliamps = 4 + percentage * 16; | |
const millivolts = 40 + percentage * 160; | |
result = milliamps; | |
document.getElementById('mvInput').value = millivolts.toFixed(1); | |
} else { | |
result = null; | |
document.getElementById('mvInput').value = ''; | |
} | |
updateDisplay(); | |
} | |
// Calculate Process Value from 4-20mA | |
function calculateFromMv() { | |
if (!isOn) { | |
result = null; | |
updateDisplay(); | |
return; | |
} | |
lastInput = 'mv'; | |
const zero = parseFloat(document.getElementById('zeroInput').value) || 0; | |
const upperValue = parseFloat(document.getElementById('spanInput').value) || 100; | |
const millivolts = parseFloat(document.getElementById('mvInput').value); | |
const span = upperValue - zero; | |
if (!isNaN(millivolts) && span !== 0) { | |
const percentage = (millivolts - 40) / 160; | |
const value = (percentage * span) + zero; | |
result = 4 + (percentage * 16); | |
document.getElementById('valueInput').value = value.toFixed(1); | |
} else { | |
document.getElementById('valueInput').value = ''; | |
result = null; | |
} | |
updateDisplay(); | |
} | |
// Update LCD display | |
function updateDisplay() { | |
const lcdContent = document.getElementById('lcdContent'); | |
const zero = parseFloat(document.getElementById('zeroInput').value) || 0; | |
const upperValue = parseFloat(document.getElementById('spanInput').value) || 100; | |
const value = parseFloat(document.getElementById('valueInput').value); | |
if (isOn) { | |
const percentage = result ? (((result - 4) / 16) * 100).toFixed(1) : "0.0"; | |
const progressWidth = result ? Math.max(0, Math.min(100, ((result - 4) / 16) * 100)) : 0; | |
let rangeDisplay = ''; | |
if (zero !== "0" || upperValue !== 100) { | |
rangeDisplay = `<div class="range-display" style="display: block;">Range: ${zero} to ${upperValue} ${currentUom}</div>`; | |
} | |
lcdContent.innerHTML = ` | |
<div class="header-bar"> | |
<span>${currentSensor || ''}</span> | |
<span>${currentGasShort || ''}</span> | |
</div> | |
<div class="main-reading"> | |
<div class="reading-value"> | |
${!isNaN(value) ? value.toFixed(1) : "0.0"} | |
</div> | |
<div class="percentage">${currentUom}</div> | |
</div> | |
<div class="scale-container"> | |
<div class="scale-labels"> | |
<span>4</span> | |
<span>8</span> | |
<span>12</span> | |
<span>16</span> | |
<span>20</span> | |
</div> | |
<div class="progress-bar"> | |
<div class="progress-fill" style="width: ${progressWidth}%"></div> | |
</div> | |
</div> | |
${rangeDisplay} | |
`; | |
} else { | |
lcdContent.innerHTML = ` | |
<div class="power-off"> | |
<div> | |
<div class="power-off-text">---</div> | |
<div class="power-off-label">Power Off</div> | |
</div> | |
</div> | |
`; | |
} | |
const infoText = document.querySelector('.info-text'); | |
let formula = ''; | |
if (lastInput === 'value') { | |
const v = parseFloat(document.getElementById('valueInput').value) || 0; | |
const z = parseFloat(document.getElementById('zeroInput').value) || 0; | |
const s_upper = parseFloat(document.getElementById('spanInput').value) || 100; | |
formula = `R = ((${v.toFixed(1)} - ${z.toFixed(1)}) / (${s_upper.toFixed(1)} - ${z.toFixed(1)})) * 160 + 40`; | |
} else { // lastInput === 'mv' | |
const r = parseFloat(document.getElementById('mvInput').value) || 0; | |
const z = parseFloat(document.getElementById('zeroInput').value) || 0; | |
const s_upper = parseFloat(document.getElementById('spanInput').value) || 100; | |
formula = `V = ((${r.toFixed(1)} - 40) / 160) * (${s_upper.toFixed(1)} - ${z.toFixed(1)}) + ${z.toFixed(1)}`; | |
} | |
infoText.textContent = formula; | |
} | |
// Clear all values | |
function clearAll() { | |
document.getElementById('valueInput').value = ''; | |
document.getElementById('mvInput').value = ''; | |
lastInput = 'value'; | |
result = null; | |
updateDisplay(); | |
} | |
// Set preset | |
function setPreset(zero, span, uom, sensor, gas_short) { | |
document.getElementById('zeroInput').value = zero; | |
document.getElementById('spanInput').value = span; | |
currentUom = uom || '%'; | |
currentSensor = sensor || ''; | |
currentGasShort = gas_short || ''; | |
calculateFromValue(); | |
} | |
// Show presets | |
function showPresets() { | |
document.getElementById('presetOverlay').style.display = 'flex'; | |
} | |
// Close presets | |
function closePresets() { | |
document.getElementById('presetOverlay').style.display = 'none'; | |
} | |
// Populate presets list | |
function populatePresets() { | |
const presetList = document.getElementById('presetList'); | |
// Group presets by gas_name | |
const groupedPresets = presets.reduce((groups, preset) => { | |
const gasName = preset.gas_name; | |
if (!groups[gasName]) { | |
groups[gasName] = []; | |
} | |
groups[gasName].push(preset); | |
return groups; | |
}, {}); | |
// Sort gas names and generate HTML | |
const sortedGasNames = Object.keys(groupedPresets).sort(); | |
presetList.innerHTML = sortedGasNames.map(gasName => { | |
const gasPresets = groupedPresets[gasName]; | |
const presetItems = gasPresets.map(preset => { | |
const upper_range = preset.zero + preset.span; | |
return ` | |
<button class="preset-item" onclick="applyPreset('${preset.zero}', '${preset.span}', '${preset.uom}', '${preset.sensor}', '${preset.gas_short}')"> | |
<div class="preset-row"> | |
<div class="preset-sensor">${preset.sensor}</div> | |
<div class="preset-details"> | |
<div class="preset-range">${preset.zero}-${upper_range}${(preset.uom === '%' || preset.uom === 'F') ? '' : ' '}</div> | |
<div class="preset-uom">${preset.uom === 'F' ? '°F' : preset.uom}</div> | |
</div> | |
</div> | |
</button> | |
`; | |
}).join(''); | |
return ` | |
<div class="gas-group"> | |
<div class="gas-group-header">${gasName}</div> | |
${presetItems} | |
</div> | |
`; | |
}).join(''); | |
} | |
// Apply preset | |
function applyPreset(zero, span, uom, sensor, gas_short) { | |
setPreset(zero, span, uom, sensor, gas_short); | |
closePresets(); | |
} | |
// Close preset overlay when clicking outside | |
document.getElementById('presetOverlay').addEventListener('click', function(e) { | |
if (e.target === this) { | |
closePresets(); | |
} | |
}); | |
// Show help modal | |
function showHelp() { | |
document.getElementById('help-modal').classList.add('show'); | |
} | |
// Close help modal | |
function closeHelp() { | |
document.getElementById('help-modal').classList.remove('show'); | |
} | |
// Register service worker for PWA | |
if ('serviceWorker' in navigator) { | |
window.addEventListener('load', function() { | |
navigator.serviceWorker.register('./sw.js'); | |
}); | |
} | |
// Hold-to-increment functionality variables | |
let holdInterval = null; | |
let holdTimeout = null; | |
let currentInputId = null; | |
let currentDirection = null; | |
// Step value function for stepper buttons | |
function stepValue(inputId, direction, stepMultiplier = 1) { | |
const input = document.getElementById(inputId); | |
const currentValue = parseFloat(input.value) || 0; | |
// Determine step size based on input type | |
let stepSize = 1; | |
if (inputId === 'mvInput') { | |
stepSize = 0.1; // Smaller steps for millivolts | |
} else if (inputId === 'valueInput') { | |
const zero = parseFloat(document.getElementById('zeroInput').value) || 0; | |
const span = parseFloat(document.getElementById('spanInput').value) || 100; | |
const range = Math.abs(span - zero); | |
stepSize = range > 100 ? 10 : (range > 10 ? 1 : 0.1); // Adaptive step size | |
} | |
// Apply step multiplier for fast increments | |
stepSize *= stepMultiplier; | |
const newValue = currentValue + (direction * stepSize); | |
input.value = newValue.toFixed(stepSize < 1 ? 1 : 0); | |
// Trigger the appropriate calculation | |
if (inputId === 'valueInput' || inputId === 'zeroInput' || inputId === 'spanInput') { | |
calculateFromValue(); | |
} else if (inputId === 'mvInput') { | |
calculateFromMv(); | |
} | |
} | |
// Start hold-to-increment functionality | |
function startHold(inputId, direction) { | |
currentInputId = inputId; | |
currentDirection = direction; | |
// Initial step | |
stepValue(inputId, direction); | |
// Start slow increment after 500ms delay | |
holdTimeout = setTimeout(() => { | |
holdInterval = setInterval(() => { | |
stepValue(currentInputId, currentDirection); | |
}, 200); // Start with 200ms intervals (slow) | |
// Speed up after 2 seconds with 10x step size | |
setTimeout(() => { | |
if (holdInterval) { | |
clearInterval(holdInterval); | |
holdInterval = setInterval(() => { | |
stepValue(currentInputId, currentDirection, 10); // 10x step multiplier | |
}, 100); // Faster increment with larger steps | |
} | |
}, 2000); | |
}, 500); | |
} | |
// Stop hold-to-increment functionality | |
function stopHold() { | |
if (holdTimeout) { | |
clearTimeout(holdTimeout); | |
holdTimeout = null; | |
} | |
if (holdInterval) { | |
clearInterval(holdInterval); | |
holdInterval = null; | |
} | |
currentInputId = null; | |
currentDirection = null; | |
} | |
</script> | |
</body> | |
</html> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment