Skip to main content
 Skyscrapers at dusk, with lit offices

Commercial and Professional Lighting

Leverage UL Solutions' expertise in the commercial and professional lighting industries for essential safety and performance checks, including connected lighting.

Commercial and professional lighting services

Commercial and professional lighting is one of the most diverse segments in the lighting industry, with applications in office, warehouse and commercial spaces, along with specialty lighting needs for healthcare, hospitality, entertainment and more. Trusted and recognized around the globe, UL Solutions provides safety testing and certification, performance and energy efficiency, Global Market Access and connected lighting for all lighting categories.

Manufacturers, municipalities and specifiers recognize and trust the UL Mark on lighting products. Our global team actively participates in standards development and can help keep you ahead of the curve on new and evolving regulations and industry standards.

Smart buildings

The adoption of connected lighting technology into smart buildings is a key driver in the lighting market as integrated systems add value, functionality and light source optimization. Whether its meeting cybersecurity requirements, adding Li-Fi capabilities and adapting to emerging IoT technology, or integrating with building automation systems, we know that building owners and managers are looking for solutions.

UL Solutions adapts with the needs of the industry; let us help you make the transition from lighting as illumination to lighting as an integrated service and fulfill your cybersecurity needs.

Lighting for the health of people and plants

Human-centric lighting in offices, schools and industry is being used to enhance work and learning environments and improve productivity. In industries like hospitality and entertainment, smart lighting is being used for control of color, illumination and mood to enhance the ambiance of the customer experience. And in healthcare, lighting has an important impact on patient outcomes, with LED light therapy being used to treat skin and sleep disorders, and other conditions related to circadian rhythm.

UL Solutions recognizes that beyond utility, the future of lighting is connected to its impact on human health and well-being. Finding ways to differentiate your products in the marketplace with performance measurements and claims verifications is becoming increasingly important.

Lighting also plays a key factor in the health of plants, for both agricultural food production and legal cannabis production. Light mapping systems and controls are becoming more sophisticated, so cybersecurity is becoming a factor for horticultural lighting as well. UL Solutions has safety and certification services for UL 8800, the Standard for Horticultural Luminaires, and we offer performance testing and verification options. UL Solutions can also help with both horticultural and cybersecurity upcoming requirements for the DesignLights Consortium (DLC) Qualified Products list (QPL).

Ultraviolet germicidal lighting

UL Solutions offers resources for manufacturers incorporating ultraviolet-C (UVC) radiation into various product forms for sanitization and germicidal purposes. Due to the worldwide pandemic, public areas, schools, hotels, businesses, hospitals and more are looking for safe, certified products that can help keep spaces clean and reduce the spread of bacteria and viruses.

Visit our UVC webpage for the latest information and contact UL Solutions to discuss your options for safety testing and certification, performance and photobiological testing, outlined guidelines for site and product safeguards, and more.

Office and industrial lighting

Advancements in smart lighting are driving new ways to use light to track productivity, equipment and materials, employees, and customers. Stay ahead of safety and certification requirements as the technology rapidly advances.

Learn more

Stores and hospitality

Find services that meet the needs of retail spaces looking for energy efficiency solutions to lower costs and adding new technology like visible light communication for geo-positioning. For both stores and hospitality, explore the way lighting is being used as a tool for an enhanced customer experience.

Learn more

HazLoc lighting

No matter what type of indoor or outdoor hazardous location, UL Solutions offers safety testing and certification, ingress protection, salt and corrosion testing, environmental and temperature testing, and more.

Learn more

Horticultural and agricultural lighting

UL Solutions testing services measure safety requirements and performance metrics specifically for horticultural lighting equipment and systems.

Learn more

Stage and studio lighting

For concerts, stage and theater, studio, TV and film, clubs, and more, LED lighting technology has advanced to provide more options for color temperatures, timing and automation controls. UL Solutions can help you keep ahead of regulations and certifications for connected lighting solutions, and test energy efficiency and performance durability.

Learn more

Electric signs

UL Solutions offers comprehensive testing and certification to UL 48, the Standard for Electric Signs, and other applicable standards for digital and electric signs and sign retrofit kits with LED, neon, fluorescent, high intensity discharge (HID), electroluminescent, or incandescent illumination.

Learn more

Healthcare lighting

Beyond mere functionality, healthcare lighting solutions improve the patient experience and help create healing and nurturing environments. UL Solutions can help you to understand safety criteria and performance measurements for emerging trends in healthcare lighting.

Learn more

Emergency lighting

UL Solutions can help you stay up to date on safety and compliance standards for emergency applications using LED technology, connected lighting systems and more.

Learn more

Commercial and professional lighting resources

UL Solutions has lighting safety, performance, global market access and connected lighting services for all luminaire and electric signs categories, and we are constantly adapting to the needs of the industry to find testing solutions for new technologies.

As the most recognized lighting certifier in the U.S., the UL Mark gives customers and regulatory authorities the confidence in your products’ compliance. Our worldwide presence combined with local support for testing and certification to international standards gives us global reach with personalized service.

For additional support, please visit Locations, and select the site and contact number convenient to your location.

X

Get connected with our sales team

Thanks for your interest in our products and services. Let's collect some information so we can connect you with the right person.

Please wait…
'; let submitButton = $('form.mktoForm .mktoButtonWrap .mktoButton'); submitButton.prop("disabled", true); submitButton.append(loadingHTML); // Ocp-Apim-Subscription-Key: '***'. var $ocpKey = drupalSettings.ul_marketo_validate_key; var $ocpUrl = drupalSettings.ul_marketo_validate_url; var $ocpEnv = drupalSettings.ul_marketo_validate_env; if (submitCount > 1 || isResponseSuccess == true) { isResponseHandled = true; form.submittable(true); if (paramsDebug.debug == 1) { console.log("NO.10 submitCount > 1: form.submit() "); } submitButton.click(); } else { var email = form.vals().Email; var phone = (form.vals().Phone) ? (form.vals().Phone) : '18472728800'; var country = (form.vals().Country) ? (form.vals().Country) : 'United States'; var countryCode = (phone == '18472728800') ? 'US' : getCountryCode(country); var $emailMsg = drupalSettings.ul_marketo_validate.email; var $phoneMsg = drupalSettings.ul_marketo_validate.phone; if (paramsDebug.debug == 1) { console.log("paramsDebug:"); console.log(paramsDebug); } sendingData = JSON.stringify({ 'Input_Email': email, 'Input_Phone': phone, 'Input_ISO2_Country_Code': countryCode }); if (paramsDebug.debug == 1) { console.log('URL, debug missing button:'); console.log($ocpUrl); console.log("Sending Data to API service (ajax):"); console.log(sendingData); } // API call for validate email/phone/country. var sendDate = (new Date()).getTime(); var responseTimeMs = sendDate; // Start a timer to handle a 3-second response timeout setTimeout(function() { if (!isResponseHandled) { isResponseHandled = true; // Handle the assumed "success" due to timeout here if (paramsDebug.debug == 1) { console.log('No response within timeout, proceeding with default validation success.'); } $('#ValidMsgEmail').remove(); $('#ValidMsgPhone').remove(); // set form to be submittable here $('#valSpinner').remove(); submitButton.prop("disabled", false); // Setup status as Timeout instead of Unknown. emailAddressStatus = "Timeout"; phoneNumberStatus = "Timeout"; phoneNumberValidated = "Timeout"; form.vals({ "emailAddressStatus": emailAddressStatus, "phoneNumberStatus": phoneNumberStatus, "phoneNumberValidated": phoneNumberValidated, }); form.submittable(true); isResponseSuccess = true; if (paramsDebug.debug == 1) { let receiveDate = (new Date()).getTime(); responseTimeMs = (receiveDate - sendDate) / 1000; console.log("setTimeout: " + responseTimeMs + " seconds."); } submitButton.click(); } }, paramsDebug.timeout * 1000); //END setTimeout $.ajax({ url: $ocpUrl, type: 'POST', data: sendingData, headers: { 'Content-Type': 'application/json', 'Ocp-Apim-Subscription-Key': $ocpKey, }, success: function (response) { $('#valSpinner').remove(); submitButton.prop("disabled", false); phoneNumberValidated = response.Validated_Phone_Number; if (!isResponseHandled) { isResponseHandled = true; // **** Handle the validation response if (paramsDebug.debug == 1) { console.log("API Response Data: "); console.log(response); } var emailCode = response.Email_Validation_Status_Number; var phoneCode = response.Phone_Validation_Status_Number; // Add values into two status fields. if (emailValidCode.hasOwnProperty(emailCode)) { emailAddressStatus = emailValidCode[emailCode]; } else { // API error code doesn't exist, set defaul. emailAddressStatus = emailValidCode['300']; } if (phoneValidCode.hasOwnProperty(phoneCode)) { phoneNumberStatus = phoneValidCode[phoneCode]; } else { // API error code doesn't exist, set defaul. phoneNumberStatus = phoneValidCode['301']; } if (emailAddressStatus.indexOf("email_not") != -1) { emailAddressStatus = 'Invalid'; } else if(emailAddressStatus == 'valid') { emailAddressStatus = 'Valid'; } if (phoneNumberStatus.indexOf('invalid_') != -1) { phoneNumberStatus = 'Invalid'; } else if(phoneNumberStatus == 'valid') { phoneNumberStatus = 'Valid'; } if (paramsDebug.debug == 1) { console.log('form.emailAddressStatus ' + emailAddressStatus); console.log('form.phoneNumberStatus ' + phoneNumberStatus); console.log('form.phoneNumberValidated ' + phoneNumberValidated); } if (validEmailCode.includes(emailCode) && validPhoneCode.includes(phoneCode)) { // Remove the loading spinner. $('#ValidMsgEmail').remove(); $('#ValidMsgPhone').remove(); $('#valSpinner').remove(); submitButton.prop("disabled", false); if (paramsDebug.debug == 1) { console.log("NO.1.1 VALID OK submitCount = " + submitCount); } isResponseSuccess = true; form.vals({ "emailAddressStatus": emailAddressStatus, "phoneNumberStatus": phoneNumberStatus, "phoneNumberValidated": phoneNumberValidated, }); form.submittable(true); submitButton.click(); } // API valid code is not "valid". else { form.submittable(false); if (paramsDebug.debug == 1) { console.log("NO.1.2 Submittable false : count= " + submitCount + " validateOrigin " + validateOrigin + " isResponseSuccess " + isResponseSuccess ); } // Set the invalid message in language translation. var msgEmailStatus = ""; if (!validEmailCode.includes(emailCode)) { if (emailCode == '300' || emailCode == '400') { msgEmailStatus = $emailMsg.email_not_valid; } else if (emailCode == '310' || emailCode == '500' ) { msgEmailStatus = $emailMsg.email_not_accept; } else { msgEmailStatus = "Unknown"; } if (paramsDebug.debug == 1) { console.log("NOT validEmailCode: " + msgEmailStatus); } errEmail = ''; $('#Email').after(errEmail); form.submittable(false); } // Set the invalid message in language translation. var msgPhoneStatus = "" if (!validPhoneCode.includes(phoneCode)) { msgPhoneStatus = $phoneMsg[phoneValidCode[phoneCode]]; if (paramsDebug.debug == 1) { console.log("NOT validPhoneCode: " + msgPhoneStatus); } errPhone = ''; $('#Phone').after(errPhone); form.submittable(false); } if (paramsDebug.debug == 1) { console.log(msgEmailStatus); console.log(msgPhoneStatus); } // Remove the loading spinner. $('#valSpinner').remove(); submitButton.prop("disabled", false); if (paramsDebug.debug == 1) { console.log("NO.1.6 Submittable false, count= " + submitCount); } form.vals({ "emailAddressStatus": emailAddressStatus, "phoneNumberStatus": phoneNumberStatus, "phoneNumberValidated": phoneNumberValidated, }); // 2nd API call and subit form. if (submitCount >= 1) { $('#ValidMsgEmail').remove(); $('#ValidMsgPhone').remove(); isResponseSuccess = true; form.submittable(true); if (paramsDebug.debug == 1) { console.log("NO.1.8 : 2nd Submit:: submittable=true && count=1 : " + submitCount); } if (submitCount==1) { submitButton.click(); } } } //END if{} else{}. }//END if (!isResponseHandled) // Calculate the time comsumed for the API call. if (paramsDebug.debug == 1) { let receiveDate = (new Date()).getTime(); responseTimeMs = (receiveDate - sendDate) / 1000; console.log("NO.1.9 : AJAX success: Time for API call: " + responseTimeMs + " seconds."); } submitCount++; }, //END success: function(); // API call error response. error: function (error) { $('#valSpinner').remove(); submitButton.prop("disabled", false); if (!isResponseHandled) { isResponseHandled = true; $('#valSpinner').remove(); submitButton.prop("disabled", false); // 2nd API call and subit form. if ( submitCount >= 1 ) { $('#ValidMsgEmail').remove(); $('#ValidMsgPhone').remove(); form.submittable(true); isResponseSuccess = true; if ( submitCount == 1 ) { form.submittable(true); } } // Handle AJAX error if (paramsDebug.debug == 1) { console.log('**** 2 ajax error. submitCount = ' + submitCount); console.log(error); } // Calculate the time comsumed for the API call. if (paramsDebug.debug == 1) { let receiveDate = (new Date()).getTime(); responseTimeMs = (receiveDate - sendDate) / 1000; console.log("NO.2.3 AJAX error: Time for API call: " + responseTimeMs + " seconds."); } } submitCount++; // Error status 500, then submit the form. submitButton.click(); } //END error: function(); }); //END $.ajax; if (isResponseSuccess) { if (paramsDebug.debug == 1) { console.log("NO.8.0 submittable(true)"); } form.submittable(true); } } //END: if (submitCount > 1) else // Setup the form.vals and form.submittable; form.vals({ "emailAddressStatus": emailAddressStatus, "phoneNumberStatus": phoneNumberStatus, "phoneNumberValidated": phoneNumberValidated, }); } //END: if (validateOrigin && (marketoBundle)) else { // For Event form and Newsletter form. if (validateOrigin === true){ form.submittable(true); } } }); //END form.onValidate() // Success callback() form.onSuccess(function(values, followUpUrl){ // Debug Phone/Email validation. if (paramsDebug.debug == 1) { console.log("NO.9.1 onSuccess: submittable = " + form.submittable()); console.log(form.getValues()); } // Track analytics. if (typeof dataLayer !== 'undefined'){ dataLayer.push({ event: drplMkto.dataLayerEvent, mktoFormId: form.getId(), 'FormValues': cleanFormVals(form.getValues()), 'FormFields': form.allFieldsFilled(), 'Submittable': form.submittable() }); } // If function exists, delete UTM cookie: if(typeof _deleteUtmCookie === "function"){ _deleteUtmCookie(); } // Marketo Modal "Thank You" message: if(use_post_submit_mssg){ $('html, body').animate({ scrollTop: 0 }, 'slow'); $('.mkto-presubmit').addClass('hidden'); $('.mktoModalContent').addClass('mkto_thnx_center'); $('.mktoModalMask').addClass('not_clicable'); $('.mkto-postsubmit').removeClass('hidden'); $('.mktoButton').removeAttr('disabled').text(drupalSettings.marketo.button_text); $('.mktoForm')[0].reset(); grecaptcha.reset(); } // Else, redirect user: else { window.location.href = drplMkto.success_url; } // IMPORTANT: Return false to prevent further code execution. return false; }); //END form.onSuccess. }); })(jQuery, drupalSettings.marketo);