Skip to Main Content
#= data.Name ? data.Name : data.Sku #
Mfr Part\\#: #:ManufacturerItemNumber#
Vendor Inv: ' + p.DropShipQuantityAvailable + stockInfoLink; } return p.QuantityAvailable.toString() + ' Available' + stockInfoLink; } var vendorInventory = ""; var ourInventory = "Qty Avail. to Order: " + p.QuantityAvailable + ""; var onHandOnOrderInventory = "
Total Qty in Stock:" + stockInfoLink; if (p.DropShipQuantityAvailable > 0) { vendorInventory = "
Vendor Inventory: " + p.DropShipQuantityAvailable.toString() + ""; if (p.QuantityAvailable == 0) { ourInventory = ""; } } stockInfoLink = ""; if (p.QuantityAvailable == 0 && p.DropShipQuantityAvailable > 0) { onHandOnOrderInventory = onHandOnOrderInventory.replace("
", ""); } return ourInventory + onHandOnOrderInventory + vendorInventory + stockInfoLink; } var dlgStockInfo = null; function showStockInquiry(link) { var sx = $(link); var p = JSON.parse(sx.attr('data-properties')); var progressTarget = $(document.body); kendo.ui.progress(progressTarget, true); if (!dlgStockInfo) { dlgStockInfo = $("#dlgStockInfo").kendoDialog({ title: 'Stock Inquiry', width: 450, closable: true, modal: true, visible: false }).data("kendoDialog"); dlgStockInfo.wrapper.addClass('cart-dialog'); dlgStockInfo.wrapper.find('.k-window-title').prepend(''); } $.post('/api/sitecore/Products/ProductStockInquiry', { 'p': p }) .done(function(result) { kendo.ui.progress(progressTarget, false); dlgStockInfo.content(result).open(); }); } function checkMSRP() { $(".item-container-pricing.main-price:contains('$0.01')").html(""); $(".item-container-pricing.field-msrp:contains('0.01')").html(" Call for Pricing"); }function loadPricing(pricePrefix, addSelector, hideTotalQty) { addSelector = addSelector || '.related-product-add'; var reqs = [], ctlHash = {}; $((pricePrefix ? pricePrefix : '') + '.item-container-pricing[data-properties]').each(function (i, ph) { phx = $(ph); var qtyInput = phx.closest('.product-detail-container').find('.k-input[data-role=numerictextbox]'); var pd = JSON.parse(phx.attr('data-properties')); var qty = (qtyInput.length ? qtyInput.val() : !pd.MOQ ? 1 : parseInt(pd.MOQ)); var uuid = (pd.itemNumber + "_" + qty + "_" + reqs.length); //BL: container id is not setup yet ctlHash[uuid] = { "data": pd, "control": phx }; reqs.push({ "UUID": uuid, "itemNumber": pd.itemNumber, "sku": pd.sku, "msrp": pd.msrp, "Quantity": qty, "HasAlternates": pd.HasAlternates, "HasAccessories": pd.HasAccessories }); if ((priceContext == null || !priceContext.IsAuthenticated) && pricePrefix == 'div.search-results.product-list ' && (pd.HasAccessories == 'True' || pd.HasAlternates == 'True')) { buildRelationshipLink(null, pd, phx); } }); //BL: don't get contract pricing if you don't have a valid user who is allowed to see it if (priceContext == null || !priceContext.IsAuthenticated /*|| priceContext.HideContractPricing*/) { checkMSRP(); return; } $.post('/api/sitecore/Products/GetPricingMulti', { "context": priceContext, "priceRequests": reqs, "dealIds": globalDealIds }) .done(function (prices) { if (prices) { $.each(prices, function (pi, p) { var px = ctlHash[pi]; var ph = px.control, pd = px.data, phParent = ph.parent(); var cnt = ph.closest(ph.hasClass('main-price') || ph.hasClass('field-msrp') ? '.product-detail-container' : '.related-product-container'); if (priceContext.CanCreateCart && pd.webOrdering !== 'ViewOnly') { cnt.addClass('buyable'); } // put price in if (!p.DealerAuthorized) { var add = cnt.find(addSelector).first(); setupGetAuthorizedCTA(add, ph); } else { if (pd.displayRetail === 'C' || pd.msrp === "0.01") { ph.html('Call for Pricing'); } else if (!priceContext.HideContractPricing) { ph.html('
MSRP | Your Price |
---|
' + qtyStr + '
').appendTo(phParent); } } } triggerPricingEvent(pricePrefix, phParent, pd, p); }); } }); } function triggerPricingEvent(pricePrefix, prcElem, productData, prcDetail) { const evtPricing = new CustomEvent('product.pricing', { detail: { pricePrefix: pricePrefix, element: prcElem, product: productData, price: prcDetail } }); window.dispatchEvent(evtPricing); } function onAccountSelect(e) { selectAccount(e.dataItem); } var pageAccountChangeHandler = null; function selectAccount(a) { //BL: throw an event here for other pages to listen to // - should we keep reload from always happening? // - can we check if handler is subcribed and only reload if not? kendo.ui.progress($(document.body), true); $.get('/api/sitecore/Account/SelectAccount', { "CustomerNumber": a.CustomerNumber, "Name": a.Name, "Description": a.Description } ) .done(function (data) { if (pageAccountChangeHandler) { // fix stuff in header and let page handler do the rest $("div.account-name").html(a.Description); priceContext.CustomerNumber = a.CustomerNumber; pageAccountChangeHandler(a); //B (4.21.22): horrible code necessary to hide account nav menu after selection var ac = $("#accountMenu .child-navigation"); $("#ddlAccounts").focus(); ac.hide(); ac.mouseleave(); ac.show(); kendo.ui.progress($(document.body), false); } else { document.location.reload(); // reload everything to make sure account gets applied } }); } function addCartItem(itemId, sku, qty, persist, origin) { if (origin === undefined) { origin = ""; } // update count overlay (and show, if need be) var lblCount = $("#cartItemCount"); if (!cartItemCount) { cartItemCount = parseInt(lblCount.html()); } // animate, while waiting lblCount.html(""); cartItemCount += qty; if (persist) { $.post('/api/sitecore/Carts/AddItem', { "sku": sku, "materialId": itemId, "quantity": qty, "origin": origin, "dealIds": globalDealIds }) .done(function (result) { // nothing really needs done here, yet ... already updated count lblCount.html(cartItemCount.toString()); hideShowCartCount(lblCount, cartItemCount); }) .fail(function (error) { alert('Issue adding item to cart: ' + error.statusText); lblCount.html("?"); }); } else { lblCount.html(cartItemCount.toString()); } } function hideShowCartCount(lblCount, cnt) { var pdiv = lblCount.parent(); if (cnt && !pdiv.is(":visible")) { pdiv.show(); } else if (cnt <= 0 && pdiv.is(":visible")) { pdiv.hide(); } } function updateCartItemCount(cnt) { cartItemCount = cnt; var lblCount = $("#cartItemCount"); lblCount.html(cartItemCount.toString()); hideShowCartCount(lblCount, cnt); } function login(returnUrl) { document.location = '/api/sitecore/Account/SignUpSignIn' + (returnUrl ? '?returnUrl=' + encodeURIComponent(returnUrl) : ''); } function logout(returnUrl) { document.location = '/api/sitecore/Account/SignOut' + (returnUrl ? '?returnUrl=' + encodeURIComponent(returnUrl) : ''); } var scopes = ['search-all', 'search-product','search-blogs']; function submitSearch(searceInputId) { // close search and auto-complete $('.search-btn').click(); $('#search').data("kendoAutoComplete").close(); var sval = $("#" + searceInputId).val(); var searchUrl = ''; if ($("#rbSearchProducts").is(":checked")) { searchUrl = '/shop#search-product_e=0&search-product_q=' + sval; } else { searchUrl = '/search'; $.each(scopes, function (i, s) { searchUrl += (i == 0 ? '#' : '&') + /*s + '_e=0&' +*/ s + '_q=' + sval; }); } document.location.href = searchUrl; } function setupGetAuthorizedCTA(ctrlAdd, ctrlPH) { // create cta button in ctrl ctrlAdd.html("Get Authorized
' + shopMessage + '
').prependTo(warningContainerSelector || '#main-content > .container > .row'); } } var productFlags = { 'Featured': { label: 'Featured', info: 'This product is featured in some promotion.', class:'flag-featured' }, 'Rebox': { label: 'ReBox', info: 'ReBox products are new, undamaged and have full factory warranty. They arrived at our warehouse in a damaged carton, and do not meet our standards to be sold as new.', class: 'flag-rebox' }, 'BStock': { label: 'B-Stock', info: 'B-Stock products are functional products that may be in an impaired physical condition, missing items or both. Standard DOA return policies apply.', class: 'flag-bstock' }, 'NonReturnable': { label: 'Non-Returnable', info: 'Non-Returnable products can not be returned once they have been shipped.', class: 'flag-non-returnable' }, 'NonCancelable': { label: 'Non-Cancelable', info: 'Non-Cancelable products can not be canceled once the order is confirmed in our system.', class: 'flag-non-cancelable' }, 'New': { label: 'New', info: 'Specialty Items are products or services that are called out as being featured, new or end-of-life', class: 'flag-new' }, 'EndOfLife': { label: 'End of Life', info: 'Specialty Items are products or services that are called out as being featured, new or end-of-life', class: 'flag-end-of-life' }, 'Clearance': { label: 'Clearance', info: 'Item marked for clearance', class: 'flag-end-of-life' }, 'PendingObsolete': { label: 'Pending Obsolescence', info: 'The manufacturer has announced that the item will soon be discontinued. Contact your sales rep for more details and potential replacement information.', class: 'flag-end-of-life' } }; function setupFlagTooltip(img) { var fdata = img.getAttribute('flag-data'); var ttContent = ''; var flags = fdata.split('|'); for (var i = 0; i < flags.length; ++i) { var fname = flags[i]; if (fname) { var f = productFlags[fname]; if (typeof f !== 'undefined') { ttContent += '
' + f.info + '
'; } } } ttContent += '
', { 'class': 'cbxWrapper', 'data-cbxvalue': name }) .append( $(document.createElement('input')).prop({ 'id': 'cbxEcommUser' + counter, 'name': 'userEmail', 'value': email, 'type': 'checkbox' }) ).append( $(document.createElement('label')).prop({ 'for': 'cbxEcommUser' + counter }).html(name)) ); } function removeHtmlTags(str) { if ((str===null) || (str==='')) return false; else str = str.toString(); return str.replace( /(<([^>]+)>)/ig, ''); } function getuuid() { return ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, c => (c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16) ); } function sendEmails(chosenElements, cartid, cartname, message) { var emails = []; chosenElements.each(function () { emails.push($(this).val()); }); $.post('/api/sitecore/Carts/NotifySharedCart', { "emails": emails, "cartid": cartid, "cartname": cartname, "note": message }) .done(function (result) { }); } var dlgCreateQuote = null; function confirmCreateQuote() { //BL: check if there is anything to quote if (!order || !order.Lines || order.Lines.length == 0) { showNotification('Please add items to your cart before creating a quote', 'error'); return; } if (!dlgCreateQuote) { dlgCreateQuote = $("#dlgCreateQuote").kendoDialog({ title: 'Create Quote', closable: true, modal: true, top: 100 }).data("kendoDialog"); dlgCreateQuote.wrapper.addClass('cart-dialog'); dlgCreateQuote.wrapper.find('.k-window-title').prepend(''); dlgCreateQuote.wrapper.find('.k-dialog-close').prepend('Close'); dlgCreateQuote.wrapper.attr("style", "top:" + (document.body.scrollTop + 50) + "px"); dlgCreateQuote.wrapper.find('.cancel-button').on('click', function () { dlgCreateQuote.close(); }); dlgCreateQuote.wrapper.find('.save-button').on('click', function () { createQuote(); dlgCreateQuote.close(); }); } dlgCreateQuote.open(); } function createQuote(cartScopeID = null, cartID = null) { if (cartScopeID == null) { //quote is coming from brand new cart var dlg = dlgCreateQuote.wrapper; var name = dlg.find("#edQuoteName").val(); var desc = dlg.find("#edQuoteDecription").val(); var mediaType = dlg.find("input[name='quoteMedia']:checked").val(); var isExcel = mediaType == "excel" ? true : false; var newName = (name !== null && name.trim() !== '') ? name : + '-' + formatShortDate(new Date()); buildQuote(newName, desc, order, itemMeta, isExcel); } else { //quote is coming from existing cart - currently forcing to PDF and using cart name/description $.get('/api/sitecore/Carts/GetCartContextForQuote', { "cartScopeId": cartScopeID, "cartId": cartID }) .done(function (quote) { buildQuote(quote.quoteName, quote.quoteDescription, quote.cartContext.Order, quote.cartContext.ItemMeta, false); }); } } function buildQuote(name, desc, cartorder, cartitemmeta, isExcel) { //BL: need to have window popup call come from main UI thread to avoid popup blocker var d2 = window.open(); var progresstarget = $(d2.document.body); kendo.ui.progress(progresstarget, true); $.post('/api/sitecore/Carts/CreateQuote',{ "name": name, "description": desc, "cart": { "Order": cartorder, "ItemMeta": cartitemmeta }, "isExcel": isExcel }) .done(function (quote) { if (quote != null) { var custnum = quote.ValidForCustomerNum; var username = quote.CreatorName.replace(" ", "-").toLowerCase(); var filename = quote.ID.toString() + quote.FileTypeExtension; if (isExcel) { buildExcelQuote(quote, custnum, username, filename); } else { kendo.ui.progress(progresstarget, false); d2.document.location = '/~/media/Project/scansource/scansourceweb/quotes/' + custnum + "/" + username + "/" + filename, '_blank'; } } else { window.alert('An error occurred while processing your quote. Please try again or contact your ScanSource sales representative.'); } }); } function buildExcelQuote(quote, custnum, username, filename) { var progresstarget = $("body"); var createDate = parseJsonDate(quote.CreationDate); var expireDate = parseJsonDate(quote.ExpirationDate); var title = "ScanSource Quote - " + quote.ValidForCustomerName + "-" + formatShortDate(createDate, true, false) + "-" + createDate.getMilliseconds(); var headercount = 6; var rows = [{}]; if (quote.Name != null && quote.Name != "") { rows.push({ cells: [{ value: 'Quote Name: ' + quote.Name, colSpan: 5 }] }) headercount++; } rows.push({ cells: [ { value: 'Requested By: ' + quote.CreatorName, colSpan: 5 }, { value: 'Date Created: ' + formatShortDate(createDate, false, true), colSpan: 4, textAlign: "right" } ] }) rows.push({ cells: [ { value: 'Valid For: ' + quote.ValidForCustomerName + " (" + quote.ValidForCustomerNum + ")", colSpan: 5 } //,{ value: 'Quote Expiration: ' + formatShortDate(expireDate, false, true), colSpan: 4, textAlign: "right" } ] }) if (quote.SalesRepEmail != null && quote.SalesRepEmail != "") { rows.push({ cells: [ { value: 'Sales Rep Email: ' + quote.SalesRepEmail, colSpan: 5 } ] }) headercount++; } if (quote.Description != null && quote.Description != "") { rows.push({ cells: [ { value: 'Quote Description: ' + quote.Description, colSpan: 9, wrap: true, verticalAlign: "top" } ] }) headercount++; } rows.push({ cells: [{}] }) rows.push({ cells: [ { value: title, background: "#f4a361", fontSize: 30, bold: true, colSpan: 9, verticalAlign: "center" } ], height: 50 }) rows.push({ cells: [ { value: 'Item#', background: "#f1f586", bold: true, fontSize: 18, borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderLeft: { color: "#000000", size: 1 } }, { value: 'Description', background: "#f1f586", bold: true, fontSize: 18, borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 } }, { value: 'Stock', background: "#f1f586", bold: true, fontSize: 18, textAlign: "Right", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 } }, { value: 'Discounts', background: "#f1f586", bold: true, fontSize: 18, borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 } }, { value: 'Discount Notes', background: "#f1f586", bold: true, fontSize: 18, borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 } }, { value: 'MSRP', background: "#f1f586", bold: true, fontSize: 18, textAlign: "Right", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 } }, { value: 'Price', background: "#f1f586", bold: true, fontSize: 18, textAlign: "Right", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 } }, { value: 'Qty', background: "#f1f586", bold: true, fontSize: 18, textAlign: "Right", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 } }, { value: 'Total', background: "#f1f586", bold: true, fontSize: 18, textAlign: "Right", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 } } ], height: 35 }); // Use fetch so that you can process the data when the request is successfully completed. for (var i = 0; i < quote.QuoteLines.length; i++) { var color = i % 2 == 1 ? "#eff8ff" : "#ffffff"; rows.push({ cells: [ { value: quote.QuoteLines[i].ManufacturerItemNumber, background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 }, borderLeft: { color: "#000000", size: 1 } }, { value: quote.QuoteLines[i].Description == "null" ? '' : quote.QuoteLines[i].Description, wrap: true, background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 } }, { value: quote.QuoteLines[i].QuantityAvailable, format: '#', background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 } }, { value: quote.QuoteLines[i].SPADescription == "null" ? '' : quote.QuoteLines[i].SPADescription, wrap: true, background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 } }, { value: quote.QuoteLines[i].SPARestriction == "null" ? '' : quote.QuoteLines[i].SPARestriction, wrap: true, background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 } }, { value: quote.QuoteLines[i].MSRP, format: '$#.00', background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 } }, { value: quote.QuoteLines[i].Price, format: '$#.00', background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 } }, { value: quote.QuoteLines[i].Quantity, background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 } }, { value: quote.QuoteLines[i].ExtPrice, format: '$#.00', background: color, verticalAlign: "top", borderTop: { color: "#000000", size: 1 }, borderRight: { color: "#000000", size: 1 }, borderBottom: { color: "#000000", size: 1 } } ], height: 40 }) } rows.push({ cells: [{}, {}, {}, {}, {}, { value: 'Total: ', background: "#ffffff", textAlign: "right" }, { value: quote.Total, format: '$#.00', background: "#ffffff", colSpan: 2, textAlign: "right" } ], height: 30 }) rows.push({ cells: [{}, { value: 'Thank you for your business. Please note that pricing, dates and availability are subject to change without notice. Due to fluctuations in the exchange rate, all prices are subject to change until invoiced. ScanSource Trading Terms apply to the exclusion of any other terms.', background: "#ffffff", color: "#0D47A1", colSpan: 6, wrap: true, textAlign: "center", verticalAlign: "top" }], height: 45 }) rows.push({ cells: [{}] }) rows.push({ cells: [{}] }) rows.push({ cells: [ { value: 'Reference # : ' + quote.ValidForCustomerName.replace(/[^a-zA-Z0-9-]/, "") + "-" + quote.ID, colSpan: 9 } ] }) var workbook = new kendo.ooxml.Workbook({ sheets: [ { frozenRows: headercount, columns: [ { width: 150 }, { width: 400 }, { autoWidth: true }, { width: 300 }, { width: 300 }, { autoWidth: true }, { autoWidth: true }, { autoWidth: true }, { autoWidth: true } ], title: 'ScanSource Custom Quote', rows: rows, } ], }); var data = workbook.toDataURL(); var base64 = data.split(";base64,")[1]; $.post('/api/sitecore/Carts/UploadQuote', { "file": base64, "quote": quote }) .done(function (success) { if (success) { kendo.ui.progress(progresstarget, false); document.location.href = '/~/media/Project/scansource/scansourceweb/quotes/' + custnum + "/" + username + "/" + filename; } else { window.alert('An error occurred while processing your quote. Please try again or contact your ScanSource sales representative.'); } }); } function formatShortDate(date, pad, slashes) { var year = date.getFullYear(); var month = pad ? String(date.getMonth() + 1).padStart(2, '0') : String(date.getMonth() + 1); var day = pad ? String(date.getDate()).padStart(2, '0') : String(date.getDate()); return slashes? [month, day, year].join('/') : year + month + day; } function parseJsonDate(jsonDateString) { return new Date(parseInt(jsonDateString.replace(/\D/g, ''))); } var dlgSessionTimeout = null; function scKeepAlive() { // check if user is still authenticated $.post('/api/sitecore/Base/Ping') .done(function (res) { if (!res || !res.IsAuthenticated) { // clear timed ping if (keepAlive) { window.clearInterval(keepAlive); } // show dialog if (dlgSessionTimeout) { dlgSessionTimeout.show(); } else { dlgSessionTimeout = $("#dlgSessionTimeout").kendoDialog({ title: false, content: '
Are you still there?
Your session has timed out due to an extended period of inactivity
', width: 400, modal: true, closable: false, buttonLayout: "normal", actions: [{ text: "I'm Here", primary: true, action: function (e) { document.location.href = '/api/sitecore/Account/SignUpSignIn?returnUrl=' + encodeURIComponent(document.location.href); return true; } }, { text: "Sign out", action: function (e) { document.location.reload(); return true; } }] }).data("kendoDialog"); } } }); }Zebra PartnerConnect
-
shop Zebra >
NEED MORE HELP?
Zebra Newsletter
PartnerConnect is designed to enable Zebra channel partners to differentiate their expertise, increase their profits, and be rewarded for their investments as they grow their business and support our mutual customers—whether they choose to go deep into a few technologies, or wide across many technologies.
In 2016, Zebra officially launched PartnerConnect—the new, integrated partner program that unites PartnersFirst™ and PartnerEmpower™ members into one platform.PartnerConnect is designed to enable Zebra channel partners to differentiate their expertise, increase their profits, and be rewarded for their investments as they grow their business and support our mutual customers—whether they choose to go deep into a few technologies, or wide across many technologies.
-
Benefits of PartnerConnect
What’s different about PartnerConnect?
Existing members of PartnersFirst and PartnerEmpower will recognize many components of the program. However, the program design also addresses new strategies such as:•Recognizing different reseller business models.PartnerConnect includes both a Business Partner Track, serving resellers focused on hardware resale, and a Solution Partner Track, designed for resellerswith a balanced mix of hardware, software, and services revenue. The benefits associated with these tracks reward each partner type for their contribution in meeting the needs of today’s customers.
•Jump-starting relationships.We have introducedregisteredstatus for both resellers and ISVs. These entry-level designations—with no revenue requirements—allow channel partners to begin a relationship with Zebra, and gain access to resources that will help them grow their Zebra business.
•Driving cross-selling through broader product access.PartnerConnect features product access across our entire portfolio—with limited restrictions on access to products and services, making it easy for resellers to expand the scope of a deal and pursue new opportunities.
Want to learn more about PartnerConnect?You will also find a number of program resources on the new Zebra partner portal, Partner Gateway. Visit the Program section for complete program guides and other resources, including a FAQ section about various aspects of participating in PartnerConnect.Learn More
-
Deal Registration Program
Deal Registration Program
One of PartnerConnect's most important benefits for resellers, the Deal Registration Program, recognizes the significant pre-sale investments resellers make in creating and closing sales opportunities, and provides the opportunity to be more competitive.Through this program, you can apply to register a deal in progress. If the application is approved, you are eligible for an incremental product discount. The discount percentage differs by product portfolio; see program guidelines for details.
Register a Deal