49,013 properties
0 phones
0 emails
0 for sale
23 results · Page 1/1
All (49,013) Self-Storage (6,315) Mobile Home Parks (7,982) Car Washes (7,857) Laundromats (5,362) RV Parks (8,082) Marinas (3,500) Budget Motels (9,891) Mailbox / Pack & Ship (24)
Map:

Swan Cleaners & Laundromat

2

ID · 520 Madison Avenue

Laundromats
Phone

Rave Laundry

2

Boise, ID · 2602 West Canal Street

Laundromats
Phone Email

Coeur d'Alene Laundry & Drycleaning

2

Coeur d'Alene, ID · 179 West Haycraft Avenue

Laundromats
Phone

Tub Laundry

2

ID · Parkway Drive

Laundromats
Phone

Wash N Go

2

ID

Laundromats
Phone

Tumbled Laundromat

2

Malad City, ID · 94 Bannock Street

Laundromats
Phone

The Laundry Bag

2

Middleton, ID · 206 South Dewey Avenue

Laundromats
Phone

Breeze

3

Boise, ID · 4026 West State Street

Laundromats
Email

Coin Laundry

3

Garden City, ID · 5173 North Glenwood Street

Laundromats
Phone

Jiffy Clean Coin Laundry

3

Boise, ID · 1736 South Broadway Avenue

Laundromats
Phone

Downtown Laundry

3

Kuna, ID · 298 North Avenue C

Laundromats
Phone Email

The Laundromat

3

Kuna, ID · 381 North Avenue E

Laundromats
Phone

Breeze, Better Laundry

3

Nampa, ID · 1317 12th Avenue Road

Laundromats
Phone

Breeze Better Laundry

3

ID

Laundromats
Email

Magic Suds Laundromat

3

Rexburg, ID · 42 North 2nd East

Laundromats
Phone

Thompsons

3

Boise, ID · 1707 South Broadway Avenue

Laundromats
Phone

Melba Laundromat

3

Melba, ID · 115 4th Street

Laundromats

12th Street Laundry

3

Boise, ID · 917 North 12th Street

Laundromats
Phone

Lemon Laundry

3

ID

Laundromats
Phone

ABC Laundry

3

Boise, ID · 4008 West Overland Road

Laundromats
Phone

Rave Laundry

3

Meridian, ID · 132 East Fairview Avenue

Laundromats
Phone

Priest Rivers Cleaners

3

Priest River, ID · 415 9th Street

Laundromats
Phone

Desert Edge Laundromat

3

Grand View, ID · 530 Riverside Avenue

Laundromats
// Heat map modes // mapPoints format: [id, lat, lon, category, valuation, data_score, motivated_score] let heatLayer = null; let circleLayer = null; let currentMode = 'markers'; function clearOverlays() { if (heatLayer) { map.removeLayer(heatLayer); heatLayer = null; } if (circleLayer) { map.removeLayer(circleLayer); circleLayer = null; } } function setMapMode(mode) { currentMode = mode; clearOverlays(); // Update button states document.querySelectorAll('.map-mode-btn').forEach(b => b.classList.remove('active')); document.getElementById('btn-' + mode).classList.add('active'); if (mode === 'markers') { markers.addTo(map); return; } map.removeLayer(markers); if (mode === 'density') { // Pure density heatmap const pts = mapPoints.filter(p => p[1] && p[2]).map(p => [p[1], p[2], 1]); heatLayer = L.heatLayer(pts, {radius: 20, blur: 15, maxZoom: 10, max: 5, gradient: {0.2: '#ffffb2', 0.4: '#fd8d3c', 0.6: '#f03b20', 0.8: '#bd0026', 1: '#800026'} }).addTo(map); } else if (mode === 'valuation') { // Circle markers colored by valuation circleLayer = L.layerGroup(); const maxVal = Math.max(...mapPoints.map(p => p[4]).filter(v => v > 0)) || 1; mapPoints.filter(p => p[1] && p[2] && p[4] > 0).forEach(p => { const ratio = Math.min(p[4] / maxVal, 1); const r = Math.round(ratio * 255); const g = Math.round((1 - ratio) * 200); const color = `rgb(${r}, ${g}, 50)`; const radius = 4 + ratio * 10; L.circleMarker([p[1], p[2]], { radius: radius, fillColor: color, color: '#fff', weight: 1, fillOpacity: 0.7 }).bindPopup(`$${(p[4]/1000).toFixed(0)}K`).addTo(circleLayer); }); circleLayer.addTo(map); } else if (mode === 'quality') { // Circle markers colored by data_score circleLayer = L.layerGroup(); mapPoints.filter(p => p[1] && p[2]).forEach(p => { const score = p[5] || 0; const ratio = score / 10; // Green = high, Red = low const r = Math.round((1 - ratio) * 255); const g = Math.round(ratio * 200); const color = `rgb(${r}, ${g}, 50)`; L.circleMarker([p[1], p[2]], { radius: 3 + ratio * 5, fillColor: color, color: '#fff', weight: 0.5, fillOpacity: 0.6 }).addTo(circleLayer); }); circleLayer.addTo(map); } else if (mode === 'motivated') { // Heat map weighted by motivated score const pts = mapPoints.filter(p => p[1] && p[2] && p[6] > 0).map(p => [p[1], p[2], p[6] / 100]); heatLayer = L.heatLayer(pts, {radius: 25, blur: 20, maxZoom: 10, max: 1, gradient: {0.2: '#fff7bc', 0.4: '#fec44f', 0.6: '#fe9929', 0.8: '#d95f0e', 1: '#993404'} }).addTo(map); } }
🔒
Unlock owner contacts for 55,000+ properties
Get Access