Imports System.Xml
    Private Function HandleClassTags(ByVal
astrContent As String)
As String
        Dim
objxmlDoc As New
XmlDocument
        Dim
objNodeList_Html As XmlNodeList
        Dim
strXML As String
= ""
        Dim
dt_ClassTags As DataTable
        Dim
strResult As String
= ""
        Try
            dt_ClassTags = GetClassTags() 
            If
dt_ClassTags.Rows.Count > 0 Then
                'replace
all & symbols with '---amp---'
                strXML = "<root>" &
astrContent.Replace("&", "---amp---") & "</root>"
                objxmlDoc.LoadXml(strXML)
'first go through and remove the existing class set for the html tag if one exists
                For
Each row As DataRow In
dt_ClassTags.Rows
                    objNodeList_Html =
objxmlDoc.GetElementsByTagName(row("parent_tag").ToString)
                    For
Each xmlElem As
System.Xml.XmlElement In objNodeList_Html
                        If xmlElem.GetAttribute("class")
IsNot Nothing OrElse xmlElem.GetAttribute("class")
<> "" Then
                           
xmlElem.RemoveAttribute("class")
                        End If
                    Next
                Next
'now add the tags from the table as described above
                For
Each row As DataRow In
dt_ClassTags.Rows
                    objNodeList_Html =
objxmlDoc.GetElementsByTagName(row("parent_tag").ToString)
                    For
Each xmlElem As
System.Xml.XmlElement In objNodeList_Html
                        If xmlElem.GetAttribute("class")
Is Nothing OrElse xmlElem.GetAttribute("class")
= "" Then
                           
xmlElem.SetAttribute("class",
row("class").ToString)
                        End If
                    Next
                Next
                strResult = objxmlDoc.OuterXml
                strResult = strResult.Replace("<root>", "").Replace("</root>", "").Replace("---amp---",
"&")
            Else
                strResult = astrContent
            End
If
            Return
strResult
        Catch
ex As Exception
            Throw
ex
        Finally
            If
dt_ClassTags IsNot Nothing
Then
                dt_ClassTags.Dispose()
                dt_ClassTags = Nothing
            End
If
            If
objxmlDoc IsNot Nothing
Then
                objxmlDoc = Nothing
            End
If
        End Try
    End Function
 
No comments:
Post a Comment