Revert "Add type cast definitions for CPDF_Dictionary."
[pdfium.git] / fpdfsdk / src / fsdk_mgr.cpp
1 // Copyright 2014 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6
7 #include "../../public/fpdf_ext.h"
8 #include "../../third_party/base/nonstd_unique_ptr.h"
9 #include "../include/formfiller/FFL_FormFiller.h"
10 #include "../include/fsdk_define.h"
11 #include "../include/fsdk_mgr.h"
12 #include "../include/javascript/IJavaScript.h"
13
14 #if _FX_OS_ == _FX_ANDROID_
15 #include "time.h"
16 #else
17 #include <ctime>
18 #endif
19
20 class CFX_SystemHandler : public IFX_SystemHandler {
21  public:
22   CFX_SystemHandler(CPDFDoc_Environment* pEnv) : m_pEnv(pEnv), m_nCharSet(-1) {}
23   ~CFX_SystemHandler() override {}
24
25  public:
26   // IFX_SystemHandler
27   void InvalidateRect(FX_HWND hWnd, FX_RECT rect) override;
28   void OutputSelectedRect(void* pFormFiller, CPDF_Rect& rect) override;
29   FX_BOOL IsSelectionImplemented() override;
30   CFX_WideString GetClipboardText(FX_HWND hWnd) override { return L""; }
31   FX_BOOL SetClipboardText(FX_HWND hWnd, CFX_WideString string) override {
32     return FALSE;
33   }
34   void ClientToScreen(FX_HWND hWnd, int32_t& x, int32_t& y) override {}
35   void ScreenToClient(FX_HWND hWnd, int32_t& x, int32_t& y) override {}
36   void SetCursor(int32_t nCursorType) override;
37   FX_HMENU CreatePopupMenu() override { return NULL; }
38   FX_BOOL AppendMenuItem(FX_HMENU hMenu,
39                          int32_t nIDNewItem,
40                          CFX_WideString string) override {
41     return FALSE;
42   }
43   FX_BOOL EnableMenuItem(FX_HMENU hMenu,
44                          int32_t nIDItem,
45                          FX_BOOL bEnabled) override {
46     return FALSE;
47   }
48   int32_t TrackPopupMenu(FX_HMENU hMenu,
49                          int32_t x,
50                          int32_t y,
51                          FX_HWND hParent) override {
52     return -1;
53   }
54   void DestroyMenu(FX_HMENU hMenu) override {}
55   CFX_ByteString GetNativeTrueTypeFont(int32_t nCharset) override;
56   FX_BOOL FindNativeTrueTypeFont(int32_t nCharset,
57                                  CFX_ByteString sFontFaceName) override;
58   CPDF_Font* AddNativeTrueTypeFontToPDF(CPDF_Document* pDoc,
59                                         CFX_ByteString sFontFaceName,
60                                         uint8_t nCharset) override;
61   int32_t SetTimer(int32_t uElapse, TimerCallback lpTimerFunc) override;
62   void KillTimer(int32_t nID) override;
63   FX_BOOL IsSHIFTKeyDown(FX_DWORD nFlag) override {
64     return m_pEnv->FFI_IsSHIFTKeyDown(nFlag);
65   }
66   FX_BOOL IsCTRLKeyDown(FX_DWORD nFlag) override {
67     return m_pEnv->FFI_IsCTRLKeyDown(nFlag);
68   }
69   FX_BOOL IsALTKeyDown(FX_DWORD nFlag) override {
70     return m_pEnv->FFI_IsALTKeyDown(nFlag);
71   }
72   FX_BOOL IsINSERTKeyDown(FX_DWORD nFlag) override {
73     return m_pEnv->FFI_IsINSERTKeyDown(nFlag);
74   }
75   FX_SYSTEMTIME GetLocalTime() override;
76   int32_t GetCharSet() override { return m_nCharSet; }
77   void SetCharSet(int32_t nCharSet) override { m_nCharSet = nCharSet; }
78
79  private:
80   CPDFDoc_Environment* m_pEnv;
81   int m_nCharSet;
82 };
83
84 void CFX_SystemHandler::SetCursor(int32_t nCursorType) {
85   m_pEnv->FFI_SetCursor(nCursorType);
86 }
87
88 void CFX_SystemHandler::InvalidateRect(FX_HWND hWnd, FX_RECT rect) {
89   // g_pFormFillApp->FFI_Invalidate();
90   CPDFSDK_Annot* pSDKAnnot = (CPDFSDK_Annot*)hWnd;
91   CPDF_Page* pPage = NULL;
92   CPDFSDK_PageView* pPageView = NULL;
93   pPageView = pSDKAnnot->GetPageView();
94   pPage = pSDKAnnot->GetPDFPage();
95   if (!pPage || !pPageView)
96     return;
97   CPDF_Matrix page2device;
98   pPageView->GetCurrentMatrix(page2device);
99   CPDF_Matrix device2page;
100   device2page.SetReverse(page2device);
101   FX_FLOAT left, top, right, bottom;
102   device2page.Transform((FX_FLOAT)rect.left, (FX_FLOAT)rect.top, left, top);
103   device2page.Transform((FX_FLOAT)rect.right, (FX_FLOAT)rect.bottom, right,
104                         bottom);
105   //  m_pEnv->FFI_DeviceToPage(pPage, rect.left, rect.top, (double*)&left,
106   //  (double*)&top);
107   //  m_pEnv->FFI_DeviceToPage(pPage, rect.right, rect.bottom, (double*)&right,
108   //  (double*)&bottom);
109   CPDF_Rect rcPDF(left, bottom, right, top);
110   rcPDF.Normalize();
111
112   m_pEnv->FFI_Invalidate(pPage, rcPDF.left, rcPDF.top, rcPDF.right,
113                          rcPDF.bottom);
114 }
115 void CFX_SystemHandler::OutputSelectedRect(void* pFormFiller, CPDF_Rect& rect) {
116   CFFL_FormFiller* pFFL = (CFFL_FormFiller*)pFormFiller;
117   if (pFFL) {
118     CPDF_Point leftbottom = CPDF_Point(rect.left, rect.bottom);
119     CPDF_Point righttop = CPDF_Point(rect.right, rect.top);
120     CPDF_Point ptA = pFFL->PWLtoFFL(leftbottom);
121     CPDF_Point ptB = pFFL->PWLtoFFL(righttop);
122
123     CPDFSDK_Annot* pAnnot = pFFL->GetSDKAnnot();
124     ASSERT(pAnnot);
125     CPDF_Page* pPage = pAnnot->GetPDFPage();
126     ASSERT(pPage);
127     m_pEnv->FFI_OutputSelectedRect(pPage, ptA.x, ptB.y, ptB.x, ptA.y);
128   }
129 }
130
131 FX_BOOL CFX_SystemHandler::IsSelectionImplemented() {
132   if (m_pEnv) {
133     FPDF_FORMFILLINFO* pInfo = m_pEnv->GetFormFillInfo();
134     if (pInfo && pInfo->FFI_OutputSelectedRect)
135       return TRUE;
136   }
137   return FALSE;
138 }
139
140 CFX_ByteString CFX_SystemHandler::GetNativeTrueTypeFont(int32_t nCharset) {
141   return "";
142 }
143
144 FX_BOOL CFX_SystemHandler::FindNativeTrueTypeFont(
145     int32_t nCharset,
146     CFX_ByteString sFontFaceName) {
147   CFX_FontMgr* pFontMgr = CFX_GEModule::Get()->GetFontMgr();
148   if (!pFontMgr)
149     return FALSE;
150
151   CFX_FontMapper* pFontMapper = pFontMgr->GetBuiltinMapper();
152   if (!pFontMapper)
153     return FALSE;
154
155   int nSize = pFontMapper->m_InstalledTTFonts.GetSize();
156   if (nSize == 0) {
157     pFontMapper->LoadInstalledFonts();
158     nSize = pFontMapper->m_InstalledTTFonts.GetSize();
159   }
160
161   for (int i = 0; i < nSize; ++i) {
162     if (pFontMapper->m_InstalledTTFonts[i].Compare(sFontFaceName))
163       return TRUE;
164   }
165
166   return FALSE;
167 }
168
169 static int CharSet2CP(int charset) {
170   if (charset == 128)
171     return 932;
172   if (charset == 134)
173     return 936;
174   if (charset == 129)
175     return 949;
176   if (charset == 136)
177     return 950;
178   return 0;
179 }
180 CPDF_Font* CFX_SystemHandler::AddNativeTrueTypeFontToPDF(
181     CPDF_Document* pDoc,
182     CFX_ByteString sFontFaceName,
183     uint8_t nCharset) {
184   if (pDoc) {
185     CFX_Font* pFXFont = new CFX_Font();
186     pFXFont->LoadSubst(sFontFaceName, TRUE, 0, 0, 0, CharSet2CP(nCharset),
187                        FALSE);
188     CPDF_Font* pFont = pDoc->AddFont(pFXFont, nCharset, FALSE);
189     delete pFXFont;
190     return pFont;
191   }
192
193   return NULL;
194 }
195
196 int32_t CFX_SystemHandler::SetTimer(int32_t uElapse,
197                                     TimerCallback lpTimerFunc) {
198   return m_pEnv->FFI_SetTimer(uElapse, lpTimerFunc);
199 }
200 void CFX_SystemHandler::KillTimer(int32_t nID) {
201   m_pEnv->FFI_KillTimer(nID);
202 }
203
204 FX_SYSTEMTIME CFX_SystemHandler::GetLocalTime() {
205   return m_pEnv->FFI_GetLocalTime();
206 }
207
208 CPDFDoc_Environment::CPDFDoc_Environment(CPDF_Document* pDoc,
209                                          FPDF_FORMFILLINFO* pFFinfo)
210     : m_pAnnotHandlerMgr(NULL),
211       m_pActionHandler(NULL),
212       m_pInfo(pFFinfo),
213       m_pSDKDoc(NULL),
214       m_pPDFDoc(pDoc),
215       m_pIFormFiller(NULL) {
216   m_pSysHandler = new CFX_SystemHandler(this);
217 }
218
219 CPDFDoc_Environment::~CPDFDoc_Environment() {
220   delete m_pIFormFiller;
221   m_pIFormFiller = NULL;
222
223   delete m_pSysHandler;
224   m_pSysHandler = NULL;
225
226   delete m_pAnnotHandlerMgr;
227   m_pAnnotHandlerMgr = NULL;
228
229   delete m_pActionHandler;
230   m_pActionHandler = NULL;
231 }
232
233 int CPDFDoc_Environment::JS_appAlert(const FX_WCHAR* Msg,
234                                      const FX_WCHAR* Title,
235                                      FX_UINT Type,
236                                      FX_UINT Icon) {
237   if (m_pInfo && m_pInfo->m_pJsPlatform && m_pInfo->m_pJsPlatform->app_alert) {
238     CFX_ByteString bsMsg = CFX_WideString(Msg).UTF16LE_Encode();
239     CFX_ByteString bsTitle = CFX_WideString(Title).UTF16LE_Encode();
240     FPDF_WIDESTRING pMsg = (FPDF_WIDESTRING)bsMsg.GetBuffer(bsMsg.GetLength());
241     FPDF_WIDESTRING pTitle =
242         (FPDF_WIDESTRING)bsTitle.GetBuffer(bsTitle.GetLength());
243     int ret = m_pInfo->m_pJsPlatform->app_alert(m_pInfo->m_pJsPlatform, pMsg,
244                                                 pTitle, Type, Icon);
245     bsMsg.ReleaseBuffer();
246     bsTitle.ReleaseBuffer();
247     return ret;
248   }
249   return -1;
250 }
251
252 int CPDFDoc_Environment::JS_appResponse(const FX_WCHAR* Question,
253                                         const FX_WCHAR* Title,
254                                         const FX_WCHAR* Default,
255                                         const FX_WCHAR* cLabel,
256                                         FPDF_BOOL bPassword,
257                                         void* response,
258                                         int length) {
259   if (m_pInfo && m_pInfo->m_pJsPlatform &&
260       m_pInfo->m_pJsPlatform->app_response) {
261     CFX_ByteString bsQuestion = CFX_WideString(Question).UTF16LE_Encode();
262     CFX_ByteString bsTitle = CFX_WideString(Title).UTF16LE_Encode();
263     CFX_ByteString bsDefault = CFX_WideString(Default).UTF16LE_Encode();
264     CFX_ByteString bsLabel = CFX_WideString(cLabel).UTF16LE_Encode();
265     FPDF_WIDESTRING pQuestion =
266         (FPDF_WIDESTRING)bsQuestion.GetBuffer(bsQuestion.GetLength());
267     FPDF_WIDESTRING pTitle =
268         (FPDF_WIDESTRING)bsTitle.GetBuffer(bsTitle.GetLength());
269     FPDF_WIDESTRING pDefault =
270         (FPDF_WIDESTRING)bsDefault.GetBuffer(bsDefault.GetLength());
271     FPDF_WIDESTRING pLabel =
272         (FPDF_WIDESTRING)bsLabel.GetBuffer(bsLabel.GetLength());
273     int ret = m_pInfo->m_pJsPlatform->app_response(
274         m_pInfo->m_pJsPlatform, pQuestion, pTitle, pDefault, pLabel, bPassword,
275         response, length);
276     bsQuestion.ReleaseBuffer();
277     bsTitle.ReleaseBuffer();
278     bsDefault.ReleaseBuffer();
279     bsLabel.ReleaseBuffer();
280     return ret;
281   }
282   return -1;
283 }
284
285 CFX_WideString CPDFDoc_Environment::JS_fieldBrowse() {
286   if (!m_pInfo || !m_pInfo->m_pJsPlatform ||
287       !m_pInfo->m_pJsPlatform->Field_browse) {
288     return L"";
289   }
290
291   const int nRequiredLen =
292       m_pInfo->m_pJsPlatform->Field_browse(m_pInfo->m_pJsPlatform, nullptr, 0);
293   if (nRequiredLen <= 0)
294     return L"";
295
296   nonstd::unique_ptr<char[]> pBuff(new char[nRequiredLen]);
297   memset(pBuff.get(), 0, nRequiredLen);
298   const int nActualLen = m_pInfo->m_pJsPlatform->Field_browse(
299       m_pInfo->m_pJsPlatform, pBuff.get(), nRequiredLen);
300   if (nActualLen <= 0 || nActualLen > nRequiredLen)
301     return L"";
302
303   CFX_ByteString bsRet = CFX_ByteString(pBuff.get(), nActualLen);
304   CFX_WideString wsRet = CFX_WideString::FromLocal(bsRet);
305   return wsRet;
306 }
307
308 CFX_WideString CPDFDoc_Environment::JS_docGetFilePath() {
309   if (!m_pInfo || !m_pInfo->m_pJsPlatform ||
310       !m_pInfo->m_pJsPlatform->Doc_getFilePath) {
311     return L"";
312   }
313
314   const int nRequiredLen = m_pInfo->m_pJsPlatform->Doc_getFilePath(
315       m_pInfo->m_pJsPlatform, nullptr, 0);
316   if (nRequiredLen <= 0)
317     return L"";
318
319   nonstd::unique_ptr<char[]> pBuff(new char[nRequiredLen]);
320   memset(pBuff.get(), 0, nRequiredLen);
321   const int nActualLen = m_pInfo->m_pJsPlatform->Doc_getFilePath(
322       m_pInfo->m_pJsPlatform, pBuff.get(), nRequiredLen);
323   if (nActualLen <= 0 || nActualLen > nRequiredLen)
324     return L"";
325
326   CFX_ByteString bsRet = CFX_ByteString(pBuff.get(), nActualLen);
327   CFX_WideString wsRet = CFX_WideString::FromLocal(bsRet);
328   return wsRet;
329 }
330
331 void CPDFDoc_Environment::JS_docSubmitForm(void* formData,
332                                            int length,
333                                            const FX_WCHAR* URL) {
334   if (m_pInfo && m_pInfo->m_pJsPlatform &&
335       m_pInfo->m_pJsPlatform->Doc_submitForm) {
336     CFX_ByteString bsDestination = CFX_WideString(URL).UTF16LE_Encode();
337     FPDF_WIDESTRING pDestination =
338         (FPDF_WIDESTRING)bsDestination.GetBuffer(bsDestination.GetLength());
339     m_pInfo->m_pJsPlatform->Doc_submitForm(m_pInfo->m_pJsPlatform, formData,
340                                            length, pDestination);
341     bsDestination.ReleaseBuffer();
342   }
343 }
344
345 void CPDFDoc_Environment::JS_docmailForm(void* mailData,
346                                          int length,
347                                          FPDF_BOOL bUI,
348                                          const FX_WCHAR* To,
349                                          const FX_WCHAR* Subject,
350                                          const FX_WCHAR* CC,
351                                          const FX_WCHAR* BCC,
352                                          const FX_WCHAR* Msg) {
353   if (m_pInfo && m_pInfo->m_pJsPlatform && m_pInfo->m_pJsPlatform->Doc_mail) {
354     CFX_ByteString bsTo = CFX_WideString(To).UTF16LE_Encode();
355     CFX_ByteString bsCC = CFX_WideString(Subject).UTF16LE_Encode();
356     CFX_ByteString bsBcc = CFX_WideString(BCC).UTF16LE_Encode();
357     CFX_ByteString bsSubject = CFX_WideString(Subject).UTF16LE_Encode();
358     CFX_ByteString bsMsg = CFX_WideString(Msg).UTF16LE_Encode();
359     FPDF_WIDESTRING pTo = (FPDF_WIDESTRING)bsTo.GetBuffer(bsTo.GetLength());
360     FPDF_WIDESTRING pCC = (FPDF_WIDESTRING)bsCC.GetBuffer(bsCC.GetLength());
361     FPDF_WIDESTRING pBcc = (FPDF_WIDESTRING)bsBcc.GetBuffer(bsBcc.GetLength());
362     FPDF_WIDESTRING pSubject =
363         (FPDF_WIDESTRING)bsSubject.GetBuffer(bsSubject.GetLength());
364     FPDF_WIDESTRING pMsg = (FPDF_WIDESTRING)bsMsg.GetBuffer(bsMsg.GetLength());
365     m_pInfo->m_pJsPlatform->Doc_mail(m_pInfo->m_pJsPlatform, mailData, length,
366                                      bUI, pTo, pSubject, pCC, pBcc, pMsg);
367     bsTo.ReleaseBuffer();
368     bsCC.ReleaseBuffer();
369     bsBcc.ReleaseBuffer();
370     bsSubject.ReleaseBuffer();
371     bsMsg.ReleaseBuffer();
372   }
373 }
374
375 IJS_Runtime* CPDFDoc_Environment::GetJSRuntime() {
376   if (!IsJSInitiated())
377     return NULL;
378   if (!m_pJSRuntime)
379     m_pJSRuntime.reset(IJS_Runtime::Create(this));
380   return m_pJSRuntime.get();
381 }
382
383 CPDFSDK_AnnotHandlerMgr* CPDFDoc_Environment::GetAnnotHandlerMgr() {
384   if (!m_pAnnotHandlerMgr)
385     m_pAnnotHandlerMgr = new CPDFSDK_AnnotHandlerMgr(this);
386   return m_pAnnotHandlerMgr;
387 }
388
389 CPDFSDK_ActionHandler* CPDFDoc_Environment::GetActionHander() {
390   if (!m_pActionHandler)
391     m_pActionHandler = new CPDFSDK_ActionHandler();
392   return m_pActionHandler;
393 }
394
395 CFFL_IFormFiller* CPDFDoc_Environment::GetIFormFiller() {
396   if (!m_pIFormFiller)
397     m_pIFormFiller = new CFFL_IFormFiller(this);
398   return m_pIFormFiller;
399 }
400
401 CPDFSDK_Document::CPDFSDK_Document(CPDF_Document* pDoc,
402                                    CPDFDoc_Environment* pEnv)
403     : m_pDoc(pDoc),
404       m_pInterForm(nullptr),
405       m_pFocusAnnot(nullptr),
406       m_pEnv(pEnv),
407       m_pOccontent(nullptr),
408       m_bChangeMask(FALSE) {}
409
410 CPDFSDK_Document::~CPDFSDK_Document() {
411   for (auto& it : m_pageMap)
412     delete it.second;
413   m_pageMap.clear();
414
415   delete m_pInterForm;
416   m_pInterForm = nullptr;
417
418   delete m_pOccontent;
419   m_pOccontent = nullptr;
420 }
421
422 CPDFSDK_PageView* CPDFSDK_Document::GetPageView(CPDF_Page* pPDFPage,
423                                                 FX_BOOL ReNew) {
424   auto it = m_pageMap.find(pPDFPage);
425   if (it != m_pageMap.end())
426     return it->second;
427
428   if (!ReNew)
429     return nullptr;
430
431   CPDFSDK_PageView* pPageView = new CPDFSDK_PageView(this, pPDFPage);
432   m_pageMap[pPDFPage] = pPageView;
433   // Delay to load all the annotations, to avoid endless loop.
434   pPageView->LoadFXAnnots();
435   return pPageView;
436 }
437
438 CPDFSDK_PageView* CPDFSDK_Document::GetCurrentView() {
439   CPDF_Page* pPage = (CPDF_Page*)m_pEnv->FFI_GetCurrentPage(m_pDoc);
440   return pPage ? GetPageView(pPage, TRUE) : nullptr;
441 }
442
443 CPDFSDK_PageView* CPDFSDK_Document::GetPageView(int nIndex) {
444   CPDF_Page* pTempPage = (CPDF_Page*)m_pEnv->FFI_GetPage(m_pDoc, nIndex);
445   if (!pTempPage)
446     return nullptr;
447
448   auto it = m_pageMap.find(pTempPage);
449   return it->second;
450 }
451
452 void CPDFSDK_Document::ProcJavascriptFun() {
453   CPDF_Document* pPDFDoc = GetDocument();
454   CPDF_DocJSActions docJS(pPDFDoc);
455   int iCount = docJS.CountJSActions();
456   if (iCount < 1)
457     return;
458   for (int i = 0; i < iCount; i++) {
459     CFX_ByteString csJSName;
460     CPDF_Action jsAction = docJS.GetJSAction(i, csJSName);
461     if (m_pEnv->GetActionHander())
462       m_pEnv->GetActionHander()->DoAction_JavaScript(
463           jsAction, CFX_WideString::FromLocal(csJSName), this);
464   }
465 }
466
467 FX_BOOL CPDFSDK_Document::ProcOpenAction() {
468   if (!m_pDoc)
469     return FALSE;
470
471   CPDF_Dictionary* pRoot = m_pDoc->GetRoot();
472   if (!pRoot)
473     return FALSE;
474
475   CPDF_Object* pOpenAction = pRoot->GetDict("OpenAction");
476   if (!pOpenAction)
477     pOpenAction = pRoot->GetArray("OpenAction");
478
479   if (!pOpenAction)
480     return FALSE;
481
482   if (pOpenAction->GetType() == PDFOBJ_ARRAY)
483     return TRUE;
484
485   if (pOpenAction->GetType() == PDFOBJ_DICTIONARY) {
486     CPDF_Dictionary* pDict = (CPDF_Dictionary*)pOpenAction;
487     CPDF_Action action(pDict);
488     if (m_pEnv->GetActionHander())
489       m_pEnv->GetActionHander()->DoAction_DocOpen(action, this);
490     return TRUE;
491   }
492   return FALSE;
493 }
494
495 CPDF_OCContext* CPDFSDK_Document::GetOCContext() {
496   if (!m_pOccontent)
497     m_pOccontent = new CPDF_OCContext(m_pDoc);
498   return m_pOccontent;
499 }
500
501 void CPDFSDK_Document::ReMovePageView(CPDF_Page* pPDFPage) {
502   auto it = m_pageMap.find(pPDFPage);
503   if (it == m_pageMap.end())
504     return;
505
506   CPDFSDK_PageView* pPageView = it->second;
507   if (pPageView->IsLocked())
508     return;
509
510   delete pPageView;
511   m_pageMap.erase(it);
512 }
513
514 CPDF_Page* CPDFSDK_Document::GetPage(int nIndex) {
515   CPDF_Page* pTempPage = (CPDF_Page*)m_pEnv->FFI_GetPage(m_pDoc, nIndex);
516   if (!pTempPage)
517     return NULL;
518   return pTempPage;
519 }
520
521 CPDFSDK_InterForm* CPDFSDK_Document::GetInterForm() {
522   if (!m_pInterForm)
523     m_pInterForm = new CPDFSDK_InterForm(this);
524   return m_pInterForm;
525 }
526
527 void CPDFSDK_Document::UpdateAllViews(CPDFSDK_PageView* pSender,
528                                       CPDFSDK_Annot* pAnnot) {
529   for (const auto& it : m_pageMap) {
530     CPDFSDK_PageView* pPageView = it.second;
531     if (pPageView != pSender) {
532       pPageView->UpdateView(pAnnot);
533     }
534   }
535 }
536
537 CPDFSDK_Annot* CPDFSDK_Document::GetFocusAnnot() {
538   return m_pFocusAnnot;
539 }
540
541 FX_BOOL CPDFSDK_Document::SetFocusAnnot(CPDFSDK_Annot* pAnnot, FX_UINT nFlag) {
542   if (m_pFocusAnnot == pAnnot)
543     return TRUE;
544
545   if (m_pFocusAnnot) {
546     if (!KillFocusAnnot(nFlag))
547       return FALSE;
548   }
549   CPDFSDK_PageView* pPageView = pAnnot->GetPageView();
550   if (pAnnot && pPageView->IsValid()) {
551     CPDFSDK_AnnotHandlerMgr* pAnnotHandler = m_pEnv->GetAnnotHandlerMgr();
552
553     if (pAnnotHandler && !m_pFocusAnnot) {
554       if (!pAnnotHandler->Annot_OnSetFocus(pAnnot, nFlag))
555         return FALSE;
556       if (!m_pFocusAnnot) {
557         m_pFocusAnnot = pAnnot;
558         return TRUE;
559       }
560     }
561   }
562   return FALSE;
563 }
564
565 FX_BOOL CPDFSDK_Document::KillFocusAnnot(FX_UINT nFlag) {
566   if (m_pFocusAnnot) {
567     CPDFSDK_AnnotHandlerMgr* pAnnotHandler = m_pEnv->GetAnnotHandlerMgr();
568     if (pAnnotHandler) {
569       CPDFSDK_Annot* pFocusAnnot = m_pFocusAnnot;
570       m_pFocusAnnot = NULL;
571       if (pAnnotHandler->Annot_OnKillFocus(pFocusAnnot, nFlag)) {
572         if (pFocusAnnot->GetType() == FX_BSTRC("Widget")) {
573           CPDFSDK_Widget* pWidget = (CPDFSDK_Widget*)pFocusAnnot;
574           int nFieldType = pWidget->GetFieldType();
575           if (FIELDTYPE_TEXTFIELD == nFieldType ||
576               FIELDTYPE_COMBOBOX == nFieldType)
577             m_pEnv->FFI_OnSetFieldInputFocus(NULL, NULL, 0, FALSE);
578         }
579
580         if (!m_pFocusAnnot)
581           return TRUE;
582       } else {
583         m_pFocusAnnot = pFocusAnnot;
584       }
585     }
586   }
587   return FALSE;
588 }
589
590 void CPDFSDK_Document::OnCloseDocument() {
591   KillFocusAnnot();
592 }
593
594 FX_BOOL CPDFSDK_Document::GetPermissions(int nFlag) {
595   FX_DWORD dwPermissions = m_pDoc->GetUserPermissions();
596   return dwPermissions & nFlag;
597 }
598
599 IJS_Runtime* CPDFSDK_Document::GetJsRuntime() {
600   ASSERT(m_pEnv != NULL);
601   return m_pEnv->GetJSRuntime();
602 }
603
604 CFX_WideString CPDFSDK_Document::GetPath() {
605   ASSERT(m_pEnv != NULL);
606   return m_pEnv->JS_docGetFilePath();
607 }
608
609 CPDFSDK_PageView::CPDFSDK_PageView(CPDFSDK_Document* pSDKDoc, CPDF_Page* page)
610     : m_page(page), m_pSDKDoc(pSDKDoc) {
611   CPDFSDK_InterForm* pInterForm = pSDKDoc->GetInterForm();
612   if (pInterForm) {
613     CPDF_InterForm* pPDFInterForm = pInterForm->GetInterForm();
614     pPDFInterForm->FixPageFields(page);
615   }
616   m_page->SetPrivateData((void*)m_page, (void*)this, NULL);
617   m_fxAnnotArray.RemoveAll();
618
619   m_bEnterWidget = FALSE;
620   m_bExitWidget = FALSE;
621   m_bOnWidget = FALSE;
622   m_CaptureWidget = NULL;
623   m_bValid = FALSE;
624   m_bLocked = FALSE;
625   m_bTakeOverPage = FALSE;
626 }
627
628 CPDFSDK_PageView::~CPDFSDK_PageView() {
629   // if there is a focused annot on the page, we should kill the focus first.
630   if (CPDFSDK_Annot* focusedAnnot = m_pSDKDoc->GetFocusAnnot()) {
631     for (int i = 0, count = m_fxAnnotArray.GetSize(); i < count; i++) {
632       CPDFSDK_Annot* pAnnot = (CPDFSDK_Annot*)m_fxAnnotArray.GetAt(i);
633       if (pAnnot == focusedAnnot) {
634         KillFocusAnnot();
635         break;
636       }
637     }
638   }
639
640   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
641   CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
642   ASSERT(pAnnotHandlerMgr);
643   for (int i = 0, count = m_fxAnnotArray.GetSize(); i < count; i++) {
644     CPDFSDK_Annot* pAnnot = (CPDFSDK_Annot*)m_fxAnnotArray.GetAt(i);
645     pAnnotHandlerMgr->ReleaseAnnot(pAnnot);
646   }
647   m_fxAnnotArray.RemoveAll();
648
649   delete m_pAnnotList;
650   m_pAnnotList = NULL;
651
652   m_page->RemovePrivateData((void*)m_page);
653   if (m_bTakeOverPage) {
654     delete m_page;
655   }
656 }
657
658 void CPDFSDK_PageView::PageView_OnDraw(CFX_RenderDevice* pDevice,
659                                        CPDF_Matrix* pUser2Device,
660                                        CPDF_RenderOptions* pOptions) {
661   m_curMatrix = *pUser2Device;
662
663   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
664   CPDFSDK_AnnotIterator annotIterator(this, TRUE);
665   int index = -1;
666   while (CPDFSDK_Annot* pSDKAnnot = annotIterator.Next(index)) {
667     CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
668     pAnnotHandlerMgr->Annot_OnDraw(this, pSDKAnnot, pDevice, pUser2Device, 0);
669   }
670 }
671
672 CPDF_Annot* CPDFSDK_PageView::GetPDFAnnotAtPoint(FX_FLOAT pageX,
673                                                  FX_FLOAT pageY) {
674   int nCount = m_pAnnotList->Count();
675   for (int i = 0; i < nCount; i++) {
676     CPDF_Annot* pAnnot = m_pAnnotList->GetAt(i);
677     CFX_FloatRect annotRect;
678     pAnnot->GetRect(annotRect);
679     if (annotRect.Contains(pageX, pageY))
680       return pAnnot;
681   }
682   return NULL;
683 }
684
685 CPDF_Annot* CPDFSDK_PageView::GetPDFWidgetAtPoint(FX_FLOAT pageX,
686                                                   FX_FLOAT pageY) {
687   int nCount = m_pAnnotList->Count();
688   for (int i = 0; i < nCount; i++) {
689     CPDF_Annot* pAnnot = m_pAnnotList->GetAt(i);
690     if (pAnnot->GetSubType() == "Widget") {
691       CFX_FloatRect annotRect;
692       pAnnot->GetRect(annotRect);
693       if (annotRect.Contains(pageX, pageY))
694         return pAnnot;
695     }
696   }
697   return NULL;
698 }
699
700 CPDFSDK_Annot* CPDFSDK_PageView::GetFXAnnotAtPoint(FX_FLOAT pageX,
701                                                    FX_FLOAT pageY) {
702   CPDFSDK_AnnotIterator annotIterator(this, FALSE);
703   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
704   CPDFSDK_AnnotHandlerMgr* pAnnotMgr = pEnv->GetAnnotHandlerMgr();
705   CPDFSDK_Annot* pSDKAnnot = NULL;
706   int index = -1;
707   while ((pSDKAnnot = annotIterator.Next(index))) {
708     CPDF_Rect rc = pAnnotMgr->Annot_OnGetViewBBox(this, pSDKAnnot);
709     if (rc.Contains(pageX, pageY))
710       return pSDKAnnot;
711   }
712
713   return NULL;
714 }
715
716 CPDFSDK_Annot* CPDFSDK_PageView::GetFXWidgetAtPoint(FX_FLOAT pageX,
717                                                     FX_FLOAT pageY) {
718   CPDFSDK_AnnotIterator annotIterator(this, FALSE);
719   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
720   CPDFSDK_AnnotHandlerMgr* pAnnotMgr = pEnv->GetAnnotHandlerMgr();
721   CPDFSDK_Annot* pSDKAnnot = NULL;
722   int index = -1;
723   while ((pSDKAnnot = annotIterator.Next(index))) {
724     if (pSDKAnnot->GetType() == "Widget") {
725       pAnnotMgr->Annot_OnGetViewBBox(this, pSDKAnnot);
726       CPDF_Point point(pageX, pageY);
727       if (pAnnotMgr->Annot_OnHitTest(this, pSDKAnnot, point))
728         return pSDKAnnot;
729     }
730   }
731
732   return NULL;
733 }
734
735 FX_BOOL CPDFSDK_PageView::Annot_HasAppearance(CPDF_Annot* pAnnot) {
736   CPDF_Dictionary* pAnnotDic = pAnnot->GetAnnotDict();
737   if (pAnnotDic)
738     return pAnnotDic->KeyExist("AS");
739   return FALSE;
740 }
741
742 CPDFSDK_Annot* CPDFSDK_PageView::AddAnnot(CPDF_Annot* pPDFAnnot) {
743   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
744   ASSERT(pEnv);
745   CPDFSDK_AnnotHandlerMgr* pAnnotHandler = pEnv->GetAnnotHandlerMgr();
746
747   CPDFSDK_Annot* pSDKAnnot = NULL;
748
749   if (pAnnotHandler) {
750     pSDKAnnot = pAnnotHandler->NewAnnot(pPDFAnnot, this);
751   }
752   if (!pSDKAnnot)
753     return NULL;
754
755   m_fxAnnotArray.Add(pSDKAnnot);
756
757   if (pAnnotHandler) {
758     pAnnotHandler->Annot_OnCreate(pSDKAnnot);
759   }
760
761   return pSDKAnnot;
762 }
763
764 CPDFSDK_Annot* CPDFSDK_PageView::AddAnnot(CPDF_Dictionary* pDict) {
765   return pDict ? AddAnnot(pDict->GetString("Subtype"), pDict) : nullptr;
766 }
767
768 CPDFSDK_Annot* CPDFSDK_PageView::AddAnnot(const FX_CHAR* lpSubType,
769                                           CPDF_Dictionary* pDict) {
770   return NULL;
771 }
772
773 FX_BOOL CPDFSDK_PageView::DeleteAnnot(CPDFSDK_Annot* pAnnot) {
774   return FALSE;
775 }
776
777 CPDF_Document* CPDFSDK_PageView::GetPDFDocument() {
778   if (m_page) {
779     return m_page->m_pDocument;
780   }
781   return NULL;
782 }
783
784 int CPDFSDK_PageView::CountAnnots() {
785   return m_pAnnotList->Count();
786 }
787
788 CPDFSDK_Annot* CPDFSDK_PageView::GetAnnot(int nIndex) {
789   int nCount = m_fxAnnotArray.GetSize();
790   if (nIndex < 0 || nIndex >= nCount) {
791     return NULL;
792   }
793
794   return (CPDFSDK_Annot*)m_fxAnnotArray.GetAt(nIndex);
795 }
796
797 CPDFSDK_Annot* CPDFSDK_PageView::GetAnnotByDict(CPDF_Dictionary* pDict) {
798   int nCount = m_fxAnnotArray.GetSize();
799   for (int i = 0; i < nCount; i++) {
800     CPDFSDK_Annot* pAnnot = (CPDFSDK_Annot*)m_fxAnnotArray.GetAt(i);
801     if (pDict == pAnnot->GetPDFAnnot()->GetAnnotDict())
802       return pAnnot;
803   }
804   return NULL;
805 }
806
807 FX_BOOL CPDFSDK_PageView::OnLButtonDown(const CPDF_Point& point,
808                                         FX_UINT nFlag) {
809   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
810   ASSERT(pEnv);
811   CPDFSDK_Annot* pFXAnnot = GetFXWidgetAtPoint(point.x, point.y);
812   if (!pFXAnnot) {
813     KillFocusAnnot(nFlag);
814   } else {
815     CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
816     ASSERT(pAnnotHandlerMgr);
817
818     FX_BOOL bRet =
819         pAnnotHandlerMgr->Annot_OnLButtonDown(this, pFXAnnot, nFlag, point);
820     if (bRet) {
821       SetFocusAnnot(pFXAnnot);
822     }
823     return bRet;
824   }
825   return FALSE;
826 }
827
828 FX_BOOL CPDFSDK_PageView::OnLButtonUp(const CPDF_Point& point, FX_UINT nFlag) {
829   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
830   ASSERT(pEnv);
831   CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
832   ASSERT(pAnnotHandlerMgr);
833   CPDFSDK_Annot* pFXAnnot = GetFXWidgetAtPoint(point.x, point.y);
834   CPDFSDK_Annot* pFocusAnnot = GetFocusAnnot();
835   FX_BOOL bRet = FALSE;
836   if (pFocusAnnot && pFocusAnnot != pFXAnnot) {
837     // Last focus Annot gets a chance to handle the event.
838     bRet = pAnnotHandlerMgr->Annot_OnLButtonUp(this, pFocusAnnot, nFlag, point);
839   }
840   if (pFXAnnot && !bRet) {
841     bRet = pAnnotHandlerMgr->Annot_OnLButtonUp(this, pFXAnnot, nFlag, point);
842     return bRet;
843   }
844   return bRet;
845 }
846
847 FX_BOOL CPDFSDK_PageView::OnMouseMove(const CPDF_Point& point, int nFlag) {
848   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
849   CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
850   ASSERT(pAnnotHandlerMgr);
851   if (CPDFSDK_Annot* pFXAnnot = GetFXWidgetAtPoint(point.x, point.y)) {
852     if (m_CaptureWidget && m_CaptureWidget != pFXAnnot) {
853       m_bExitWidget = TRUE;
854       m_bEnterWidget = FALSE;
855       pAnnotHandlerMgr->Annot_OnMouseExit(this, m_CaptureWidget, nFlag);
856     }
857     m_CaptureWidget = (CPDFSDK_Widget*)pFXAnnot;
858     m_bOnWidget = TRUE;
859     if (!m_bEnterWidget) {
860       m_bEnterWidget = TRUE;
861       m_bExitWidget = FALSE;
862       pAnnotHandlerMgr->Annot_OnMouseEnter(this, pFXAnnot, nFlag);
863     }
864     pAnnotHandlerMgr->Annot_OnMouseMove(this, pFXAnnot, nFlag, point);
865     return TRUE;
866   }
867   if (m_bOnWidget) {
868     m_bOnWidget = FALSE;
869     m_bExitWidget = TRUE;
870     m_bEnterWidget = FALSE;
871     if (m_CaptureWidget) {
872       pAnnotHandlerMgr->Annot_OnMouseExit(this, m_CaptureWidget, nFlag);
873       m_CaptureWidget = NULL;
874     }
875   }
876   return FALSE;
877 }
878
879 FX_BOOL CPDFSDK_PageView::OnMouseWheel(double deltaX,
880                                        double deltaY,
881                                        const CPDF_Point& point,
882                                        int nFlag) {
883   if (CPDFSDK_Annot* pAnnot = GetFXWidgetAtPoint(point.x, point.y)) {
884     CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
885     CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
886     ASSERT(pAnnotHandlerMgr);
887     return pAnnotHandlerMgr->Annot_OnMouseWheel(this, pAnnot, nFlag,
888                                                 (int)deltaY, point);
889   }
890   return FALSE;
891 }
892
893 FX_BOOL CPDFSDK_PageView::OnChar(int nChar, FX_UINT nFlag) {
894   if (CPDFSDK_Annot* pAnnot = GetFocusAnnot()) {
895     CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
896     CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
897     ASSERT(pAnnotHandlerMgr);
898     return pAnnotHandlerMgr->Annot_OnChar(pAnnot, nChar, nFlag);
899   }
900
901   return FALSE;
902 }
903
904 FX_BOOL CPDFSDK_PageView::OnKeyDown(int nKeyCode, int nFlag) {
905   if (CPDFSDK_Annot* pAnnot = GetFocusAnnot()) {
906     CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
907     CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
908     ASSERT(pAnnotHandlerMgr);
909     return pAnnotHandlerMgr->Annot_OnKeyDown(pAnnot, nKeyCode, nFlag);
910   }
911   return FALSE;
912 }
913
914 FX_BOOL CPDFSDK_PageView::OnKeyUp(int nKeyCode, int nFlag) {
915   return FALSE;
916 }
917
918 void CPDFSDK_PageView::LoadFXAnnots() {
919   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
920
921   FX_BOOL enableAPUpdate = CPDF_InterForm::UpdatingAPEnabled();
922   // Disable the default AP construction.
923   CPDF_InterForm::EnableUpdateAP(FALSE);
924   m_pAnnotList = new CPDF_AnnotList(m_page);
925   CPDF_InterForm::EnableUpdateAP(enableAPUpdate);
926   int nCount = m_pAnnotList->Count();
927   SetLock(TRUE);
928   for (int i = 0; i < nCount; i++) {
929     CPDF_Annot* pPDFAnnot = m_pAnnotList->GetAt(i);
930     CPDF_Document* pDoc = GetPDFDocument();
931
932     CheckUnSupportAnnot(pDoc, pPDFAnnot);
933
934     CPDFSDK_AnnotHandlerMgr* pAnnotHandlerMgr = pEnv->GetAnnotHandlerMgr();
935     ASSERT(pAnnotHandlerMgr != NULL);
936
937     if (pAnnotHandlerMgr) {
938       CPDFSDK_Annot* pAnnot = pAnnotHandlerMgr->NewAnnot(pPDFAnnot, this);
939       if (!pAnnot)
940         continue;
941       m_fxAnnotArray.Add(pAnnot);
942
943       pAnnotHandlerMgr->Annot_OnLoad(pAnnot);
944     }
945   }
946   SetLock(FALSE);
947 }
948
949 void CPDFSDK_PageView::UpdateRects(CFX_RectArray& rects) {
950   for (int i = 0; i < rects.GetSize(); i++) {
951     CPDF_Rect rc = rects.GetAt(i);
952     CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
953     pEnv->FFI_Invalidate(m_page, rc.left, rc.top, rc.right, rc.bottom);
954   }
955 }
956
957 void CPDFSDK_PageView::UpdateView(CPDFSDK_Annot* pAnnot) {
958   CPDF_Rect rcWindow = pAnnot->GetRect();
959   CPDFDoc_Environment* pEnv = m_pSDKDoc->GetEnv();
960   pEnv->FFI_Invalidate(m_page, rcWindow.left, rcWindow.top, rcWindow.right,
961                        rcWindow.bottom);
962 }
963
964 int CPDFSDK_PageView::GetPageIndex() {
965   if (m_page) {
966     CPDF_Dictionary* pDic = m_page->m_pFormDict;
967     CPDF_Document* pDoc = m_pSDKDoc->GetDocument();
968     if (pDoc && pDic) {
969       return pDoc->GetPageIndex(pDic->GetObjNum());
970     }
971   }
972   return -1;
973 }
974
975 FX_BOOL CPDFSDK_PageView::IsValidAnnot(void* p) {
976   if (p == NULL)
977     return FALSE;
978   int iCount = m_pAnnotList->Count();
979   for (int i = 0; i < iCount; i++) {
980     if (m_pAnnotList->GetAt(i) == p)
981       return TRUE;
982   }
983   return FALSE;
984 }
985
986 CPDFSDK_Annot* CPDFSDK_PageView::GetFocusAnnot() {
987   CPDFSDK_Annot* pFocusAnnot = m_pSDKDoc->GetFocusAnnot();
988   if (!pFocusAnnot)
989     return NULL;
990
991   for (int i = 0; i < m_fxAnnotArray.GetSize(); i++) {
992     CPDFSDK_Annot* pAnnot = (CPDFSDK_Annot*)m_fxAnnotArray.GetAt(i);
993     if (pAnnot == pFocusAnnot)
994       return pAnnot;
995   }
996   return NULL;
997 }