summaryrefslogtreecommitdiff
path: root/plugins/SendScreenshotPlus/src
diff options
context:
space:
mode:
authorRené Schümann <white06tiger@gmail.com>2014-04-11 17:11:23 +0000
committerRené Schümann <white06tiger@gmail.com>2014-04-11 17:11:23 +0000
commit99e1f60a6570c12fd02a9a2ebe8915680d2bfcec (patch)
tree847576f3018a23689c951734200c58707d116825 /plugins/SendScreenshotPlus/src
parente80eac0d78daff0f041078d21218850f31c5315e (diff)
SendSS:
*+ improved "Result"-Dialog (resource.rc/h, CSend, mir_icolib) added thumbnail link added copy buttons w/ images (copy raw, BBCode image, BBCode image with link) also improved handling. Now plays sound before dialog opens (was on close before) * CSend got new member variables. m_URL and m_URLthumb to hold image URLs (used by FTP,HTTP and ImageShack as of now) - removed m_URL and similar from CSendFTPFile and CSendHTTPServer git-svn-id: http://svn.miranda-ng.org/main/trunk@8957 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'plugins/SendScreenshotPlus/src')
-rw-r--r--plugins/SendScreenshotPlus/src/CSend.cpp98
-rw-r--r--plugins/SendScreenshotPlus/src/CSend.h4
-rw-r--r--plugins/SendScreenshotPlus/src/CSendFTPFile.cpp5
-rw-r--r--plugins/SendScreenshotPlus/src/CSendFTPFile.h1
-rw-r--r--plugins/SendScreenshotPlus/src/CSendHTTPServer.cpp6
-rw-r--r--plugins/SendScreenshotPlus/src/CSendHTTPServer.h1
-rw-r--r--plugins/SendScreenshotPlus/src/mir_icolib.cpp5
-rw-r--r--plugins/SendScreenshotPlus/src/mir_icolib.h5
-rw-r--r--plugins/SendScreenshotPlus/src/resource.h19
9 files changed, 115 insertions, 29 deletions
diff --git a/plugins/SendScreenshotPlus/src/CSend.cpp b/plugins/SendScreenshotPlus/src/CSend.cpp
index 7de9574cf6..b79fd340cd 100644
--- a/plugins/SendScreenshotPlus/src/CSend.cpp
+++ b/plugins/SendScreenshotPlus/src/CSend.cpp
@@ -27,6 +27,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#include "global.h"
+#define CSEND_DIALOG 8800
//---------------------------------------------------------------------------
CSend::CSend(HWND /*Owner*/, MCONTACT hContact, bool bAsync, bool bSilent) :
@@ -35,6 +36,8 @@ CSend::CSend(HWND /*Owner*/, MCONTACT hContact, bool bAsync, bool bSilent) :
m_bSilent(bSilent),
m_pszFile(NULL),
m_pszFileDesc(NULL),
+ m_URL(NULL),
+ m_URLthumb(NULL),
m_pszSendTyp(NULL),
m_pszProto(NULL),
// m_hContact(hContact), // initialized below
@@ -54,6 +57,8 @@ CSend::CSend(HWND /*Owner*/, MCONTACT hContact, bool bAsync, bool bSilent) :
CSend::~CSend(){
mir_free(m_pszFile);
mir_free(m_pszFileDesc);
+ mir_free(m_URL);
+ mir_free(m_URLthumb);
mir_free(m_szEventMsg);
mir_free(m_ErrorMsg);
mir_free(m_ErrorTitle);
@@ -88,19 +93,80 @@ INT_PTR CALLBACK CSend::ResultDialogProc(HWND hwndDlg,UINT uMsg,WPARAM wParam,LP
mir_tcsadd(tmp,self->m_pszSendTyp);
SetDlgItemText(hwndDlg,IDC_HEADERBAR,tmp);
mir_free(tmp);
- SendMessage(GetDlgItem(hwndDlg,IDC_HEADERBAR),WM_SETICON,ICON_BIG,(LPARAM)Skin_GetIcon(ICO_COMMON_ARROWR,1));
- SetDlgItemText(hwndDlg,ID_edtURL,self->m_ErrorTitle);
- if(self->m_pszFileDesc)
+ SendDlgItemMessage(hwndDlg,IDC_HEADERBAR,WM_SETICON,ICON_BIG,(LPARAM)Skin_GetIcon(ICO_COMMON_ARROWR,1));
+ SetDlgItemTextA(hwndDlg,ID_edtURL,self->m_URL);
+ if(self->m_URLthumb){
+ SetDlgItemTextA(hwndDlg,ID_edtURLthumb,self->m_URLthumb);
+ }else{
+ SetDlgItemTextA(hwndDlg,ID_edtURLthumb,"-");
+ for(int i=ID_btnThumbCopy; i<=ID_edtURLthumb; ++i){
+ EnableWindow(GetDlgItem(hwndDlg,i),FALSE);
+ }
+ }
+ if(!self->m_pszFileDesc)
+ SetDlgItemText(hwndDlg,ID_bvlDesc,self->m_ErrorTitle);
+ else
SetDlgItemText(hwndDlg,ID_bvlDesc,self->m_pszFileDesc);
- SendMessage(GetDlgItem(hwndDlg,IDOK),BUTTONSETDEFAULT,1,NULL);
- SendMessage(GetDlgItem(hwndDlg,IDOK),BM_SETIMAGE,IMAGE_ICON,(LPARAM)Skin_GetIcon(ICO_BTN_EDIT));
- SendMessage(GetDlgItem(hwndDlg,IDCANCEL),BM_SETIMAGE,IMAGE_ICON,(LPARAM)Skin_GetIcon(ICO_BTN_CANCEL));
+ SendDlgItemMessage(hwndDlg,IDOK,BM_SETIMAGE,IMAGE_ICON,(LPARAM)Skin_GetIcon(ICO_BTN_COPY));
+ SendDlgItemMessage(hwndDlg,IDOK,BUTTONTRANSLATE,0,0);
+ SendDlgItemMessage(hwndDlg,IDCANCEL,BM_SETIMAGE,IMAGE_ICON,(LPARAM)Skin_GetIcon(ICO_BTN_CANCEL));
+ SendDlgItemMessage(hwndDlg,IDCANCEL,BUTTONTRANSLATE,0,0);
+ for(int i=ID_btnCopy; i<=ID_btnThumbBBC2; ++i){
+ SendDlgItemMessage(hwndDlg,i,BUTTONSETASTHEMEDBTN,0,0);
+ SendDlgItemMessage(hwndDlg,i,BUTTONSETASFLATBTN,1,0);
+ switch(i){
+ case ID_btnCopy:
+ case ID_btnThumbCopy:
+ SendDlgItemMessage(hwndDlg,i,BM_SETIMAGE,IMAGE_ICON,(LPARAM)Skin_GetIcon(ICO_BTN_COPY));
+ SendDlgItemMessage(hwndDlg,i,BUTTONADDTOOLTIP,(WPARAM)LPGENT("Copy"),BATF_TCHAR);
+ break;
+ case ID_btnBBC:
+ case ID_btnThumbBBC:
+ SendDlgItemMessage(hwndDlg,i,BM_SETIMAGE,IMAGE_ICON,(LPARAM)Skin_GetIcon(ICO_BTN_BBC));
+ SendDlgItemMessage(hwndDlg,i,BUTTONADDTOOLTIP,(WPARAM)LPGENT("Copy BBCode"),BATF_TCHAR);
+ break;
+ default:
+ SendDlgItemMessage(hwndDlg,i,BM_SETIMAGE,IMAGE_ICON,(LPARAM)Skin_GetIcon(ICO_BTN_BBC2));
+ SendDlgItemMessage(hwndDlg,i,BUTTONADDTOOLTIP,(WPARAM)LPGENT("Copy BBCode w/ link"),BATF_TCHAR);
+ }
+ }
+ TranslateDialogDefault(hwndDlg);
return TRUE;}
case WM_COMMAND:
switch(LOWORD(wParam)) {
- case IDOK:{
- TCHAR tmp[1024];
- size_t len=GetDlgItemText(hwndDlg,ID_edtURL,tmp,1024);
+ case IDOK:
+ case ID_btnCopy:
+ case ID_btnThumbCopy:
+ case ID_btnBBC:
+ case ID_btnThumbBBC:
+ case ID_btnThumbBBC2:{
+ TCHAR tmp[2048];
+ int edtID=ID_edtURL;
+ int bbc=0;
+ switch(LOWORD(wParam)){
+ case ID_btnThumbBBC2: ++bbc;
+ case ID_btnThumbBBC: ++bbc;
+ case ID_btnThumbCopy:
+ edtID=ID_edtURLthumb;
+ break;
+ case ID_btnBBC: ++bbc;
+ break;
+ }
+ size_t len;
+ if(bbc){
+ if(bbc==1){
+ memcpy(tmp,_T("[img]"),5*sizeof(TCHAR)); len=5;
+ len+=GetDlgItemText(hwndDlg,edtID,tmp+len,2048-11);
+ memcpy(tmp+len,_T("[/img]"),7*sizeof(TCHAR)); len+=7;
+ }else{
+ memcpy(tmp,_T("[url="),5*sizeof(TCHAR)); len=5;
+ len+=GetDlgItemText(hwndDlg,ID_edtURL,tmp+len,1024);
+ memcpy(tmp+len,_T("][img]"),6*sizeof(TCHAR)); len+=6;
+ len+=GetDlgItemText(hwndDlg,edtID,tmp+len,1024);
+ memcpy(tmp+len,_T("[/img][/url]"),13*sizeof(TCHAR)); len+=12;
+ }
+ }else
+ len=GetDlgItemText(hwndDlg,edtID,tmp,2048);
int retries=3;
do{
if(!OpenClipboard(hwndDlg)){
@@ -116,7 +182,8 @@ INT_PTR CALLBACK CSend::ResultDialogProc(HWND hwndDlg,UINT uMsg,WPARAM wParam,LP
CloseClipboard();
break;
}while(--retries);
- DestroyWindow(hwndDlg);
+ if(LOWORD(wParam)==IDOK)
+ DestroyWindow(hwndDlg);
return TRUE;}
case IDCANCEL:
DestroyWindow(hwndDlg);
@@ -130,9 +197,9 @@ void CSend::svcSendMsgExit(const char* szMessage) {
Exit(ACKRESULT_SUCCESS); return;
}
if(!m_hContact){
- mir_free(m_ErrorTitle), m_ErrorTitle=mir_a2t(szMessage);
- DialogBoxParam(hInst, MAKEINTRESOURCE(IDD_UResultForm),0, ResultDialogProc,(LPARAM)this);
- Exit(ACKRESULT_SUCCESS); return;
+ if(!m_pszFileDesc)
+ m_pszFileDesc=mir_a2t(szMessage);
+ Exit(CSEND_DIALOG); return;
}
if(m_ChatRoom){
TCHAR* tmp = mir_a2t(szMessage);
@@ -339,6 +406,11 @@ void CSend::Exit(unsigned int Result) {
if(!m_bSilent){
bool err = true;
switch(Result) {
+ case CSEND_DIALOG:
+ SkinPlaySound("FileDone");
+ DialogBoxParam(hInst, MAKEINTRESOURCE(IDD_UResultForm),0, ResultDialogProc,(LPARAM)this);
+ err = false;
+ break;
case ACKRESULT_SUCCESS:
case GC_RESULT_SUCCESS:
SkinPlaySound("FileDone");
diff --git a/plugins/SendScreenshotPlus/src/CSend.h b/plugins/SendScreenshotPlus/src/CSend.h
index 63047b7fd3..77b0d677e9 100644
--- a/plugins/SendScreenshotPlus/src/CSend.h
+++ b/plugins/SendScreenshotPlus/src/CSend.h
@@ -58,6 +58,8 @@ class CSend {
void SetFile(char* file){mir_free(m_pszFile), m_pszFile=mir_a2t(file);};
void SetDescription(TCHAR* descr){mir_free(m_pszFileDesc), m_pszFileDesc=mir_tstrdup(descr);};
void SetContact(MCONTACT hContact);
+ char* GetURL(){return m_URL;};
+ char* GetURLthumbnail(){return m_URLthumb;};
BYTE GetEnableItem() {return m_EnableItem;};
TCHAR* GetErrorMsg() {return m_ErrorMsg;};
@@ -67,6 +69,8 @@ class CSend {
bool m_bSilent;
TCHAR* m_pszFile;
TCHAR* m_pszFileDesc;
+ char* m_URL;
+ char* m_URLthumb;
static int OnSend(void *obj, WPARAM wParam, LPARAM lParam);
TCHAR* m_pszSendTyp; //hold string for error mess
char* m_pszProto; //Contact Proto Modul
diff --git a/plugins/SendScreenshotPlus/src/CSendFTPFile.cpp b/plugins/SendScreenshotPlus/src/CSendFTPFile.cpp
index b52a3925e8..407a63a734 100644
--- a/plugins/SendScreenshotPlus/src/CSendFTPFile.cpp
+++ b/plugins/SendScreenshotPlus/src/CSendFTPFile.cpp
@@ -36,12 +36,10 @@ CSendFTPFile::CSendFTPFile(HWND Owner, MCONTACT hContact, bool /*bAsync*/)
m_EnableItem = 0 ; //SS_DLG_DESCRIPTION | SS_DLG_AUTOSEND | SS_DLG_DELETEAFTERSSEND;
m_pszSendTyp = LPGENT("FTPFile transfer");
m_pszFileName = NULL;
- m_URL = NULL;
}
CSendFTPFile::~CSendFTPFile(){
mir_free(m_pszFileName);
- mir_free(m_URL);
}
//---------------------------------------------------------------------------
@@ -70,7 +68,6 @@ int CSendFTPFile::Send()
}
void CSendFTPFile::SendThread() {
- mir_freeAndNil(m_URL);
INT_PTR ret = FTPFileUploadA(m_hContact, FNUM_DEFAULT, FMODE_RAWFILE, &m_pszFileName,1);
if (ret != 0) {
@@ -81,7 +78,7 @@ void CSendFTPFile::SendThread() {
//Can't delete the file since FTP File plugin will use it
m_bDeleteAfterSend = false;
- if (m_URL && m_URL[0]!= NULL) {
+ if (m_URL && *m_URL) {/// @fixme : m_URL never set
svcSendMsgExit(m_URL); return;
}
Exit(ACKRESULT_FAILED);
diff --git a/plugins/SendScreenshotPlus/src/CSendFTPFile.h b/plugins/SendScreenshotPlus/src/CSendFTPFile.h
index fb70249f1c..c5c64d1bba 100644
--- a/plugins/SendScreenshotPlus/src/CSendFTPFile.h
+++ b/plugins/SendScreenshotPlus/src/CSendFTPFile.h
@@ -40,7 +40,6 @@ class CSendFTPFile : public CSend {
protected:
char* m_pszFileName;
- char* m_URL;
void SendThread();
static void SendThreadWrapper(void * Obj);
};
diff --git a/plugins/SendScreenshotPlus/src/CSendHTTPServer.cpp b/plugins/SendScreenshotPlus/src/CSendHTTPServer.cpp
index cc705ba0e0..e0726c82e1 100644
--- a/plugins/SendScreenshotPlus/src/CSendHTTPServer.cpp
+++ b/plugins/SendScreenshotPlus/src/CSendHTTPServer.cpp
@@ -39,14 +39,12 @@ CSendHTTPServer::CSendHTTPServer(HWND Owner, MCONTACT hContact, bool /*bAsync*/)
m_EnableItem = SS_DLG_DESCRIPTION ; //| SS_DLG_AUTOSEND | SS_DLG_DELETEAFTERSSEND;
m_pszSendTyp = LPGENT("HTTPServer transfer");
m_pszFileName = NULL;
- m_URL = NULL;
m_fsi_pszSrvPath = NULL;
m_fsi_pszRealPath = NULL;
}
CSendHTTPServer::~CSendHTTPServer(){
mir_free(m_pszFileName);
- mir_free(m_URL);
mir_free(m_fsi_pszSrvPath);
mir_free(m_fsi_pszRealPath);
}
@@ -85,12 +83,12 @@ int CSendHTTPServer::Send()
void CSendHTTPServer::SendThread() {
INT_PTR ret;
- mir_freeAndNil(m_URL);
if (ServiceExists(MS_HTTP_GET_LINK)) {
//patched plugin version
ret = CallService(MS_HTTP_ADD_CHANGE_REMOVE, (WPARAM)m_hContact, (LPARAM)&m_fsi);
if (!ret) {
+ mir_free(m_URL);
m_URL = (char*)CallService(MS_HTTP_GET_LINK, (WPARAM)m_fsi.pszSrvPath, NULL);
}
}
@@ -110,7 +108,7 @@ void CSendHTTPServer::SendThread() {
//Share the file by HTTP Server plugin, SendSS does not own the file anymore = auto-delete won't work
m_bDeleteAfterSend = false;
- if (m_URL && m_URL[0]!= NULL) {
+ if (m_URL && *m_URL) {
svcSendMsgExit(m_URL); return;
}
Exit(ACKRESULT_FAILED);
diff --git a/plugins/SendScreenshotPlus/src/CSendHTTPServer.h b/plugins/SendScreenshotPlus/src/CSendHTTPServer.h
index 5b62896739..d3070806a9 100644
--- a/plugins/SendScreenshotPlus/src/CSendHTTPServer.h
+++ b/plugins/SendScreenshotPlus/src/CSendHTTPServer.h
@@ -40,7 +40,6 @@ class CSendHTTPServer : public CSend {
protected:
char* m_pszFileName;
- char* m_URL;
STFileShareInfo m_fsi;
char* m_fsi_pszSrvPath;
char* m_fsi_pszRealPath;
diff --git a/plugins/SendScreenshotPlus/src/mir_icolib.cpp b/plugins/SendScreenshotPlus/src/mir_icolib.cpp
index e4f198081a..61e61f9c6e 100644
--- a/plugins/SendScreenshotPlus/src/mir_icolib.cpp
+++ b/plugins/SendScreenshotPlus/src/mir_icolib.cpp
@@ -63,7 +63,10 @@ static ICODESC icoDesc[] =
{ ICO_BTN_OK, LPGEN("OK"), SECT_BUTTONS, IDI_OK, 0 },
{ ICO_BTN_CANCEL, LPGEN("Cancel"), SECT_BUTTONS, IDI_CLOSE, 0 },
// { ICO_BTN_APPLY, LPGEN("Apply"), SECT_BUTTONS, IDI_APPLY, 0 },
- { ICO_BTN_EDIT, LPGEN("Edit"), SECT_BUTTONS, IDI_EDIT, 0 },
+// { ICO_BTN_EDIT, LPGEN("Edit"), SECT_BUTTONS, IDI_EDIT, 0 },
+ { ICO_BTN_COPY, LPGEN("Copy"), SECT_BUTTONS, IDI_COPY, 0 },
+ { ICO_BTN_BBC, LPGEN("BBC"), SECT_BUTTONS, IDI_BBC, 0 },
+ { ICO_BTN_BBC2, LPGEN("BBC link"), SECT_BUTTONS, IDI_BBC2, 0 },
{ ICO_BTN_DOWNARROW, LPGEN("Down arrow"), SECT_BUTTONS, IDI_DOWNARROW, 0 },
};
diff --git a/plugins/SendScreenshotPlus/src/mir_icolib.h b/plugins/SendScreenshotPlus/src/mir_icolib.h
index bd026b3875..3176047f3d 100644
--- a/plugins/SendScreenshotPlus/src/mir_icolib.h
+++ b/plugins/SendScreenshotPlus/src/mir_icolib.h
@@ -48,7 +48,10 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#define ICO_BTN_OK MODNAME"_plug_ok"
#define ICO_BTN_CANCEL MODNAME"_plug_cancel"
//#define ICO_BTN_APPLY MODNAME"_plug_apply"
-#define ICO_BTN_EDIT MODNAME"_plug_edit"
+//#define ICO_BTN_EDIT MODNAME"_plug_edit"
+#define ICO_BTN_COPY MODNAME"_plug_copy"
+#define ICO_BTN_BBC MODNAME"_plug_bbc"
+#define ICO_BTN_BBC2 MODNAME"_plug_bbclnk"
#define ICO_BTN_DOWNARROW MODNAME"_plug_downarrow"
//#define ICO_BTN_OVERLAYOFF MODNAME"_plug_SSOverlayOff"
diff --git a/plugins/SendScreenshotPlus/src/resource.h b/plugins/SendScreenshotPlus/src/resource.h
index 572372d490..0385d53f00 100644
--- a/plugins/SendScreenshotPlus/src/resource.h
+++ b/plugins/SendScreenshotPlus/src/resource.h
@@ -5,9 +5,9 @@
#define IDOK 1
#define IDA_btnClose 1
#define IDCANCEL 2
-#define IDB_Bmp1 2
+//#define IDB_Bmp1 2
#define IDABORT 3
-#define IDB_Bmp2 3
+//#define IDB_Bmp2 3
#define IDRETRY 4
#define IDIGNORE 5
#define IDYES 6
@@ -45,8 +45,11 @@
#define IDI_OK 205
#define IDI_CLOSE 206
//#define IDI_APPLY 207
-#define IDI_EDIT 208
-#define IDI_DOWNARROW 210
+//#define IDI_EDIT 208
+#define IDI_COPY 209
+#define IDI_BBC 210
+#define IDI_BBC2 211
+#define IDI_DOWNARROW 212
#define IDC_CAPTURETAB 1005
#define IDC_CREDIT 1009
#define STATIC_WHITERECT 1100
@@ -91,6 +94,14 @@
#define ID_btnCapture 2005
#define ID_edtURL 2010
#define ID_bvlDesc 2011
+#define ID_bvlLine 2012
+#define ID_btnCopy 2013//group I
+#define ID_btnBBC 2014
+#define ID_btnThumbCopy 2015//group II
+#define ID_btnThumbBBC 2016
+#define ID_btnThumbBBC2 2017//end group I
+#define ID_edtURLthumbLabel 2018
+#define ID_edtURLthumb 2019//end group II
#define IDE_StatusBar 2501
// Next default values for new objects