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