/////////////////////////////////////////////////////////////////////////////
-// Name: m_links.cpp
+// Name: src/html/m_links.cpp
// Purpose: wxHtml module for links & anchors
// Author: Vaclav Slavik
-// RCS-ID: $Id$
// Copyright: (c) 1999 Vaclav Slavik
-// Licence: wxWidgets Licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
-#pragma implementation
-#endif
-
#include "wx/wxprec.h"
-#include "wx/defs.h"
-#if wxUSE_HTML && wxUSE_STREAMS
-
#ifdef __BORLANDC__
-#pragma hdrstop
+ #pragma hdrstop
#endif
-#ifndef WXPRECOMP
+#if wxUSE_HTML && wxUSE_STREAMS
+
+#ifndef WX_PRECOMP
#endif
#include "wx/html/forcelnk.h"
#include "wx/html/m_templ.h"
+#include "wx/html/styleparams.h"
FORCE_LINK_ME(m_links)
virtual const wxHtmlCell* Find(int condition, const void* param) const
{
- if ((condition == wxHTML_COND_ISANCHOR) &&
+ if ((condition == wxHTML_COND_ISANCHOR) &&
(m_AnchorName == (*((const wxString*)param))))
{
return this;
}
}
- DECLARE_NO_COPY_CLASS(wxHtmlAnchorCell)
+ wxDECLARE_NO_COPY_CLASS(wxHtmlAnchorCell);
};
TAG_HANDLER_PROC(tag)
{
- if (tag.HasParam( wxT("NAME") ))
+ wxString name;
+ if (tag.GetParamAsString(wxT("NAME"), &name))
{
- m_WParser->GetContainer()->InsertCell(new wxHtmlAnchorCell(tag.GetParam( wxT("NAME") )));
+ m_WParser->GetContainer()->InsertCell(new wxHtmlAnchorCell(name));
}
- if (tag.HasParam( wxT("HREF") ))
+ wxString href;
+ if (tag.GetParamAsString(wxT("HREF"), &href))
{
wxHtmlLinkInfo oldlnk = m_WParser->GetLink();
wxColour oldclr = m_WParser->GetActualColor();
+ wxColour oldbackclr = m_WParser->GetActualBackgroundColor();
+ int oldbackmode = m_WParser->GetActualBackgroundMode();
+ int oldsize = m_WParser->GetFontSize();
+ int oldbold = m_WParser->GetFontBold();
+ int olditalic = m_WParser->GetFontItalic();
int oldund = m_WParser->GetFontUnderlined();
- wxString name(tag.GetParam( wxT("HREF") )), target;
+ wxString oldfontface = m_WParser->GetFontFace();
+ wxString target = tag.GetParam( wxT("TARGET") );
- if (tag.HasParam( wxT("TARGET") )) target = tag.GetParam( wxT("TARGET") );
+ // set default styles, might get overridden by ApplyStyle
m_WParser->SetActualColor(m_WParser->GetLinkColor());
m_WParser->GetContainer()->InsertCell(new wxHtmlColourCell(m_WParser->GetLinkColor()));
- m_WParser->SetFontUnderlined(TRUE);
+ m_WParser->SetFontUnderlined(true);
m_WParser->GetContainer()->InsertCell(new wxHtmlFontCell(m_WParser->CreateCurrentFont()));
- m_WParser->SetLink(wxHtmlLinkInfo(name, target));
+ m_WParser->SetLink(wxHtmlLinkInfo(href, target));
+
+ // Load any style parameters
+ wxHtmlStyleParams styleParams(tag);
+ ApplyStyle(styleParams);
ParseInner(tag);
m_WParser->SetLink(oldlnk);
+ m_WParser->SetFontSize(oldsize);
+ m_WParser->SetFontBold(oldbold);
+ m_WParser->SetFontFace(oldfontface);
+ m_WParser->SetFontItalic(olditalic);
m_WParser->SetFontUnderlined(oldund);
m_WParser->GetContainer()->InsertCell(new wxHtmlFontCell(m_WParser->CreateCurrentFont()));
m_WParser->SetActualColor(oldclr);
m_WParser->GetContainer()->InsertCell(new wxHtmlColourCell(oldclr));
- return TRUE;
+ if (oldbackmode != m_WParser->GetActualBackgroundMode() ||
+ oldbackclr != m_WParser->GetActualBackgroundColor())
+ {
+ m_WParser->SetActualBackgroundMode(oldbackmode);
+ m_WParser->SetActualBackgroundColor(oldbackclr);
+ m_WParser->GetContainer()->InsertCell(
+ new wxHtmlColourCell(oldbackclr, oldbackmode == wxTRANSPARENT ? wxHTML_CLR_TRANSPARENT_BACKGROUND : wxHTML_CLR_BACKGROUND));
+ }
+
+ return true;
}
- else return FALSE;
+ else return false;
}
TAG_HANDLER_END(A)