From 34980170539197a7713618783eed63db5342e1f9 Mon Sep 17 00:00:00 2001 From: Michal Rentka Date: Thu, 11 Jul 2024 12:03:47 +0200 Subject: [PATCH 1/2] iOS support added --- src/index.ios.js | 105 +++++++++++++++++++++++++++++++++++++---------- 1 file changed, 84 insertions(+), 21 deletions(-) diff --git a/src/index.ios.js b/src/index.ios.js index 0ee569b7..0ef7396b 100644 --- a/src/index.ios.js +++ b/src/index.ios.js @@ -1,46 +1,109 @@ import View from './common/view'; function postMessage(event, params = {}) { - window.webkit.messageHandlers.textHandler.postMessage({ event, params }); + window.webkit.messageHandlers.textHandler.postMessage({event, params}); } -window.createView = (options) => { - window._view = new View({ - ...options, +function log(data) { + window.webkit.messageHandlers.logHandler.postMessage(data); +} + +function decodeBase64(base64) { + const text = atob(base64); + const length = text.length; + const bytes = new Uint8Array(length); + for (let i = 0; i < length; i++) { + bytes[i] = text.charCodeAt(i); + } + const decoder = new TextDecoder(); + return decoder.decode(bytes); +} + +window.createView = options => { + log("Create " + options.type + " view"); + const annotations = JSON.parse(decodeBase64(options.annotations)); + log("Loaded " + annotations.length + " annotations"); + window._view = new View({ + type: options.type, + annotations: annotations, + viewState: options.viewState, container: document.getElementById('view'), data: { // TODO: Implement a more efficient way to transfer large files buf: new Uint8Array(options.buf) }, - onSaveAnnotations: (annotations) => { - postMessage('onSaveAnnotations', { annotations }); + onSaveAnnotations: annotations => { + postMessage('onSaveAnnotations', {annotations}); + + if (annotations[0].type == "note") { + window._view.selectAnnotations([annotations[0].id]); + } }, - onSetOutline: (outline) => { - postMessage('onSetOutline', { outline }); + onSetOutline: outline => { + postMessage('onSetOutline', {outline}); }, - onSelectAnnotations: (ids) => { - postMessage('onSelectAnnotations', { ids }); + onSelectAnnotations: ids => { + postMessage('onSelectAnnotations', {ids}); + window._view.selectAnnotations(ids); }, - onSetSelectionPopup: (params) => { + onSetSelectionPopup: params => { postMessage('onSetSelectionPopup', params); }, - onSetAnnotationPopup: (params) => { + onSetAnnotationPopup: params => { postMessage('onSetAnnotationPopup', params); }, - onOpenLink: (url) => { - postMessage('onOpenLink', { url }); + onOpenLink: url => { + postMessage('onOpenLink', {url}); }, - onFindResult: (result) => { + onFindResult: result => { postMessage('onFindResult', result); }, - onChangeViewState: (state) => { - postMessage('onChangeViewState', { state }); + onChangeViewState: state => { + postMessage('onChangeViewState', {state}); }, - onChangeViewStats: (stats) => { - postMessage('onChangeViewStats', { stats }); + onChangeViewStats: stats => { + postMessage('onChangeViewStats', {stats}); } }); -}; +} + +window.setTool = options => { + log("Set tool: " + options.type + "; color: " + options.color); + window._view.setTool(options); +} + +window.clearTool = () => { + log("Clear tool"); + window._view.setTool(); +} + +window.updateAnnotations = (options) => { + const deletions = JSON.parse(decodeBase64(options.deletions)); + const insertions = JSON.parse(decodeBase64(options.insertions)); + const modifications = JSON.parse(decodeBase64(options.modifications)); + + if (deletions.length > 0) { + log("Delete: " + JSON.stringify(deletions)); + window._view.unsetAnnotations(deletions); + } + let updates = [...insertions, ...modifications]; + if (updates.length > 0) { + log("Add/Update: " + JSON.stringify(updates)); + window._view.setAnnotations(updates); + } +} + +window.search = options => { + const term = decodeBase64(options.term); + log("Search document: " + term); + window._view.find({ query: term, highlightAll: true, caseSensitive: false, entireWord: false }); +} + +window.select = options => { + log("Select: " + options.key); + window._view.selectAnnotations([options.key]) + window._view.navigate({annotationID: options.key}); +} // Notify when iframe is loaded -postMessage('onInitialized'); +postMessage('onInitialized'); \ No newline at end of file From d128f7ccdd51ad1552fe7984bc6f519cd4da9807 Mon Sep 17 00:00:00 2001 From: Michal Rentka Date: Wed, 21 Aug 2024 09:52:15 +0200 Subject: [PATCH 2/2] Load document from url --- src/index.ios.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/index.ios.js b/src/index.ios.js index 0ef7396b..71fcddd4 100644 --- a/src/index.ios.js +++ b/src/index.ios.js @@ -29,8 +29,7 @@ window.createView = options => { viewState: options.viewState, container: document.getElementById('view'), data: { - // TODO: Implement a more efficient way to transfer large files - buf: new Uint8Array(options.buf) + url: new URL(options.url) }, onSaveAnnotations: annotations => { postMessage('onSaveAnnotations', {annotations});