To do what you want you could use a pivot in a SQL report. the Issue with that is unless you have congruence in details from the MIB Tables the data you want to display together may or may not work well. Worst thing here is once you have your report setup you might have to separate different vendors or portions of your UnDP's into different reports with adjusted queries.
Give this a go and see how well it shows for your APC's - note the Vendor Variable at the top, and the OID details in the where clause. Then reference your applied OIDs to different nodes to get what you need for another vendor. To pull the same table use the full OID minus the last column identifer (last #). Depending on the Vendors MIB setup you may or may not be able to shave more off of the OID to use a bigger wild card. Some vendors have MIB tables that work, and some have additional details that might 'mess up' your report. You could add a clause on the unique name <> X to exclude certain UnDP's but be careful of building too large a query that might adversly affect the report load time.
/* !Matrices for each vendor type and OID Table*/
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX),
@ven AS NVARCHAR(MAX)
Set @ven = 'American Power Conversion Corp.' -- Adjust the Vendor to create reports for other devices
select @cols = STUFF((SELECT ',' + QUOTENAME(p.UniqueName)
FROM Nodes n
JOIN CustomPollerAssignment ca ON n.NodeID = ca.NodeID
JOIN CustomPollers p on ca.CustomPollerID = p.PollerID
WHERE n.Vendor = @ven and (P.Enabled = 1) AND (
(P.OID like '18.104.22.168.4.1.322.214.171.124.2.2.%') -- If you change the OID here it also needs to change in the where clause to match in the set @query section.
group by p.UniqueName
order by p.UniqueName
FOR XML PATH(''), TYPE
set @query = 'SELECT Vendor, NodeID, Caption, IP_Address, MachineType, RowID, ' + @cols + ' from
,cps.Status as Status
FROM Nodes n
RIGHT JOIN CustomPollerAssignment cpa ON n.NodeID = cpa.NodeID
LEFT JOIN CustomPollers p on cpa.CustomPollerID = p.PollerID
RIGHT JOIN CustomPollerStatus cps on cps.CustomPollerAssignmentID = cpa.CustomPollerAssignmentID
WHERE ((n.Vendor = ''' + @ven + ''') AND (P.OID like ''126.96.36.199.4.1.3188.8.131.52.2.2.%'')) --- This needs to match the OID in the where clause above
for UniqueName in (' + @cols + ')
) p '
Loop1 Systems: SolarWinds Training and Professional Services
to the internal select query to bring in the Vendor Icon, and what look like a Custom Property that you have in your screen shot.