From 48540940b6c28bb4378abfeb500ec45a625b37b6 Mon Sep 17 00:00:00 2001 From: Vadim Dashevskiy Date: Tue, 15 May 2012 10:38:20 +0000 Subject: initial commit git-svn-id: http://svn.miranda-ng.org/main/trunk@2 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c --- plugins/IEView/TabSRMMHTMLBuilder.cpp | 446 ++++++++++++++++++++++++++++++++++ 1 file changed, 446 insertions(+) create mode 100644 plugins/IEView/TabSRMMHTMLBuilder.cpp (limited to 'plugins/IEView/TabSRMMHTMLBuilder.cpp') diff --git a/plugins/IEView/TabSRMMHTMLBuilder.cpp b/plugins/IEView/TabSRMMHTMLBuilder.cpp new file mode 100644 index 0000000000..42bc5fc2c7 --- /dev/null +++ b/plugins/IEView/TabSRMMHTMLBuilder.cpp @@ -0,0 +1,446 @@ +/* + +IEView Plugin for Miranda IM +Copyright (C) 2005-2010 Piotr Piastucki + +This program is free software; you can redistribute it and/or +modify it under the terms of the GNU General Public License +as published by the Free Software Foundation; either version 2 +of the License, or (at your option) any later version. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program; if not, write to the Free Software +Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +*/ +#include "TabSRMMHTMLBuilder.h" +#include "Options.h" +#include "Utils.h" + +// tabsrmm stuff + +#define MWF_LOG_SHOWNICK 512 +#define MWF_LOG_SHOWTIME 1024 +#define MWF_LOG_SHOWSECONDS 2048 +#define MWF_LOG_SHOWDATES 4096 +#define MWF_LOG_NEWLINE 8192 +#define MWF_LOG_INDENT 16384 +#define MWF_LOG_RTL 32768 +#define MWF_LOG_UNDERLINE 65536 +#define MWF_LOG_SWAPNICK 131072 +#define MWF_LOG_SHOWICONS 262144 + +#define MWF_LOG_INDENTWITHTABS 1048576 +#define MWF_LOG_SYMBOLS 0x200000 +#define MWF_LOG_TEXTFORMAT 0x2000000 +#define MWF_LOG_GRID 0x4000000 +#define MWF_LOG_INDIVIDUALBKG 0x8000000 + +#define MWF_DIVIDERWANTED 0x40000000 +#define MWF_LOG_GROUPMODE 0x80000000 +#define MWF_LOG_LONGDATES 64 +#define MWF_LOG_USERELATIVEDATES 1 + +#define MWF_SHOW_URLEVENTS 1 +#define MWF_SHOW_FILEEVENTS 2 +#define MWF_SHOW_INOUTICONS 4 +#define MWF_SHOW_EMPTYLINEFIX 8 +#define MWF_SHOW_MICROLF 16 +#define MWF_SHOW_MARKFOLLOWUPTS 32 + +#define SRMSGMOD "SRMsg" +#define SRMSGMOD_T "Tab_SRMsg" +#define TABSRMM_FONTMODULE "TabSRMM_Fonts" + +#define EVENTTYPE_DIVIDER 25367 +#define EVENTTYPE_ERRMSG 25366 + +#define SRMSGSET_SHOWURLS "ShowURLs" +#define SRMSGSET_SHOWFILES "ShowFiles" +#define SRMSGSET_SHOWSTATUSCHANGES "ShowFiles" + +#define MWF_LOG_DEFAULT (MWF_LOG_SHOWTIME | MWF_LOG_SHOWNICK | MWF_LOG_SHOWDATES) + +#define FONTF_BOLD 1 +#define FONTF_ITALIC 2 +#define FONTF_UNDERLINE 4 + +#define FONT_NUM 19 + +static const char *classNames[] = { + ".messageOut", ".miscOut", ".messageIn", ".miscIn", ".nameOut", ".timeOut", ".nameIn", ".timeIn", + ".hMessageOut", ".hMiscOut", ".hMessageIn", ".hMiscIn", ".hNameOut", ".hTimeOut", ".hNameIn", ".hTimeIn", + ".inputArea", ".statusChange", ".dividers" +}; + +TabSRMMHTMLBuilder::TabSRMMHTMLBuilder() { + setLastEventType(-1); + setLastEventTime(time(NULL)); + lastEventTime = time(NULL); + startedTime = time(NULL); +} + +bool TabSRMMHTMLBuilder::isDbEventShown(DWORD dwFlags, DBEVENTINFO * dbei) +{ + switch (dbei->eventType) { + case EVENTTYPE_MESSAGE: + return 1; + break; + case EVENTTYPE_STATUSCHANGE: + return 1; + break; + case EVENTTYPE_URL: + if(dwFlags & MWF_SHOW_URLEVENTS) return 1; + break; + case EVENTTYPE_FILE: + if(dwFlags & MWF_SHOW_FILEEVENTS) return 1; + break; + } + return 0; +} + +bool TabSRMMHTMLBuilder::isDbEventShown(DBEVENTINFO * dbei) +{ + DWORD dwFlags2 = DBGetContactSettingByte(NULL, SRMSGMOD_T, SRMSGSET_SHOWURLS, 0) ? MWF_SHOW_URLEVENTS : 0; + dwFlags2 |= DBGetContactSettingByte(NULL, SRMSGMOD_T, SRMSGSET_SHOWFILES, 0) ? MWF_SHOW_FILEEVENTS : 0; + return isDbEventShown(dwFlags2, dbei); +} + +void TabSRMMHTMLBuilder::loadMsgDlgFont(int i, LOGFONTA * lf, COLORREF * colour) { + char str[32]; + int style; + DBVARIANT dbv; + if (colour) { + wsprintfA(str, "Font%dCol", i); + *colour = DBGetContactSettingDword(NULL, TABSRMM_FONTMODULE, str, 0x000000); + } + if (lf) { + HDC hdc = GetDC(NULL); + wsprintfA(str, "Font%dSize", i); +// if(i == H_MSGFONTID_DIVIDERS) + // lf->lfHeight = 5; + // else { + lf->lfHeight = (char) DBGetContactSettingByte(NULL, TABSRMM_FONTMODULE, str, 10); +// lf->lfHeight= MulDiv(lf->lfHeight, GetDeviceCaps(hdc, LOGPIXELSY), 74); + // } + ReleaseDC(NULL,hdc); + lf->lfWidth = 0; + lf->lfEscapement = 0; + lf->lfOrientation = 0; + wsprintfA(str, "Font%dSty", i); + style = DBGetContactSettingByte(NULL, TABSRMM_FONTMODULE, str, 0); + lf->lfWeight = style & FONTF_BOLD ? FW_BOLD : FW_NORMAL; + lf->lfItalic = style & FONTF_ITALIC ? 1 : 0; + lf->lfUnderline = style & FONTF_UNDERLINE ? 1 : 0; + lf->lfStrikeOut = 0; + wsprintfA(str, "Font%dSet", i); + lf->lfCharSet = DBGetContactSettingByte(NULL, TABSRMM_FONTMODULE, str, DEFAULT_CHARSET); + lf->lfOutPrecision = OUT_DEFAULT_PRECIS; + lf->lfClipPrecision = CLIP_DEFAULT_PRECIS; + lf->lfQuality = DEFAULT_QUALITY; + lf->lfPitchAndFamily = DEFAULT_PITCH | FF_DONTCARE; + wsprintfA(str, "Font%d", i); + if (DBGetContactSetting(NULL, TABSRMM_FONTMODULE, str, &dbv)) + lstrcpyA(lf->lfFaceName, "Verdana"); + else { + lstrcpynA(lf->lfFaceName, dbv.pszVal, sizeof(lf->lfFaceName)); + DBFreeVariant(&dbv); + } + } +} + +char *TabSRMMHTMLBuilder::timestampToString(DWORD dwFlags, time_t check, int isGroupBreak) +{ + static char szResult[512]; + char str[80]; + + DBTIMETOSTRING dbtts; + + struct tm tm_now, tm_today; + time_t now = time(NULL); + time_t today; + + dbtts.cbDest = 70;; + dbtts.szDest = str; + + if(!isGroupBreak || !(dwFlags & MWF_LOG_SHOWDATES)) { + dbtts.szFormat = (dwFlags & MWF_LOG_SHOWSECONDS) ? (char *)"s" : (char *)"t"; + szResult[0] = '\0'; + } + else { + tm_now = *localtime(&now); + tm_today = tm_now; + tm_today.tm_hour = tm_today.tm_min = tm_today.tm_sec = 0; + today = mktime(&tm_today); + + if(dwFlags & MWF_LOG_USERELATIVEDATES && check >= today) { + dbtts.szFormat = (dwFlags & MWF_LOG_SHOWSECONDS) ? (char *)"s" : (char *)"t"; + strcpy(szResult, Translate("Today")); + strcat(szResult, ", "); + } + else if(dwFlags & MWF_LOG_USERELATIVEDATES && check > (today - 86400)) { + dbtts.szFormat = (dwFlags & MWF_LOG_SHOWSECONDS) ? (char *)"s" : (char *)"t"; + strcpy(szResult, Translate("Yesterday")); + strcat(szResult, ", "); + } + else { + if(dwFlags & MWF_LOG_LONGDATES) + dbtts.szFormat = (dwFlags & MWF_LOG_SHOWSECONDS) ? (char *)"D s" : (char *)"D t"; + else + dbtts.szFormat = (dwFlags & MWF_LOG_SHOWSECONDS) ? (char *)"d s" : (char *)"d t"; + szResult[0] = '\0'; + } + } + CallService(MS_DB_TIME_TIMESTAMPTOSTRING, check, (LPARAM) & dbtts); + strncat(szResult, str, 500); + Utils::UTF8Encode(szResult, szResult, 500); + return szResult; +} + + + +void TabSRMMHTMLBuilder::buildHead(IEView *view, IEVIEWEVENT *event) { + LOGFONTA lf; + COLORREF color; + char *output = NULL; + int outputSize; + ProtocolSettings *protoSettings = getSRMMProtocolSettings(event->hContact); + if (protoSettings == NULL) { + return; + } + if (protoSettings->getSRMMMode() == Options::MODE_TEMPLATE) { + buildHeadTemplate(view, event, protoSettings); + return; + } + if (protoSettings->getSRMMMode() == Options::MODE_CSS) { + const char *externalCSS = protoSettings->getSRMMCssFilename(); + if (strncmp(externalCSS, "http://", 7)) { + Utils::appendText(&output, &outputSize, "\n", externalCSS); + } else { + Utils::appendText(&output, &outputSize, "\n", externalCSS); + } + } else { + HDC hdc = GetDC(NULL); + int logPixelSY = GetDeviceCaps(hdc, LOGPIXELSY); + ReleaseDC(NULL, hdc); + DWORD dwFlags = DBGetContactSettingDword(NULL, SRMSGMOD_T, "mwflags", MWF_LOG_DEFAULT); + Utils::appendText(&output, &outputSize, "\n"); + } + if (output != NULL) { + view->write(output); + free(output); + } + setLastEventType(-1); +} + +time_t TabSRMMHTMLBuilder::getStartedTime() { + return startedTime; +} + +void TabSRMMHTMLBuilder::appendEventNonTemplate(IEView *view, IEVIEWEVENT *event) { +// int indentLeft = DBGetContactSettingDword(NULL, SRMSGMOD_T, "IndentAmount", 0); +// int indentRight = DBGetContactSettingDword(NULL, SRMSGMOD_T, "RightIndent", 0); + DWORD today = (DWORD)time(NULL); + today = today - today % 86400; + DWORD dwFlags = DBGetContactSettingDword(NULL, SRMSGMOD_T, "mwflags", MWF_LOG_DEFAULT); + DWORD dwFlags2 = DBGetContactSettingByte(NULL, SRMSGMOD_T, SRMSGSET_SHOWURLS, 0) ? MWF_SHOW_URLEVENTS : 0; + dwFlags2 |= DBGetContactSettingByte(NULL, SRMSGMOD_T, SRMSGSET_SHOWFILES, 0) ? MWF_SHOW_FILEEVENTS : 0; + dwFlags2 |= DBGetContactSettingByte(NULL, SRMSGMOD_T, "in_out_icons", 0) ? MWF_SHOW_INOUTICONS : 0; + dwFlags2 |= DBGetContactSettingByte(NULL, SRMSGMOD_T, "emptylinefix", 1) ? MWF_SHOW_EMPTYLINEFIX : 0; + dwFlags2 |= MWF_SHOW_MICROLF; + dwFlags2 |= DBGetContactSettingByte(NULL, SRMSGMOD_T, "followupts", 1) ? MWF_SHOW_MARKFOLLOWUPTS : 0; + + char *szRealProto = getRealProto(event->hContact); + IEVIEWEVENTDATA* eventData = event->eventData; + for (int eventIdx = 0; eventData!=NULL && (eventIdx < event->count || event->count==-1); eventData = eventData->next, eventIdx++) { + int outputSize; + char *output; + output = NULL; + if (eventData->iType == IEED_EVENT_MESSAGE || eventData->iType == IEED_EVENT_FILE || eventData->iType == IEED_EVENT_URL || eventData->iType == IEED_EVENT_STATUSCHANGE) { + int isGroupBreak = TRUE; + int isSent = (eventData->dwFlags & IEEDF_SENT); + int isRTL = eventData->dwFlags & IEEDF_RTL; + int isHistory = (eventData->time < (DWORD)getStartedTime() && (eventData->dwFlags & IEEDF_READ || eventData->dwFlags & IEEDF_SENT)); + if (dwFlags & MWF_LOG_GROUPMODE && eventData->dwFlags == LOWORD(getLastEventType()) + && eventData->iType == IEED_EVENT_MESSAGE && HIWORD(getLastEventType()) == IEED_EVENT_MESSAGE + && ((eventData->time < today) == (getLastEventTime() < today)) + && (((eventData->time < (DWORD)startedTime) == (getLastEventTime() < (DWORD)startedTime)) || !(eventData->dwFlags & IEEDF_READ))) { + isGroupBreak = FALSE; + } + char *szName = NULL; + char *szText = NULL; + if (eventData->dwFlags & IEEDF_UNICODE_NICK) { + szName = encodeUTF8(event->hContact, szRealProto, eventData->pszNickW, ENF_NAMESMILEYS, true); + } else { + szName = encodeUTF8(event->hContact, szRealProto, eventData->pszNick, ENF_NAMESMILEYS, true); + } + if (eventData->dwFlags & IEEDF_UNICODE_TEXT) { + szText = encodeUTF8(event->hContact, szRealProto, eventData->pszTextW, eventData->iType == IEED_EVENT_MESSAGE ? ENF_ALL : 0, isSent); + } else { + szText = encodeUTF8(event->hContact, szRealProto, eventData->pszText, event->codepage, eventData->iType == IEED_EVENT_MESSAGE ? ENF_ALL : 0, isSent); + } + /* TabSRMM-specific formatting */ + if ((dwFlags & MWF_LOG_GRID) && isGroupBreak && getLastEventType()!=-1) { + Utils::appendText(&output, &outputSize, "
", isRTL ? isSent ? "divOutGridRTL" : "divInGridRTL" : isSent ? "divOutGrid" : "divInGrid"); + } else { + Utils::appendText(&output, &outputSize, "
", isRTL ? isSent ? "divOutRTL" : "divInRTL" : isSent ? "divOut" : "divIn"); + } + if (dwFlags & MWF_LOG_SHOWICONS && isGroupBreak) { + const char *iconFile = ""; + if (eventData->iType == IEED_EVENT_MESSAGE) { + if (dwFlags2 & MWF_SHOW_INOUTICONS) iconFile = isSent ? "message_out.gif" : "message_in.gif"; + else iconFile = "message.gif"; + } else if (eventData->iType == IEED_EVENT_FILE) { + iconFile = "file.gif"; + } else if (eventData->iType == IEED_EVENT_URL) { + iconFile = "url.gif"; + } else if (eventData->iType == IEED_EVENT_STATUSCHANGE) { + iconFile = "status.gif"; + } + Utils::appendIcon(&output, &outputSize, iconFile); + } + if ((dwFlags & MWF_LOG_SWAPNICK) && (dwFlags & MWF_LOG_SHOWNICK) && isGroupBreak && (eventData->iType != IEED_EVENT_STATUSCHANGE)) { + const char *className = ""; + if (!isHistory) className = isSent ? "nameOut" : "nameIn"; + else className = isSent ? "hNameOut" : "hNameIn"; + if (dwFlags & MWF_LOG_UNDERLINE) { + Utils::appendText(&output, &outputSize, "%s%s", + className, szName, (dwFlags & MWF_LOG_SHOWTIME) ? " " :": "); + } else { + Utils::appendText(&output, &outputSize, "%s%s", + className, szName, (dwFlags & MWF_LOG_SHOWTIME) ? " " :": "); + } + } + if (dwFlags & MWF_LOG_SHOWTIME && (isGroupBreak || dwFlags2 & MWF_SHOW_MARKFOLLOWUPTS)) { + const char *className = ""; + if (!isHistory) className = isSent ? "timeOut" : "timeIn"; + else className = isSent ? "hTimeOut" : "hTimeIn"; + if (dwFlags & MWF_LOG_UNDERLINE) { + Utils::appendText(&output, &outputSize, "%s%s", + className, timestampToString(dwFlags, eventData->time, isGroupBreak), + (!isGroupBreak || (eventData->iType == IEED_EVENT_STATUSCHANGE) || (dwFlags & MWF_LOG_SWAPNICK) || !(dwFlags & MWF_LOG_SHOWNICK)) ? ": " : " "); + } else { + Utils::appendText(&output, &outputSize, "%s%s", + className, timestampToString(dwFlags, eventData->time, isGroupBreak), + (!isGroupBreak || (eventData->iType == IEED_EVENT_STATUSCHANGE) || (dwFlags & MWF_LOG_SWAPNICK) || !(dwFlags & MWF_LOG_SHOWNICK)) ? ": " : " "); + } + } + if ((eventData->iType == IEED_EVENT_STATUSCHANGE) || ((dwFlags & MWF_LOG_SHOWNICK) && !(dwFlags & MWF_LOG_SWAPNICK) && isGroupBreak)) { + if (eventData->iType == IEED_EVENT_STATUSCHANGE) { + Utils::appendText(&output, &outputSize, "%s ", szName); + } else { + const char *className = ""; + if (!isHistory) className = isSent ? "nameOut" : "nameIn"; + else className = isSent ? "hNameOut" : "hNameIn"; + if (dwFlags & MWF_LOG_UNDERLINE) { + Utils::appendText(&output, &outputSize, "%s: ", + className, szName); + } else { + Utils::appendText(&output, &outputSize, "%s: ", + className, szName); + } + } + } + if (dwFlags & MWF_LOG_NEWLINE && eventData->iType != IEED_EVENT_STATUSCHANGE && eventData->iType != IEED_EVENT_ERRMSG && isGroupBreak) { + Utils::appendText(&output, &outputSize, "
"); + } + const char *className = ""; + if (eventData->iType == IEED_EVENT_MESSAGE) { + if (!isHistory) className = isSent ? "messageOut" : "messageIn"; + else className = isSent ? "hMessageOut" : "hMessageIn"; + } else if (eventData->iType == IEED_EVENT_FILE) { + className = isHistory ? "hMiscIn" : "miscIn"; + } else if (eventData->iType == IEED_EVENT_URL) { + className = isHistory ? "hMiscIn" : "miscIn"; + } else if (eventData->iType == IEED_EVENT_STATUSCHANGE) { + className = "statusChange"; + } + Utils::appendText(&output, &outputSize, "%s", className, szText); + Utils::appendText(&output, &outputSize, "
\n"); + setLastEventType(MAKELONG(eventData->dwFlags, eventData->iType)); + setLastEventTime(eventData->time); + if (szName!=NULL) delete szName; + if (szText!=NULL) delete szText; + } + if (output != NULL) { + view->write(output); + free(output); + } + } + if (szRealProto!=NULL) delete szRealProto; + view->documentClose(); +// view->scrollToBottom(); +} + +void TabSRMMHTMLBuilder::appendEvent(IEView *view, IEVIEWEVENT *event) { + ProtocolSettings *protoSettings = getSRMMProtocolSettings(event->hContact); + if (protoSettings == NULL) { + return; + } + if (protoSettings->getSRMMMode() == Options::MODE_TEMPLATE) { + appendEventTemplate(view, event, protoSettings); + } else { + appendEventNonTemplate(view, event); + } +} -- cgit v1.2.3