diff --git a/bt5/erp5_document_scanner/ActionTemplateItem/portal_types/Preference/document_scanner_preference.xml b/bt5/erp5_document_scanner/ActionTemplateItem/portal_types/Preference/document_scanner_preference.xml new file mode 100644 index 0000000000000000000000000000000000000000..7a0c764808b48d98dbeb70c83c0edbdbc2d42d0c --- /dev/null +++ b/bt5/erp5_document_scanner/ActionTemplateItem/portal_types/Preference/document_scanner_preference.xml @@ -0,0 +1,81 @@ + + + + + + + + + + action + + AAAAAAAAAAI= + + + + categories + + + action_type/object_view + + + + + category + object_view + + + condition + + + + description + + + + + + icon + + + + id + document_scanner_preference + + + permissions + + + View + + + + + priority + 4.0 + + + title + Document Scanner + + + visible + 1 + + + + + + + + + + + + text + string:${object_url}/Preference_viewDocumentScannerSettting + + + + + diff --git a/bt5/erp5_document_scanner/PathTemplateItem/portal_alarms/remove_outdated_active_process.xml b/bt5/erp5_document_scanner/PathTemplateItem/portal_alarms/remove_outdated_active_process.xml new file mode 100644 index 0000000000000000000000000000000000000000..b09b324212df421e4310f293451acef68317d28c --- /dev/null +++ b/bt5/erp5_document_scanner/PathTemplateItem/portal_alarms/remove_outdated_active_process.xml @@ -0,0 +1,95 @@ + + + + + + + + + + active_sense_method_id + Alarm_removeOutdatedActiveProcess + + + automatic_solve + 0 + + + description + + + + + + enabled + 1 + + + id + remove_outdated_active_process + + + periodicity_day_frequency + 1 + + + periodicity_hour + + + + + + periodicity_minute + + + + + + periodicity_month + + + + + + periodicity_month_day + + + + + + periodicity_start_date + + + + + + + + + + + 1167609600.0 + GMT + + + + + + + periodicity_week + + + + + + portal_type + Alarm + + + title + Remove Outdated Active Process + + + + + diff --git a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_css.css b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_css.css index 7bc0cceb982c68bdb4100f34afaad386f24cf0cb..4ec4d6f3318d1ef66acc6caf8400a60224caadea 100644 --- a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_css.css +++ b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_css.css @@ -1,13 +1,11 @@ -.device-selector { +div[data-gadget-url$="gadget_document_scanner.html"] { text-align: center; - font-size: 19px; } -div[data-gadget-scope="field_your_document_scanner_gadget"] { - text-align: center; -} - -.video, .photo, .camera-output { +div[data-gadget-url$="gadget_document_scanner.html"] .photo, +div[data-gadget-url$="gadget_document_scanner.html"] .video, +div[data-gadget-url$="gadget_document_scanner.html"] .camera-output, +div[data-gadget-url$="gadget_document_scanner.html"] .canvas { max-width: 100%; width: auto; max-height: 500px; @@ -15,69 +13,67 @@ div[data-gadget-scope="field_your_document_scanner_gadget"] { text-align: center; } -.camera-input, .camera-output { +div[data-gadget-url$="gadget_document_scanner.html"] .camera-input { min-height: 360px; - display: none; } -.canvas { - display: none; - filter: brightness(1); -} - -.page-number { +div[data-gadget-url$="gadget_document_scanner.html"] .page-number { display: inline; } -.camera-header { +div[data-gadget-url$="gadget_document_scanner.html"] .camera-header { font-size: 12pt; font-weight: 400; } -.camera-input, .camera-output, .camera-header, .edit-picture { +div[data-gadget-url$="gadget_document_scanner.html"] .camera-input, +div[data-gadget-url$="gadget_document_scanner.html"] .camera-output, +div[data-gadget-url$="gadget_document_scanner.html"] .camera-header, +div[data-gadget-url$="gadget_document_scanner.html"] .edit-picture { text-align: center; } -.camera, .camera-input, .camera-output { +div[data-gadget-url$="gadget_document_scanner.html"] .camera, +div[data-gadget-url$="gadget_document_scanner.html"] .camera-input { display: inline-block; } -.capture-button, .reset-button { - display: inline; - margin: 0 2em 0 2em; -} - -.startbutton { - display: block; - margin: 0 auto; -} - -.reset-btn, .confirm-btn, .edit-btn, .take-picture-btn, - .capture-btn, .change-camera-btn, .confirm-btn { +div[data-gadget-url$="gadget_document_scanner.html"] .reset-btn, +div[data-gadget-url$="gadget_document_scanner.html"] .confirm-btn, +div[data-gadget-url$="gadget_document_scanner.html"] .edit-btn, +div[data-gadget-url$="gadget_document_scanner.html"] .take-picture-btn, +div[data-gadget-url$="gadget_document_scanner.html"] .capture-btn, +div[data-gadget-url$="gadget_document_scanner.html"] .change-camera-btn, +div[data-gadget-url$="gadget_document_scanner.html"] .confirm-btn { color: #212529; padding: 3pt; border: 1px solid rgba(0, 0, 0, 0.14); border-radius: 0.325em; + display: "inline-block"; + margin-right: 6pt; } -.take-picture-btn, .capture-btn, .confirm-btn, - .reset-btn, .confirm-btn, .change-camera-btn, .edit-btn { - display: none; +div[data-gadget-url$="gadget_document_scanner.html"] .ui-btn-icon-left:before { + margin-right: 6pt; } -.contentarea { - font-size: 16px; - font-family: "Lucida Grande", "Arial", sans-serif; - width: 760px; +div[data-gadget-url$="gadget_document_scanner.html"] button:disabled, +div[data-gadget-url$="gadget_document_scanner.html"] button[disabled] { + color: #999999; } -button:disabled, -button[disabled]{ - color: #999999; +div[data-gadget-url$="gadget_document_scanner.html"] > .camera > .thumbnail-list { + padding-top: .5em; +} + +div[data-gadget-url$="gadget_document_scanner.html"] .show-img { + width: 21%; +} + +div[data-gadget-url$="gadget_document_scanner.html"] .upload-error { + border: 3px solid red; } -@media only screen and (max-width: 600px) { - body { - max-height: 360px; - } +div[data-gadget-url$="gadget_document_scanner.html"] .new-btn { + font-size: 26pt; } \ No newline at end of file diff --git a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_css.xml b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_css.xml index 5b92866dd88f0ec95832a8dcddc7adfa8d5f518e..bb3b92ec18252c443ec11ef4895afb21840eebc9 100644 --- a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_css.xml +++ b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_css.xml @@ -69,7 +69,9 @@ content_type - text/css + + + default_reference @@ -167,9 +169,7 @@ action - - - + publish_alive actor @@ -188,50 +188,11 @@ - + - - - 1574261202.27 - UTC - - - - - - - validation_state - draft - - - - - action - publish_alive - - - actor - zope - - - comment - - - - error_message - - - - time - - - - - - 1574261323.29 @@ -262,51 +223,6 @@ _log - - - action - edit - - - actor - zope - - - comment - - - - error_message - - - - serial - 0.0.0.0 - - - state - current - - - time - - - - - - - - - - - 1574261202.26 - UTC - - - - - - action @@ -328,7 +244,7 @@ serial - 979.60822.46188.23978 + 981.42527.16024.21179 state @@ -338,148 +254,15 @@ time - - - - - - - 1574261231.12 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60823.12148.22101 - - - state - current - - - time - - - - - - - - - 1574261265.43 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 980.2211.58828.61730 - - - state - current - - - time - - - - - - - - - 1574688148.62 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 980.2402.31270.49459 - - - state - current - - - time - - - + + + - 1574697983.15 + 1575027025.78 UTC diff --git a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_html.html b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_html.html index 33040111f811445a10895581d297b610fecd10f2..130264f3545bc98a414aa3d93de17554e89a95c8 100644 --- a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_html.html +++ b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_html.html @@ -3,10 +3,13 @@ @@ -14,30 +17,12 @@ + + Gadget Document Scanner -
-
-

Page

-
-
- -
- -
- Photo - - -
-
- - - - - -
-
+
- \ No newline at end of file + diff --git a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_html.xml b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_html.xml index 53e20769df47db22d86fb40ad09f2fff353c5073..d2eb3e76bcb7de49703ad5cb684f5b1060bb4d7a 100644 --- a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_html.xml +++ b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_html.xml @@ -167,9 +167,7 @@ action - - - + publish_alive actor @@ -188,50 +186,11 @@ - + - - - 1574261595.83 - UTC - - - - - - - validation_state - draft - - - - - action - publish_alive - - - actor - zope - - - comment - - - - error_message - - - - time - - - - - - 1574261995.43 @@ -262,96 +221,6 @@ _log - - - action - edit - - - actor - zope - - - comment - - - - error_message - - - - serial - 0.0.0.0 - - - state - current - - - time - - - - - - - - - - - 1574261595.83 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60829.17295.36334 - - - state - current - - - time - - - - - - - - - 1574261616.19 - UTC - - - - - - action @@ -373,7 +242,7 @@ serial - 979.60829.39532.12458 + 981.31842.62752.52411 state @@ -383,373 +252,15 @@ time - - - - - - - 1574261638.39 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60835.60550.28808 - - - state - current - - - time - - - - - - - - - 1574262871.91 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60850.34860.27477 - - - state - current - - - time - - - - - - - - - 1574263390.85 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 980.2211.58828.61730 - - - state - current - - - time - - - - - - - - - 1574679628.14 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 980.2260.30741.13158 - - - state - current - - - time - - - - - - - - - 1574679704.62 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 980.2261.48739.22886 - - - state - current - - - time - - - - - - - - - 1574686933.44 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 980.2382.14691.53162 - - - state - current - - - time - - - - - - - - - 1574687074.8 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 980.2384.38015.42888 - - - state - current - - - time - - - - - - - - - 1574688159.56 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 980.2402.43212.46062 - - - state - current - - - time - - - + + + - 1574698038.29 + 1580352868.23 UTC diff --git a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_js.js b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_js.js index 73007963db81215c2b4390d0505e509f11dc0dc3..b8f0ccc631ead3e065516a353225eb930b15be0d 100644 --- a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_js.js +++ b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_js.js @@ -1,34 +1,54 @@ /*jslint indent: 2 */ -/*global rJS, RSVP, window, navigator, Cropper, Promise, JSON, jIO*/ -(function (rJS, RSVP, window, navigator, Cropper, Promise, JSON, jIO) { +/*global rJS, RSVP, window, navigator, Cropper, Promise, JSON, jIO, Caman*/ +(function (rJS, RSVP, window, navigator, Cropper, Promise, JSON, jIO, Caman) { "use strict"; - function drawCanvas(gadget, img) { - var ratio, x, y, + function startCropper(gadget, img) { + var queue, + settings = gadget.props.preferred_image_settings_data, root = gadget.element, - canvas = root.querySelector("canvas"); - canvas.width = gadget.props.image_width; - canvas.height = gadget.props.image_height; - ratio = Math.min(canvas.width / img.width, canvas.height / img.height); - x = (canvas.width - img.width * ratio) / 2; - y = (canvas.height - img.height * ratio) / 2; + canvas = document.createElement("canvas"); - canvas.getContext('2d').clearRect(0, 0, canvas.width, canvas.height); - canvas.getContext('2d').drawImage(img, 0, 0, img.width, img.height, x, y, img.width * ratio, img.height * ratio); + queue = new RSVP.Queue(); + if (settings.brightness || settings.contrast || settings.enable_greyscale || settings.compression) { + queue.push(function () { + return new Promise(function (resolve) { + Caman(canvas, img.src, function () { + if (settings.brightness !== 0) { + this.brightness(settings.brightness); + } + if (settings.contrast !== 0) { + this.contrast(settings.contrast); + } + if (settings.enable_greyscale) { + this.greyscale(); + } + this.render(function () { + resolve(canvas.toDataURL("image/jpeg", settings.compression)); + }); + }); + }); + }); + } - //contrastImage(canvas, canvas, 10); + queue.push(function (data_str) { + if (data_str) { + img.setAttribute("src", data_str); + } - root.querySelector(".camera-output").style.display = ""; - if (gadget.props.cropper) { - gadget.props.cropper.destroy(); - } - // creating Cropper is asynchronous - return new RSVP.Promise(function (resolve) { - gadget.props.cropper = new Cropper(root.querySelector('.photo'), { - data: gadget.props.preferred_cropped_canvas_data, - ready: resolve + root.querySelector(".camera-output").style.display = ""; + if (gadget.props.cropper) { + gadget.props.cropper.destroy(); + } + // creating Cropper is asynchronous + return new RSVP.Promise(function (resolve) { + gadget.props.cropper = new Cropper(root.querySelector('.photo'), { + data: gadget.props.preferred_cropped_canvas_data, + ready: resolve + }); }); }); + return queue; } function takePicture(gadget) { @@ -36,7 +56,10 @@ image_capture = gadget.props.image_capture; return new RSVP.Queue() .push(function () { - return image_capture.takePhoto({imageWidth: gadget.props.image_width}); + return image_capture.takePhoto({ + imageWidth: gadget.props.image_width, + imageHeight: gadget.props.image_height + }); }) .push(function (blob) { return jIO.util.readBlobAsDataURL(blob); @@ -48,7 +71,7 @@ photo.setAttribute("src", data_str); photoInput.setAttribute("value", data_str.split(",")[1]); - return drawCanvas(gadget, photo); + return startCropper(gadget, photo); }); } @@ -88,60 +111,6 @@ }); } - /*function contrastImage(input, output, contrast) { - var i, - outputContext, - inputContext = input.getContext("2d"), - imageData = inputContext.getImageData(0, 0, input.width, input.height), - data = imageData.data, - factor = (259 * (contrast + 255)) / (255 * (259 - contrast)); - - for (i = 0; i < data.length; i += 4) { - data[i] = factor * (data[i] - 128) + 128; - data[i + 1] = factor * (data[i + 1] - 128) + 128; - data[i + 2] = factor * (data[i + 2] - 128) + 128; - } - outputContext = output.getContext("2d"); - outputContext.putImageData(imageData, 0, 0); - }*/ - - /*function grayscale(input, output) { - var i, - gray, - outputContext, - outputCanvas = document.createElement("canvas"), - inputContext = input.getContext("2d"), - imageData = inputContext.getImageData(0, 0, input.width, input.height), - data = imageData.data, - arraylength = input.width * input.height * 4; - - //gray = 0.3*R + 0.59*G + 0.11*B - // http://www.tannerhelland.com/3643/grayscale-image-algorithm-vb6/ - for (i = arraylength - 1; i > 0; i -= 4) { - gray = 0.3 * data[i - 3] + 0.59 * data[i - 2] + 0.11 * data[i - 1]; - data[i - 3] = gray; - data[i - 2] = gray; - data[i - 1] = gray; - } - outputContext = outputCanvas.getContext("2d"); - outputContext.putImageData(imageData, 0, 0); - - data = canvas.toDataURL("image/png"); - output.setAttribute("src", data); - if (cropper) { - cropper.destroy(); - } - return new RSVP.Queue() - .push(function () { - cropper = new Cropper( - output, - { - data: preferred_cropped_canvas_data - } - ); - }); - }*/ - function handleUserMedia(gadget, callback) { var stream, video = gadget.props.video; @@ -235,9 +204,9 @@ root.querySelector("video").innerText = result_list[0]; }) .push(function () { - var preferred_cropped_canvas_data = gadget.props.preferred_cropped_canvas_data; - preferred_cropped_canvas_data = preferred_cropped_canvas_data || JSON.parse(options.preferred_cropped_canvas_data); - gadget.props.dialog_method = preferred_cropped_canvas_data.dialog_method; + gadget.props.preferred_cropped_canvas_data = gadget.props.preferred_cropped_canvas_data || JSON.parse(options.preferred_cropped_canvas_data); + gadget.props.preferred_image_settings_data = JSON.parse(options.preferred_image_settings_data); + gadget.props.dialog_method = options.dialog_method; // Clear photo input root.querySelector('.photoInput').value = ""; gadget.props.page_number = parseInt(root.querySelector('input[name="page-number"]').value, 10); @@ -288,10 +257,6 @@ camera_list = this.props.camera_list, root = this.element; - /*if (evt.target.name === "grayscale") { - return grayscale(root.querySelector(".canvas"), - root.querySelector('.photo')); - }*/ if (evt.target.className.indexOf("change-camera-btn") !== -1) { evt.preventDefault(); @@ -324,7 +289,9 @@ root.querySelector(".camera-input").style.display = ""; root.querySelector(".camera-output").style.display = "none"; root.querySelector('.photoInput').value = ""; - gadget.props.cropper.destroy(); + if (gadget.props.cropper) { + gadget.props.cropper.destroy(); + } return setPageOne(gadget); } if (evt.target.className.indexOf("confirm-btn") !== -1) { @@ -340,7 +307,7 @@ var canvas = gadget.props.cropper.getCroppedCanvas(); disableButton(gadget.element); return new Promise(function (resolve) { - canvas.toBlob(resolve, 'image/jpeg', 0.85); + canvas.toBlob(resolve, 'image/jpeg', 1); }); }) .push(function (blob) { @@ -352,7 +319,9 @@ realData = block[1].split(",")[1]; root.querySelector(".photo").src = base64data; root.querySelector(".photoInput").value = realData; - gadget.props.cropper.destroy(); + if (gadget.props.proper) { + gadget.props.cropper.destroy(); + } }) .push(function () { return gadget.submitDialogWithCustomDialogMethod(gadget.props.dialog_method); @@ -364,4 +333,4 @@ } }, false, false); -}(rJS, RSVP, window, navigator, Cropper, Promise, JSON, jIO)); \ No newline at end of file +}(rJS, RSVP, window, navigator, Cropper, Promise, JSON, jIO, Caman)); diff --git a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_js.xml b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_js.xml index 2bdd94c24aa37e90404206274c974159f2dfc0b6..16fbd1337de2b93947082c3312371c1f2d6b7eca 100644 --- a/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_js.xml +++ b/bt5/erp5_document_scanner/PathTemplateItem/web_page_module/rjs_gadget_document_scanner_js.xml @@ -169,9 +169,7 @@ action - - - + publish_alive actor @@ -190,50 +188,11 @@ - + - - - 1574261340.43 - UTC - - - - - - - validation_state - draft - - - - - action - publish_alive - - - actor - zope - - - comment - - - - error_message - - - - time - - - - - - 1574261409.0 @@ -285,7 +244,7 @@ serial - 981.11546.40848.57344 + 981.43882.8130.35481 state @@ -296,194 +255,14 @@ - + - 1579082847.27 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 981.11551.29846.29269 - - - state - current - - - time - - - - - - - - - 1579082942.18 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 981.11553.2579.61422 - - - state - current - - - time - - - - - - - - - 1579082950.88 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 981.11553.11938.60603 - - - state - current - - - time - - - - - - - - - 1579082992.83 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 981.11553.57761.12817 - - - state - current - - - time - - - - - - - - - 1579083055.7 + 1581025205.74 UTC @@ -494,22 +273,6 @@ - - _next - - AAAAAAAAAAY= - - - - _prev - - AAAAAAAAAAc= - - - - _tail_count - 75 - @@ -576,3441 +339,4 @@ - - - - - - - - _log - - - - - action - edit - - - actor - zope - - - comment - - - - error_message - - - - serial - 0.0.0.0 - - - state - current - - - time - - - - - - - - - - - 1574261340.43 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60825.480.48810 - - - state - current - - - time - - - - - - - - - 1574261356.64 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60825.46120.29849 - - - state - current - - - time - - - - - - - - - 1574261398.96 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60826.9837.15291 - - - state - current - - - time - - - - - - - - - 1574261577.9 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60828.63254.50278 - - - state - current - - - time - - - - - - - - - 1574262365.84 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60842.6386.64017 - - - state - current - - - time - - - - - - - - - 1574262388.11 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60842.30711.49083 - - - state - current - - - time - - - - - - - - - 1574262460.21 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60843.43928.56746 - - - state - current - - - time - - - - - - - - - 1574262462.44 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60843.43928.56746 - - - state - current - - - time - - - - - - - - - 1574263610.67 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60862.55352.10837 - - - state - current - - - time - - - - - - - - - 1574263793.54 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60865.58483.62873 - - - state - current - - - time - - - - - - - - - 1574263803.34 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60866.3654.22835 - - - state - current - - - time - - - - - - - - - 1574263914.73 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60867.59788.15547 - - - state - current - - - time - - - - - - - - - 1574263994.48 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60869.15817.48384 - - - state - current - - - time - - - - - - - - - 1574264044.06 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60870.4440.37973 - - - state - current - - - time - - - - - - - - - 1574264065.96 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60870.28365.56046 - - - state - current - - - time - - - - - - - - - 1574264073.08 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60870.36143.59784 - - - state - current - - - time - - - - - - - - - 1574264140.93 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.60870.36143.59784 - - - state - current - - - time - - - - - - - - - 1574328581.59 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61945.45445.19456 - - - state - current - - - time - - - - - - - - - 1574328759.88 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61948.43567.53623 - - - state - current - - - time - - - - - - - - - 1574328864.83 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61950.27123.63556 - - - state - current - - - time - - - - - - - - - 1574328881.2 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61950.45006.25873 - - - state - current - - - time - - - - - - - - - 1574328921.25 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61950.45006.25873 - - - state - current - - - time - - - - - - - - - 1574329058.14 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61953.41665.18483 - - - state - current - - - time - - - - - - - - - 1574329244.42 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61956.48527.26880 - - - state - current - - - time - - - - - - - - - 1574329481.16 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61960.44965.38075 - - - state - current - - - time - - - - - - - - - 1574329491.66 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61960.56435.41181 - - - state - current - - - time - - - - - - - - - 1574329517.12 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61961.18710.238 - - - state - current - - - time - - - - - - - - - 1574329524.83 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61961.27126.52992 - - - state - current - - - time - - - - - - - - - 1574329548.23 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61961.52681.35140 - - - state - current - - - time - - - - - - - - - 1574329610.14 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61962.54770.6109 - - - state - current - - - time - - - - - - - - - 1574329618.9 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61962.64337.54272 - - - state - current - - - time - - - - - - - - - 1574329630.75 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61963.11749.30293 - - - state - current - - - time - - - - - - - - - 1574329651.09 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61963.33962.34389 - - - state - current - - - time - - - - - - - - - 1574329665.75 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61963.49975.1860 - - - state - current - - - time - - - - - - - - - 1574329684.61 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61964.5044.3515 - - - state - current - - - time - - - - - - - - - 1574329725.87 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61964.50110.5427 - - - state - current - - - time - - - - - - - - - 1574329792.87 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.61965.57749.53930 - - - state - current - - - time - - - - - - - - - 1574333504.33 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62027.48424.22186 - - - state - current - - - time - - - - - - - - - 1574333540.39 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62028.22281.31658 - - - state - current - - - time - - - - - - - - - 1574333546.63 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62028.29088.60535 - - - state - current - - - time - - - - - - - - - 1574333578.09 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62028.63457.3959 - - - state - current - - - time - - - - - - - - - 1574333588.59 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62029.9391.19456 - - - state - current - - - time - - - - - - - - - 1574333680.86 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62030.44640.11980 - - - state - current - - - time - - - - - - - - - 1574333691.05 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62030.55770.24268 - - - state - current - - - time - - - - - - - - - 1574333695.51 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62030.55770.24268 - - - state - current - - - time - - - - - - - - - 1574333703.68 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62030.55770.24268 - - - state - current - - - time - - - - - - - - - 1574333724.09 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62031.26316.48913 - - - state - current - - - time - - - - - - - - - 1574333754.93 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62031.60011.63180 - - - state - current - - - time - - - - - - - - - 1574333791.01 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62032.33877.17049 - - - state - current - - - time - - - - - - - - - 1574333800.61 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62032.44371.3805 - - - state - current - - - time - - - - - - - - - 1574333880.66 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62034.728.43673 - - - state - current - - - time - - - - - - - - - 1574333903.9 - UTC - - - - - - - - - - - _next - - AAAAAAAAAAc= - - - - _prev - - AAAAAAAAAAQ= - - - - - - - - - - - - - _log - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62034.26107.12646 - - - state - current - - - time - - - - - - - - - - - 1574334426.15 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62043.6727.63897 - - - state - current - - - time - - - - - - - - - 1574334434.07 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62043.15372.1979 - - - state - current - - - time - - - - - - - - - 1574334459.67 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62043.43339.58368 - - - state - current - - - time - - - - - - - - - 1574334473.18 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62043.58096.27869 - - - state - current - - - time - - - - - - - - - 1574334938.08 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62051.41603.16452 - - - state - current - - - time - - - - - - - - - 1574334949.25 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62051.53805.39168 - - - state - current - - - time - - - - - - - - - 1574335000.76 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62052.44527.12595 - - - state - current - - - time - - - - - - - - - 1574335009.11 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62052.53648.38587 - - - state - current - - - time - - - - - - - - - 1574335034.19 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62053.15499.63539 - - - state - current - - - time - - - - - - - - - 1574335260.18 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62057.201.30139 - - - state - current - - - time - - - - - - - - - 1574335275.2 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62057.16612.7850 - - - state - current - - - time - - - - - - - - - 1574335306.78 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62057.51100.60962 - - - state - current - - - time - - - - - - - - - 1574335319.75 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62057.65272.3805 - - - state - current - - - time - - - - - - - - - 1574335338.51 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62058.20221.31044 - - - state - current - - - time - - - - - - - - - 1574335518.14 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62061.19823.20002 - - - state - current - - - time - - - - - - - - - 1574339757.58 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62131.62904.38792 - - - state - current - - - time - - - - - - - - - 1574339781.65 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62132.23662.32563 - - - state - current - - - time - - - - - - - - - 1574339815.15 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62132.60242.36198 - - - state - current - - - time - - - - - - - - - 1574339853.78 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62133.36904.64409 - - - state - current - - - time - - - - - - - - - 1574341175.19 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62155.38441.25361 - - - state - current - - - time - - - - - - - - - 1574341251.38 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 979.62156.56125.51746 - - - state - current - - - time - - - - - - - - - 1574341335.11 - UTC - - - - - - - - - action - edit - - - actor - zope - - - comment - - - - - - error_message - - - - serial - 981.4762.16692.46353 - - - state - current - - - time - - - - - - - - - 1579082557.27 - UTC - - - - - - - - - - - _next - - AAAAAAAAAAQ= - - - - _prev - - AAAAAAAAAAY= - - - - _tail_count - 52 - - - - diff --git a/bt5/erp5_document_scanner/PortalTypePropertySheetTemplateItem/property_sheet_list.xml b/bt5/erp5_document_scanner/PortalTypePropertySheetTemplateItem/property_sheet_list.xml new file mode 100644 index 0000000000000000000000000000000000000000..a338d10d476c4c5574d94f2c39a7345c42a5ed61 --- /dev/null +++ b/bt5/erp5_document_scanner/PortalTypePropertySheetTemplateItem/property_sheet_list.xml @@ -0,0 +1,5 @@ + + + Reference + + \ No newline at end of file diff --git a/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference.xml b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference.xml new file mode 100644 index 0000000000000000000000000000000000000000..749538fd3c40dd15e8c7ef56b7aa344560423252 --- /dev/null +++ b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference.xml @@ -0,0 +1,66 @@ + + + + + + + + + + _count + + AAAAAAAAAAI= + + + + _mt_index + + AAAAAAAAAAM= + + + + _tree + + AAAAAAAAAAQ= + + + + description + + + + + + id + DocumentScannerPreference + + + portal_type + Property Sheet + + + + + + + + + 0 + + + + + + + + + + + + + + + + + + diff --git a/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_brightness_property.xml b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_brightness_property.xml new file mode 100644 index 0000000000000000000000000000000000000000..981bc70917c7218ff0b011c9919f2c7ba7f97911 --- /dev/null +++ b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_brightness_property.xml @@ -0,0 +1,59 @@ + + + + + + + + + + _local_properties + + + + + id + mode + + + type + string + + + + + + + categories + + + elementary_type/float + + + + + description + + + + + + id + preferred_image_scanner_conversion_brightness_property + + + mode + + + + portal_type + Standard Property + + + preference + 1 + + + + + diff --git a/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_compression_property.xml b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_compression_property.xml new file mode 100644 index 0000000000000000000000000000000000000000..fb8a1a0eaff152929006490a5fe78cbb9eb61f16 --- /dev/null +++ b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_compression_property.xml @@ -0,0 +1,59 @@ + + + + + + + + + + _local_properties + + + + + id + mode + + + type + string + + + + + + + categories + + + elementary_type/float + + + + + description + + + + + + id + preferred_image_scanner_conversion_compression_property + + + mode + + + + portal_type + Standard Property + + + preference + 1 + + + + + diff --git a/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_contrast_property.xml b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_contrast_property.xml new file mode 100644 index 0000000000000000000000000000000000000000..df0ebc4d797eb4f36591a8385ac70fdbf3f3c89c --- /dev/null +++ b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_contrast_property.xml @@ -0,0 +1,59 @@ + + + + + + + + + + _local_properties + + + + + id + mode + + + type + string + + + + + + + categories + + + elementary_type/int + + + + + description + + + + + + id + preferred_image_scanner_conversion_contrast_property + + + mode + + + + portal_type + Standard Property + + + preference + 1 + + + + + diff --git a/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_enable_greyscale_property.xml b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_enable_greyscale_property.xml new file mode 100644 index 0000000000000000000000000000000000000000..55f4127aa4d6346dc603e3f2b3bbb8aeb97638a2 --- /dev/null +++ b/bt5/erp5_document_scanner/PropertySheetTemplateItem/portal_property_sheets/DocumentScannerPreference/preferred_image_scanner_conversion_enable_greyscale_property.xml @@ -0,0 +1,59 @@ + + + + + + + + + + _local_properties + + + + + id + mode + + + type + string + + + + + + + categories + + + elementary_type/boolean + + + + + description + + + + + + id + preferred_image_scanner_conversion_enable_greyscale_property + + + mode + + + + portal_type + Standard Property + + + preference + 1 + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/ActiveProcess_removeItselfFromActivityTool.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/ActiveProcess_removeItselfFromActivityTool.py new file mode 100644 index 0000000000000000000000000000000000000000..fe9f5217da27d283d07ee7d323b776118584b962 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/ActiveProcess_removeItselfFromActivityTool.py @@ -0,0 +1,5 @@ +assert context.getPortalType() == "Active Process", "It must be an Active Process" +assert context.getReference() == context.Base_getDocumentScannerDefaultReference(), "Unexpected reference" + +context.getPortalObject().portal_activities.manage_delObjects( + ids=[context.getId(),]) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_removeActiveProcessFromActivityTool.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/ActiveProcess_removeItselfFromActivityTool.xml similarity index 85% rename from bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_removeActiveProcessFromActivityTool.xml rename to bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/ActiveProcess_removeItselfFromActivityTool.xml index 7d180b28ae5a9b3371e52569b72e353534325cb7..f94ae5aacd4375f8acc8c5573158480bdf3d369c 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_removeActiveProcessFromActivityTool.xml +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/ActiveProcess_removeItselfFromActivityTool.xml @@ -50,19 +50,11 @@ _params - active_process - - - _proxy_roles - - - Manager - - + id - Base_removeActiveProcessFromActivityTool + ActiveProcess_removeItselfFromActivityTool diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Alarm_removeOutdatedActiveProcess.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Alarm_removeOutdatedActiveProcess.py new file mode 100644 index 0000000000000000000000000000000000000000..62cd3545bbeec647d45b6f0f24a50a8eec006b7c --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Alarm_removeOutdatedActiveProcess.py @@ -0,0 +1,9 @@ +portal = context.getPortalObject() + +portal.portal_catalog.searchAndActivate( + portal_type=["Active Process",], + method_id='ActiveProcess_removeItselfFromActivityTool', + reference=context.Base_getDocumentScannerDefaultReference(), + # Active Process don't have creation date set + modification_date="< %s" % (DateTime()-4).earliestTime(), +) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Alarm_removeOutdatedActiveProcess.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Alarm_removeOutdatedActiveProcess.xml new file mode 100644 index 0000000000000000000000000000000000000000..285f32086927a210cb332952f968df744ea445f2 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Alarm_removeOutdatedActiveProcess.xml @@ -0,0 +1,62 @@ + + + + + + + + + + Script_magic + 3 + + + _bind_names + + + + + + + + + + _asgns + + + + name_container + container + + + name_context + context + + + name_m_self + script + + + name_subpath + traverse_subpath + + + + + + + + + + + _params + + + + id + Alarm_removeOutdatedActiveProcess + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDefaultBackendDataAsJSON.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDefaultBackendDataAsJSON.py new file mode 100644 index 0000000000000000000000000000000000000000..c9b44ae8d9fcfb39ba3570d8800b4748cf3c4b58 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDefaultBackendDataAsJSON.py @@ -0,0 +1,9 @@ +import json + +active_process = context.getPortalObject().portal_activities.newActiveProcess( + reference=context.Base_getDocumentScannerDefaultReference()) + +return json.dumps({ + "active_process": active_process.getRelativeUrl(), + "image_list": [] +}) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDefaultBackendDataAsJSON.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDefaultBackendDataAsJSON.xml new file mode 100644 index 0000000000000000000000000000000000000000..6ecf8f8573d4b7cb74e6ef35ce9b3307f65611af --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDefaultBackendDataAsJSON.xml @@ -0,0 +1,62 @@ + + + + + + + + + + Script_magic + 3 + + + _bind_names + + + + + + + + + + _asgns + + + + name_container + container + + + name_context + context + + + name_m_self + script + + + name_subpath + traverse_subpath + + + + + + + + + + + _params + + + + id + Base_getDefaultBackendDataAsJSON + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDocumentScannerDefaultReference.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDocumentScannerDefaultReference.py new file mode 100644 index 0000000000000000000000000000000000000000..3c9deb1dcf6a78dad4e470e353b548153d51400f --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDocumentScannerDefaultReference.py @@ -0,0 +1 @@ +return "document_scanner_js" diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDocumentScannerDefaultReference.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDocumentScannerDefaultReference.xml new file mode 100644 index 0000000000000000000000000000000000000000..ce94818e61d9761c0a58157f13bb9471054e225d --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getDocumentScannerDefaultReference.xml @@ -0,0 +1,62 @@ + + + + + + + + + + Script_magic + 3 + + + _bind_names + + + + + + + + + + _asgns + + + + name_container + container + + + name_context + context + + + name_m_self + script + + + name_subpath + traverse_subpath + + + + + + + + + + + _params + + + + id + Base_getDocumentScannerDefaultReference + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredCropperSettingsFromSelection.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredCropperSettingsFromSelection.py index 9fd6782b15fe50e83406201dc3dd610387ee26a8..629e0d88d6a64f0516fb2ded036d8e51155f09b0 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredCropperSettingsFromSelection.py +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredCropperSettingsFromSelection.py @@ -7,6 +7,4 @@ selection_mapping = portal.portal_selections.getSelectionParamsFor( REQUEST=context.REQUEST) or {} canvas_data = selection_mapping.get(context.REQUEST["HTTP_USER_AGENT"]) or {} -canvas_data["dialog_method"] = context.Base_storeDocumentFromCameraInActiveProcess.getId() - return json.dumps(canvas_data) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredImageSettingsFromPreference.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredImageSettingsFromPreference.py new file mode 100644 index 0000000000000000000000000000000000000000..3fead8983ab930b2219ccd67b4f6d04745d2f537 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredImageSettingsFromPreference.py @@ -0,0 +1,15 @@ +import json + +portal = context.getPortalObject() +active_preference = portal.portal_preferences.getActiveUserPreference() +if not active_preference: + active_preference = portal.portal_preferences.getActivePreference() + +setting_dict = { + "compression": active_preference.getPreferredImageScannerConversionCompression(), + "enable_greyscale": active_preference.getPreferredImageScannerConversionEnableGreyscale(), + "brightness": active_preference.getPreferredImageScannerConversionBrightness(), + "contrast": active_preference.getPreferredImageScannerConversionContrast(), +} + +return json.dumps(setting_dict) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredImageSettingsFromPreference.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredImageSettingsFromPreference.xml new file mode 100644 index 0000000000000000000000000000000000000000..116a266fbee98c5db65fd3a9b725e963734a0653 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getPreferredImageSettingsFromPreference.xml @@ -0,0 +1,62 @@ + + + + + + + + + + Script_magic + 3 + + + _bind_names + + + + + + + + + + _asgns + + + + name_container + container + + + name_context + context + + + name_m_self + script + + + name_subpath + traverse_subpath + + + + + + + + + + + _params + + + + id + Base_getPreferredImageSettingsFromPreference + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getTempImageList.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getTempImageList.py index 9bf0f212ec782fc577b7668790f8755a06158a45..f3ec6775067e34ab66833362897a0346fd595371 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getTempImageList.py +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getTempImageList.py @@ -1,6 +1,7 @@ """ Proxy role as Manager is required here to access getResultList """ +from base64 import decodestring if REQUEST: return RuntimeError("You cannot run this script in the url") @@ -8,9 +9,10 @@ image_module = context.getPortalObject().image_module pdf_data_list = [] for result in active_process.getResultList(): - pdf_data_list.append( - image_module.newContent(data=result.detail, - portal_type="Image", - temp_object=True).convert(format="pdf")[1]) + if result.reference in image_list: + pdf_data_list.append( + image_module.newContent(data=decodestring(result.detail), + portal_type="Image", + temp_object=True).convert(format="pdf")[1]) return pdf_data_list diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getTempImageList.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getTempImageList.xml index 2b1fd5a7338045904401791fce0847aee882cb5e..16b453294e42b670c7fea2df85f2be23d2b03b3d 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getTempImageList.xml +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_getTempImageList.xml @@ -50,7 +50,7 @@ _params - active_process, REQUEST=None + active_process, image_list, REQUEST=None _proxy_roles diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_postDataToActiveResult.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_postDataToActiveResult.py index 19b37877ad01e7c38b25fac8e5dc1d3083224b30..ad5835bb80f806ed121ee22b5436e3cbb16936e2 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_postDataToActiveResult.py +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_postDataToActiveResult.py @@ -2,16 +2,26 @@ We need proy role as manager to create a new active process and post active result """ +import string +import random + portal = context.getPortalObject() if REQUEST: return RuntimeError("You cannot run this script in the url") +reference = context.Base_getDocumentScannerDefaultReference() if active_process_url: active_process = portal.restrictedTraverse(active_process_url) else: - active_process = portal.portal_activities.newActiveProcess() + active_process = portal.portal_activities.newActiveProcess( + reference=reference) -active_process.postActiveResult(detail=detail) +if generate_new_uid: + id_group = (reference, active_process.getUid()) + new_uid = portal.portal_ids.generateNewId(id_group=id_group, default=0) +else: + new_uid = None -return active_process +active_process.postActiveResult(detail=detail, reference=new_uid) +return active_process, new_uid diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_postDataToActiveResult.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_postDataToActiveResult.xml index aebf41d96ca1835fcd9a9b708a14bb931c103af2..35be01bdfabae5dc44dada59216e82e9c68df985 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_postDataToActiveResult.xml +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_postDataToActiveResult.xml @@ -50,7 +50,7 @@ _params - active_process_url, detail, REQUEST=None, **kw + active_process_url, detail, generate_new_uid=False, REQUEST=None, **kw _proxy_roles diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_removeActiveProcessFromActivityTool.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_removeActiveProcessFromActivityTool.py deleted file mode 100644 index 5ddd3718c0c553231954131a5ebe13cbd23789ba..0000000000000000000000000000000000000000 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_removeActiveProcessFromActivityTool.py +++ /dev/null @@ -1,2 +0,0 @@ -context.getPortalObject().portal_activities.manage_delObjects( - ids=[active_process.getId(),]) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeDocumentFromCameraInActiveProcess.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeDocumentFromCameraInActiveProcess.py index d39242917ec09b228c30f597f144f7a734933798..a670922147d44f3ca0ffee485c84adb87428174b 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeDocumentFromCameraInActiveProcess.py +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeDocumentFromCameraInActiveProcess.py @@ -13,7 +13,7 @@ selection_mapping = portal.portal_selections.getSelectionParamsFor( REQUEST=context.REQUEST) or {} http_user_agent = context.REQUEST["HTTP_USER_AGENT"] -selection_mapping[http_user_agent] = preferred_cropped_canvas_data +selection_mapping[http_user_agent] = preferred_cropped_canvas_data or {} portal.portal_selections.setSelectionParamsFor( context.Base_getDocumentScannerSelectionName(), @@ -30,7 +30,7 @@ if not image_str: return context.Base_renderForm('Base_viewUploadDocumentFromCameraDialog', message=translateString('Nothing to capture')) -active_process = context.Base_postDataToActiveResult( +active_process, _ = context.Base_postDataToActiveResult( active_process_url, image_str) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeNewImageCropped.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeNewImageCropped.py new file mode 100644 index 0000000000000000000000000000000000000000..1540954c9f78f6ac41fa3cee911bbdd6c5375b3c --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeNewImageCropped.py @@ -0,0 +1,6 @@ +import json + +_, uuid = context.Base_postDataToActiveResult( + active_process_url, input_value, + generate_new_uid=True) +return json.dumps({"uuid": uuid}) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeNewImageCropped.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeNewImageCropped.xml new file mode 100644 index 0000000000000000000000000000000000000000..711192e99d6275850d7e3b6f8ce6d14869c2de77 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_storeNewImageCropped.xml @@ -0,0 +1,62 @@ + + + + + + + + + + Script_magic + 3 + + + _bind_names + + + + + + + + + + _asgns + + + + name_container + container + + + name_context + context + + + name_m_self + script + + + name_subpath + traverse_subpath + + + + + + + + + + + _params + input_value, active_process_url, **kw + + + id + Base_storeNewImageCropped + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCamera.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCamera.py index 32cdbc7816159da02b4318ea9c419406e935c204..0537dc94132a95987c6dc5a81a9015087d55e1c1 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCamera.py +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCamera.py @@ -5,9 +5,9 @@ class StringIOWithFileName(StringIO): kw.get("title") or DateTime().strftime('%d-%m-%Y_%Hh%M')) portal = context.getPortalObject() -active_process = portal.restrictedTraverse(active_process_url) +active_process = portal.restrictedTraverse(str(active_process_url)) -pdf_data_list = context.Base_getTempImageList(active_process) +pdf_data_list = context.Base_getTempImageList(active_process, image_list) pdf_data = context.ERP5Site_mergePDFList(pdf_data_list=pdf_data_list) file_object = StringIOWithFileName(pdf_data) diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCamera.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCamera.xml index 0c0905377cf04f5fa0bd4ea2c0975695d03d1ed1..994d863fcf052f90a86cf28c47ef64a74162ac60 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCamera.xml +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCamera.xml @@ -50,7 +50,7 @@ _params - publication_state, active_process_url=None, **kw + publication_state, active_process_url, image_list, **kw id diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCameraByActivity.py b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCameraByActivity.py index 88daa42965f3fc9a41c04378e8a2b80ee27d7950..114c285b24d73827fea5eee476372fd7929d51b9 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCameraByActivity.py +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCameraByActivity.py @@ -1,16 +1,19 @@ +import json + +data_dict = json.loads(data_json) portal = context.getPortalObject() translateString = portal.Base_translateString -active_process = context.Base_storeDocumentFromCameraInActiveProcess( - active_process_url=active_process_url, - batch_mode=True, - **kw) +active_process_url = data_dict.pop("active_process") +image_list = data_dict.pop("image_list") # Avoid to pass huge images to the activity kw.pop("your_document_scanner_gadget", None) context.activate().Base_uploadDocumentFromCamera( - active_process_url=active_process.getRelativeUrl(), + publication_state=publication_state, + active_process_url=active_process_url, + image_list=image_list, **kw) return context.Base_redirect('view', diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCameraByActivity.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCameraByActivity.xml index 79f84fcd9d93fa6bb4aab8eb22604687e6760fc3..5feee9b571807e329298c8405fc78ea26f9d0e08 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCameraByActivity.xml +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_uploadDocumentFromCameraByActivity.xml @@ -50,7 +50,7 @@ _params - active_process_url=None, **kw + data_json, publication_state, **kw id diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog.xml index 7495b0edfd0a5c0bfa562e815f8e82411338829f..617f4ea965f8c817a8c1e9ac5aee869a8df7f601 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog.xml +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog.xml @@ -95,7 +95,6 @@ left - your_active_process_url your_document_scanner_gadget diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog/your_document_scanner_gadget.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog/your_document_scanner_gadget.xml index 3df51736aa29a80c3bf387071d421d2e8827063a..ae71d97cd2c99a6589b3fa2a8dd283c413fd0921 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog/your_document_scanner_gadget.xml +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog/your_document_scanner_gadget.xml @@ -10,6 +10,7 @@ delegated_list + default gadget_url renderjs_extra title @@ -51,6 +52,12 @@ tales + + default + + AAAAAAAAAAI= + + field_id @@ -62,19 +69,19 @@ gadget_url - AAAAAAAAAAI= + AAAAAAAAAAM= renderjs_extra - AAAAAAAAAAM= + AAAAAAAAAAQ= title - AAAAAAAAAAQ= + AAAAAAAAAAU= @@ -88,6 +95,10 @@ values + + default + + field_id my_gadget_field @@ -128,7 +139,7 @@ _text - string: gadget_document_scanner.html + python: here.Base_getDefaultBackendDataAsJSON() @@ -141,12 +152,25 @@ _text - python: [(\'preferred_cropped_canvas_data\', context.Base_getPreferredCropperSettingsFromSelection()),] + python: [(\'preferred_cropped_canvas_data\', context.Base_getPreferredCropperSettingsFromSelection()), (\'preferred_image_settings_data\', context.Base_getPreferredImageSettingsFromPreference()), ("dialog_method", context.Base_storeDocumentFromCameraInActiveProcess.getId())] + + + + + + + _text + python: [(\'dialog_method\', \'Base_storeDocumentFromCameraInActiveProcess\'), (\'preferred_cropped_canvas_data\', context.Base_getPreferredCropperSettingsFromSelection()), ("store_new_image_cropped_method", \'Base_storeNewImageCropped\')] + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting.xml new file mode 100644 index 0000000000000000000000000000000000000000..b75d59c67568fb5df48ad3b443179342487843ee --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting.xml @@ -0,0 +1,146 @@ + + + + + + + + + + _bind_names + + + + + + + + + + _asgns + + + + + + + + + + + _objects + + + + + + action + Base_edit + + + action_title + + + + description + + + + edit_order + + + + + + encoding + UTF-8 + + + enctype + + + + group_list + + + left + right + center + + + + + groups + + + + center + + + + + + left + + + my_preferred_image_scanner_conversion_enable_greyscale + + + + + right + + + my_preferred_image_scanner_conversion_compression + my_preferred_image_scanner_conversion_brightness + my_preferred_image_scanner_conversion_contrast + + + + + + + + id + Preference_viewDocumentScannerSettting + + + method + POST + + + name + Preference_viewDocumentScannerSettting + + + pt + form_view + + + row_length + 4 + + + stored_encoding + UTF-8 + + + title + Document Scanner + + + unicode_mode + 0 + + + update_action + + + + update_action_title + + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_brightness.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_brightness.xml new file mode 100644 index 0000000000000000000000000000000000000000..c8e0cdd5fa53c46f1777864c8d0a8daaede969de --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_brightness.xml @@ -0,0 +1,96 @@ + + + + + + + + + + delegated_list + + + title + + + + + id + my_preferred_image_scanner_conversion_brightness + + + message_values + + + + external_validator_failed + The input failed the external validator. + + + + + + overrides + + + + field_id + + + + form_id + + + + target + + + + + + + tales + + + + field_id + + + + form_id + + + + target + + + + + + + values + + + + field_id + my_float_field + + + form_id + Base_viewFieldLibrary + + + target + Click to edit the target + + + title + Brightness [-100 .. 100] + + + + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_compression.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_compression.xml new file mode 100644 index 0000000000000000000000000000000000000000..ace59bfd9c9d32e0ef69ab880d345fbae3a61636 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_compression.xml @@ -0,0 +1,96 @@ + + + + + + + + + + delegated_list + + + title + + + + + id + my_preferred_image_scanner_conversion_compression + + + message_values + + + + external_validator_failed + The input failed the external validator. + + + + + + overrides + + + + field_id + + + + form_id + + + + target + + + + + + + tales + + + + field_id + + + + form_id + + + + target + + + + + + + values + + + + field_id + my_float_field + + + form_id + Base_viewFieldLibrary + + + target + Click to edit the target + + + title + Image compression [0 .. 1] + + + + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_contrast.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_contrast.xml new file mode 100644 index 0000000000000000000000000000000000000000..8a2bb4e03f0d11ed19c93ace8c333f100ed1a514 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_contrast.xml @@ -0,0 +1,96 @@ + + + + + + + + + + delegated_list + + + title + + + + + id + my_preferred_image_scanner_conversion_contrast + + + message_values + + + + external_validator_failed + The input failed the external validator. + + + + + + overrides + + + + field_id + + + + form_id + + + + target + + + + + + + tales + + + + field_id + + + + form_id + + + + target + + + + + + + values + + + + field_id + my_integer_value + + + form_id + Base_viewFieldLibrary + + + target + Click to edit the target + + + title + Contrast [-100 .. 100] + + + + + + + + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog/your_active_process_url.xml b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_enable_greyscale.xml similarity index 89% rename from bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog/your_active_process_url.xml rename to bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_enable_greyscale.xml index b12726a259ea9d325480d7532d4bc076a339d3ff..fdab7fdb4d3ac90780b7464332a9bd59ae905453 100644 --- a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Base_viewUploadDocumentFromCameraDialog/your_active_process_url.xml +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/Preference_viewDocumentScannerSettting/my_preferred_image_scanner_conversion_enable_greyscale.xml @@ -10,13 +10,13 @@ delegated_list - hidden + title id - your_active_process_url + my_preferred_image_scanner_conversion_enable_greyscale message_values @@ -73,20 +73,20 @@ field_id - my_string_field + your_checkbox form_id Base_viewFieldLibrary - - hidden - 1 - target Click to edit the target + + title + Enable Greyscale + diff --git a/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/caman.full.min.js.js b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/caman.full.min.js.js new file mode 100644 index 0000000000000000000000000000000000000000..437fbcabece4d519d2336f26b4bbdbbd038d8059 --- /dev/null +++ b/bt5/erp5_document_scanner/SkinTemplateItem/portal_skins/erp5_document_scanner/caman.full.min.js.js @@ -0,0 +1,251 @@ + +(function(){var $,Analyze,Blender,Calculate,Caman,CamanParser,Canvas,Convert,Event,Fiber,Filter,IO,Image,Layer,Log,Module,Pixel,Plugin,Renderer,Root,Store,Util,fs,http,moduleKeywords,slice,vignetteFilters,__indexOf=[].indexOf||function(item){for(var i=0,l=this.length;i255){return 255;} +return val;};Util.copyAttributes=function(from,to,opts){var attr,_i,_len,_ref,_ref1,_results;if(opts==null){opts={};} +_ref=from.attributes;_results=[];for(_i=0,_len=_ref.length;_i<_len;_i++){attr=_ref[_i];if((opts.except!=null)&&(_ref1=attr.nodeName,__indexOf.call(opts.except,_ref1)>=0)){continue;} +_results.push(to.setAttribute(attr.nodeName,attr.nodeValue));} +return _results;};Util.dataArray=function(length){if(length==null){length=0;} +if(Caman.NodeJS||(window.Uint8Array!=null)){return new Uint8Array(length);} +return new Array(length);};return Util;})();if(typeof exports!=="undefined"&&exports!==null){Root=exports;Canvas=require('canvas');Image=Canvas.Image;Fiber=require('fibers');fs=require('fs');http=require('http');}else{Root=window;} +Caman=(function(_super){__extends(Caman,_super);Caman.version={release:"4.1.2",date:"7/27/2013"};Caman.DEBUG=false;Caman.allowRevert=true;Caman.crossOrigin="anonymous";Caman.remoteProxy="";Caman.proxyParam="camanProxyUrl";Caman.NodeJS=typeof exports!=="undefined"&&exports!==null;Caman.autoload=!Caman.NodeJS;Caman.toString=function(){return"Version "+Caman.version.release+", Released "+Caman.version.date;};Caman.getAttrId=function(canvas){if(Caman.NodeJS){return true;} +if(typeof canvas==="string"){canvas=$(canvas);} +if(!((canvas!=null)&&(canvas.getAttribute!=null))){return null;} +return canvas.getAttribute('data-caman-id');};function Caman(){this.nodeFileReady=__bind(this.nodeFileReady,this);var args,callback,id,_this=this;if(arguments.length===0){throw"Invalid arguments";} +if(this instanceof Caman){this.finishInit=this.finishInit.bind(this);this.imageLoaded=this.imageLoaded.bind(this);args=arguments[0];if(!Caman.NodeJS){id=parseInt(Caman.getAttrId(args[0]),10);callback=typeof args[1]==="function"?args[1]:typeof args[2]==="function"?args[2]:function(){};if(!isNaN(id)&&Store.has(id)){return Store.execute(id,callback);}} +this.id=Util.uniqid.get();this.initializedPixelData=this.originalPixelData=null;this.cropCoordinates={x:0,y:0};this.cropped=false;this.resized=false;this.pixelStack=[];this.layerStack=[];this.canvasQueue=[];this.currentLayer=null;this.scaled=false;this.analyze=new Analyze(this);this.renderer=new Renderer(this);this.domIsLoaded(function(){_this.parseArguments(args);return _this.setup();});return this;}else{return new Caman(arguments);}} +Caman.prototype.domIsLoaded=function(cb){var listener,_this=this;if(Caman.NodeJS){return setTimeout(function(){return cb.call(_this);},0);}else{if(document.readyState==="complete"){Log.debug("DOM initialized");return setTimeout(function(){return cb.call(_this);},0);}else{listener=function(){if(document.readyState==="complete"){Log.debug("DOM initialized");return cb.call(_this);}};return document.addEventListener("readystatechange",listener,false);}}};Caman.prototype.parseArguments=function(args){var key,val,_ref,_results;if(args.length===0){throw"Invalid arguments given";} +this.initObj=null;this.initType=null;this.imageUrl=null;this.callback=function(){};this.setInitObject(args[0]);if(args.length===1){return;} +switch(typeof args[1]){case"string":this.imageUrl=args[1];break;case"function":this.callback=args[1];} +if(args.length===2){return;} +this.callback=args[2];if(args.length===4){_ref=args[4];_results=[];for(key in _ref){if(!__hasProp.call(_ref,key))continue;val=_ref[key];_results.push(this.options[key]=val);} +return _results;}};Caman.prototype.setInitObject=function(obj){if(Caman.NodeJS){this.initObj=obj;this.initType='node';return;} +if(typeof obj==="object"){this.initObj=obj;}else{this.initObj=$(obj);} +if(this.initObj==null){throw"Could not find image or canvas for initialization.";} +return this.initType=this.initObj.nodeName.toLowerCase();};Caman.prototype.setup=function(){switch(this.initType){case"node":return this.initNode();case"img":return this.initImage();case"canvas":return this.initCanvas();}};Caman.prototype.initNode=function(){Log.debug("Initializing for NodeJS");if(typeof this.initObj==="string"&&this.initObj.match(/^https?:\/\//)){return this.readFromHttp(this.initObj,this.nodeFileReady);}else if(typeof this.initObj==="string"){return fs.readFile(this.initObj,this.nodeFileReady);}else{return this.nodeFileReady(null,this.initObj);}};Caman.prototype.readFromHttp=function(url,callback){var req;Log.debug("Fetching image from "+url);req=http.get(url,function(res){var buf;buf='';res.setEncoding('binary');res.on('data',function(chunk){return buf+=chunk;});return res.on('end',function(){return callback(null,new Buffer(buf,'binary'));});});return req.on('error',callback);};Caman.prototype.nodeFileReady=function(err,data){if(err){throw err;} +this.image=new Image();this.image.src=data;Log.debug("Image loaded. Width = "+(this.imageWidth())+", Height = "+(this.imageHeight()));this.canvas=new Canvas(this.imageWidth(),this.imageHeight());return this.finishInit();};Caman.prototype.initImage=function(){this.image=this.initObj;this.canvas=document.createElement('canvas');this.context=this.canvas.getContext('2d');Util.copyAttributes(this.image,this.canvas,{except:['src']});if(this.image.parentNode!=null){this.image.parentNode.replaceChild(this.canvas,this.image);} +this.imageAdjustments();return this.waitForImageLoaded();};Caman.prototype.initCanvas=function(){this.canvas=this.initObj;this.context=this.canvas.getContext('2d');if(this.imageUrl!=null){this.image=document.createElement('img');this.image.src=this.imageUrl;this.imageAdjustments();return this.waitForImageLoaded();}else{return this.finishInit();}};Caman.prototype.imageAdjustments=function(){if(this.needsHiDPISwap()){Log.debug(this.image.src,"->",this.hiDPIReplacement());this.swapped=true;this.image.src=this.hiDPIReplacement();} +if(IO.isRemote(this.image)){this.image.src=IO.proxyUrl(this.image.src);return Log.debug("Remote image detected, using URL = "+this.image.src);}};Caman.prototype.waitForImageLoaded=function(){if(this.isImageLoaded()){return this.imageLoaded();}else{return this.image.onload=this.imageLoaded;}};Caman.prototype.isImageLoaded=function(){if(!this.image.complete){return false;} +if((this.image.naturalWidth!=null)&&this.image.naturalWidth===0){return false;} +return true;};Caman.prototype.imageWidth=function(){return this.image.width||this.image.naturalWidth;};Caman.prototype.imageHeight=function(){return this.image.height||this.image.naturalHeight;};Caman.prototype.imageLoaded=function(){Log.debug("Image loaded. Width = "+(this.imageWidth())+", Height = "+(this.imageHeight()));if(this.swapped){this.canvas.width=this.imageWidth()/this.hiDPIRatio();this.canvas.height=this.imageHeight()/this.hiDPIRatio();}else{this.canvas.width=this.imageWidth();this.canvas.height=this.imageHeight();} +return this.finishInit();};Caman.prototype.finishInit=function(){var i,pixel,_i,_len,_ref;if(this.context==null){this.context=this.canvas.getContext('2d');} +this.originalWidth=this.preScaledWidth=this.width=this.canvas.width;this.originalHeight=this.preScaledHeight=this.height=this.canvas.height;this.hiDPIAdjustments();if(!this.hasId()){this.assignId();} +if(this.image!=null){this.context.drawImage(this.image,0,0,this.imageWidth(),this.imageHeight(),0,0,this.preScaledWidth,this.preScaledHeight);} +this.imageData=this.context.getImageData(0,0,this.canvas.width,this.canvas.height);this.pixelData=this.imageData.data;if(Caman.allowRevert){this.initializedPixelData=Util.dataArray(this.pixelData.length);this.originalPixelData=Util.dataArray(this.pixelData.length);_ref=this.pixelData;for(i=_i=0,_len=_ref.length;_i<_len;i=++_i){pixel=_ref[i];this.initializedPixelData[i]=pixel;this.originalPixelData[i]=pixel;}} +this.dimensions={width:this.canvas.width,height:this.canvas.height};if(!Caman.NodeJS){Store.put(this.id,this);} +this.callback.call(this,this);return this.callback=function(){};};Caman.prototype.reloadCanvasData=function(){this.imageData=this.context.getImageData(0,0,this.canvas.width,this.canvas.height);return this.pixelData=this.imageData.data;};Caman.prototype.resetOriginalPixelData=function(){var i,pixel,_i,_len,_ref,_results;if(!Caman.allowRevert){throw"Revert disabled";} +this.originalPixelData=Util.dataArray(this.pixelData.length);_ref=this.pixelData;_results=[];for(i=_i=0,_len=_ref.length;_i<_len;i=++_i){pixel=_ref[i];_results.push(this.originalPixelData[i]=pixel);} +return _results;};Caman.prototype.hasId=function(){return Caman.getAttrId(this.canvas)!=null;};Caman.prototype.assignId=function(){if(Caman.NodeJS||this.canvas.getAttribute('data-caman-id')){return;} +return this.canvas.setAttribute('data-caman-id',this.id);};Caman.prototype.hiDPIDisabled=function(){return this.canvas.getAttribute('data-caman-hidpi-disabled')!==null;};Caman.prototype.hiDPIAdjustments=function(){var ratio;if(Caman.NodeJS||!this.needsHiDPISwap()){return;} +ratio=this.hiDPIRatio();if(ratio!==1){Log.debug("HiDPI ratio = "+ratio);this.scaled=true;this.preScaledWidth=this.canvas.width;this.preScaledHeight=this.canvas.height;this.canvas.width=this.preScaledWidth*ratio;this.canvas.height=this.preScaledHeight*ratio;this.canvas.style.width=""+this.preScaledWidth+"px";this.canvas.style.height=""+this.preScaledHeight+"px";this.context.scale(ratio,ratio);this.width=this.originalWidth=this.canvas.width;return this.height=this.originalHeight=this.canvas.height;}};Caman.prototype.hiDPIRatio=function(){var backingStoreRatio,devicePixelRatio;devicePixelRatio=window.devicePixelRatio||1;backingStoreRatio=this.context.webkitBackingStorePixelRatio||this.context.mozBackingStorePixelRatio||this.context.msBackingStorePixelRatio||this.context.oBackingStorePixelRatio||this.context.backingStorePixelRatio||1;return devicePixelRatio/backingStoreRatio;};Caman.prototype.hiDPICapable=function(){return(window.devicePixelRatio!=null)&&window.devicePixelRatio!==1;};Caman.prototype.needsHiDPISwap=function(){if(this.hiDPIDisabled()||!this.hiDPICapable()){return false;} +return this.hiDPIReplacement()!==null;};Caman.prototype.hiDPIReplacement=function(){if(this.image==null){return null;} +return this.image.getAttribute('data-caman-hidpi');};Caman.prototype.replaceCanvas=function(newCanvas){var oldCanvas;oldCanvas=this.canvas;this.canvas=newCanvas;this.context=this.canvas.getContext('2d');if(!Caman.NodeJS){oldCanvas.parentNode.replaceChild(this.canvas,oldCanvas);} +this.width=this.canvas.width;this.height=this.canvas.height;this.reloadCanvasData();return this.dimensions={width:this.canvas.width,height:this.canvas.height};};Caman.prototype.render=function(callback){var _this=this;if(callback==null){callback=function(){};} +Event.trigger(this,"renderStart");return this.renderer.execute(function(){_this.context.putImageData(_this.imageData,0,0);return callback.call(_this);});};Caman.prototype.revert=function(updateContext){var i,pixel,_i,_len,_ref;if(updateContext==null){updateContext=true;} +if(!Caman.allowRevert){throw"Revert disabled";} +_ref=this.originalVisiblePixels();for(i=_i=0,_len=_ref.length;_i<_len;i=++_i){pixel=_ref[i];this.pixelData[i]=pixel;} +if(updateContext){return this.context.putImageData(this.imageData,0,0);}};Caman.prototype.reset=function(){var canvas,ctx,i,imageData,pixel,pixelData,_i,_len,_ref;canvas=document.createElement('canvas');Util.copyAttributes(this.canvas,canvas);canvas.width=this.originalWidth;canvas.height=this.originalHeight;ctx=canvas.getContext('2d');imageData=ctx.getImageData(0,0,canvas.width,canvas.height);pixelData=imageData.data;_ref=this.initializedPixelData;for(i=_i=0,_len=_ref.length;_i<_len;i=++_i){pixel=_ref[i];pixelData[i]=pixel;} +ctx.putImageData(imageData,0,0);this.cropCoordinates={x:0,y:0};this.resized=false;return this.replaceCanvas(canvas);};Caman.prototype.originalVisiblePixels=function(){var canvas,coord,ctx,endX,endY,i,imageData,pixel,pixelData,pixels,scaledCanvas,startX,startY,width,_i,_j,_len,_ref,_ref1,_ref2,_ref3;if(!Caman.allowRevert){throw"Revert disabled";} +pixels=[];startX=this.cropCoordinates.x;endX=startX+this.width;startY=this.cropCoordinates.y;endY=startY+this.height;if(this.resized){canvas=document.createElement('canvas');canvas.width=this.originalWidth;canvas.height=this.originalHeight;ctx=canvas.getContext('2d');imageData=ctx.getImageData(0,0,canvas.width,canvas.height);pixelData=imageData.data;_ref=this.originalPixelData;for(i=_i=0,_len=_ref.length;_i<_len;i=++_i){pixel=_ref[i];pixelData[i]=pixel;} +ctx.putImageData(imageData,0,0);scaledCanvas=document.createElement('canvas');scaledCanvas.width=this.width;scaledCanvas.height=this.height;ctx=scaledCanvas.getContext('2d');ctx.drawImage(canvas,0,0,this.originalWidth,this.originalHeight,0,0,this.width,this.height);pixelData=ctx.getImageData(0,0,this.width,this.height).data;width=this.width;}else{pixelData=this.originalPixelData;width=this.originalWidth;} +for(i=_j=0,_ref1=pixelData.length;_j<_ref1;i=_j+=4){coord=Pixel.locationToCoordinates(i,width);if(((startX<=(_ref2=coord.x)&&_ref2_ref;i=0<=_ref?++_i:--_i){divisor+=adjust[i];}} +this.renderer.add({type:Filter.Type.Kernel,name:name,adjust:adjust,divisor:divisor,bias:bias});return this;};Caman.prototype.processPlugin=function(plugin,args){this.renderer.add({type:Filter.Type.Plugin,plugin:plugin,args:args});return this;};Caman.prototype.newLayer=function(callback){var layer;layer=new Layer(this);this.canvasQueue.push(layer);this.renderer.add({type:Filter.Type.LayerDequeue});callback.call(layer);this.renderer.add({type:Filter.Type.LayerFinished});return this;};Caman.prototype.executeLayer=function(layer){return this.pushContext(layer);};Caman.prototype.pushContext=function(layer){this.layerStack.push(this.currentLayer);this.pixelStack.push(this.pixelData);this.currentLayer=layer;return this.pixelData=layer.pixelData;};Caman.prototype.popContext=function(){this.pixelData=this.pixelStack.pop();return this.currentLayer=this.layerStack.pop();};Caman.prototype.applyCurrentLayer=function(){return this.currentLayer.applyToParent();};return Caman;})(Module);Root.Caman=Caman;Caman.Analyze=(function(){function Analyze(c){this.c=c;} +Analyze.prototype.calculateLevels=function(){var i,levels,numPixels,_i,_j,_k,_ref;levels={r:{},g:{},b:{}};for(i=_i=0;_i<=255;i=++_i){levels.r[i]=0;levels.g[i]=0;levels.b[i]=0;} +for(i=_j=0,_ref=this.c.pixelData.length;_j<_ref;i=_j+=4){levels.r[this.c.pixelData[i]]++;levels.g[this.c.pixelData[i+1]]++;levels.b[this.c.pixelData[i+2]]++;} +numPixels=this.c.pixelData.length/4;for(i=_k=0;_k<=255;i=++_k){levels.r[i]/=numPixels;levels.g[i]/=numPixels;levels.b[i]/=numPixels;} +return levels;};return Analyze;})();Analyze=Caman.Analyze;Caman.DOMUpdated=function(){var img,imgs,parser,_i,_len,_results;imgs=document.querySelectorAll("img[data-caman]");if(!(imgs.length>0)){return;} +_results=[];for(_i=0,_len=imgs.length;_i<_len;_i++){img=imgs[_i];_results.push(parser=new CamanParser(img,function(){this.parse();return this.execute();}));} +return _results;};if(Caman.autoload){(function(){if(document.readyState==="complete"){return Caman.DOMUpdated();}else{return document.addEventListener("DOMContentLoaded",Caman.DOMUpdated,false);}})();} +CamanParser=(function(){var INST_REGEX;INST_REGEX="(\\w+)\\((.*?)\\)";function CamanParser(ele,ready){this.dataStr=ele.getAttribute('data-caman');this.caman=Caman(ele,ready.bind(this));} +CamanParser.prototype.parse=function(){var args,e,filter,func,inst,instFunc,m,r,unparsedInstructions,_i,_len,_ref,_results;this.ele=this.caman.canvas;r=new RegExp(INST_REGEX,'g');unparsedInstructions=this.dataStr.match(r);if(!(unparsedInstructions.length>0)){return;} +r=new RegExp(INST_REGEX);_results=[];for(_i=0,_len=unparsedInstructions.length;_i<_len;_i++){inst=unparsedInstructions[_i];_ref=inst.match(r),m=_ref[0],filter=_ref[1],args=_ref[2];instFunc=new Function("return function() { this."+filter+"("+args+"); };");try{func=instFunc();_results.push(func.call(this.caman));}catch(_error){e=_error;_results.push(Log.debug(e));}} +return _results;};CamanParser.prototype.execute=function(){var ele;ele=this.ele;return this.caman.render(function(){return ele.parentNode.replaceChild(this.toImage(),ele);});};return CamanParser;})();Caman.Blender=(function(){function Blender(){} +Blender.blenders={};Blender.register=function(name,func){return this.blenders[name]=func;};Blender.execute=function(name,rgbaLayer,rgbaParent){return this.blenders[name](rgbaLayer,rgbaParent);};return Blender;})();Blender=Caman.Blender;Caman.Calculate=(function(){function Calculate(){} +Calculate.distance=function(x1,y1,x2,y2){return Math.sqrt(Math.pow(x2-x1,2)+Math.pow(y2-y1,2));};Calculate.randomRange=function(min,max,getFloat){var rand;if(getFloat==null){getFloat=false;} +rand=min+(Math.random()*(max-min));if(getFloat){return rand.toFixed(getFloat);}else{return Math.round(rand);}};Calculate.luminance=function(rgba){return(0.299*rgba.r)+(0.587*rgba.g)+(0.114*rgba.b);};Calculate.bezier=function(start,ctrl1,ctrl2,end,lowBound,highBound){var bezier,clamp,controlPoints,endX,i,j,lerp,next,prev,t,_i,_j,_ref;if(lowBound==null){lowBound=0;} +if(highBound==null){highBound=255;} +if(start[0]instanceof Array){controlPoints=start;lowBound=ctrl1;highBound=ctrl2;}else{controlPoints=[start,ctrl1,ctrl2,end];} +if(controlPoints.length<2){throw"Invalid number of arguments to bezier";} +bezier={};lerp=function(a,b,t){return a*(1-t)+b*t;};clamp=function(a,min,max){return Math.min(Math.max(a,min),max);};for(i=_i=0;_i<1000;i=++_i){t=i/1000;prev=controlPoints;while(prev.length>1){next=[];for(j=_j=0,_ref=prev.length-2;0<=_ref?_j<=_ref:_j>=_ref;j=0<=_ref?++_j:--_j){next.push([lerp(prev[j][0],prev[j+1][0],t),lerp(prev[j][1],prev[j+1][1],t)]);} +prev=next;} +bezier[Math.round(prev[0][0])]=Math.round(clamp(prev[0][1],lowBound,highBound));} +endX=controlPoints[controlPoints.length-1][0];bezier=Caman.Calculate.missingValues(bezier,endX);if(bezier[endX]==null){bezier[endX]=bezier[endX-1];} +return bezier;};Calculate.hermite=function(controlPoints,lowBound,highBound){var add,clamp,count,endX,fac0,fac1,fac2,fac3,i,j,lerp,m0,m1,mul,p,p0,p1,pointsPerSegment,pointsPerStep,pos,ret,sub,t,_i,_j,_ref,_this=this;if(controlPoints.length<2){throw"Invalid number of arguments to hermite";} +ret={};lerp=function(a,b,t){return a*(1-t)+b*t;};add=function(a,b,c,d){return[a[0]+b[0]+c[0]+d[0],a[1]+b[1]+c[1]+d[1]];};mul=function(a,b){return[a[0]*b[0],a[1]*b[1]];};sub=function(a,b){return[a[0]-b[0],a[1]-b[1]];};clamp=function(a,min,max){return Math.min(Math.max(a,min),max);};count=0;for(i=_i=0,_ref=controlPoints.length-2;0<=_ref?_i<=_ref:_i>=_ref;i=0<=_ref?++_i:--_i){p0=controlPoints[i];p1=controlPoints[i+1];pointsPerSegment=p1[0]-p0[0];pointsPerStep=1/pointsPerSegment;if(i===controlPoints.length-2){pointsPerStep=1/(pointsPerSegment-1);} +p=i>0?controlPoints[i-1]:p0;m0=mul(sub(p1,p),[0.5,0.5]);p=i=pointsPerSegment;j=0<=pointsPerSegment?++_j:--_j){t=j*pointsPerStep;fac0=2.0*t*t*t-3.0*t*t+1.0;fac1=t*t*t-2.0*t*t+t;fac2=-2.0*t*t*t+3.0*t*t;fac3=t*t*t-t*t;pos=add(mul(p0,[fac0,fac0]),mul(m0,[fac1,fac1]),mul(p1,[fac2,fac2]),mul(m1,[fac3,fac3]));ret[Math.round(pos[0])]=Math.round(clamp(pos[1],lowBound,highBound));count+=1;}} +endX=controlPoints[controlPoints.length-1][0];ret=Caman.Calculate.missingValues(ret,endX);return ret;};Calculate.missingValues=function(values,endX){var i,j,leftCoord,ret,rightCoord,_i,_j;if(Object.keys(values).length=endX;i=0<=endX?++_i:--_i){if(values[i]!=null){ret[i]=values[i];}else{leftCoord=[i-1,ret[i-1]];for(j=_j=i;i<=endX?_j<=endX:_j>=endX;j=i<=endX?++_j:--_j){if(values[j]!=null){rightCoord=[j,values[j]];break;}} +ret[i]=leftCoord[1]+((rightCoord[1]-leftCoord[1])/(rightCoord[0]-leftCoord[0]))*(i-leftCoord[0]);}} +return ret;} +return values;};return Calculate;})();Calculate=Caman.Calculate;Caman.Convert=(function(){function Convert(){} +Convert.hexToRGB=function(hex){var b,g,r;if(hex.charAt(0)==="#"){hex=hex.substr(1);} +r=parseInt(hex.substr(0,2),16);g=parseInt(hex.substr(2,2),16);b=parseInt(hex.substr(4,2),16);return{r:r,g:g,b:b};};Convert.rgbToHSL=function(r,g,b){var d,h,l,max,min,s;if(typeof r==="object"){g=r.g;b=r.b;r=r.r;} +r/=255;g/=255;b/=255;max=Math.max(r,g,b);min=Math.min(r,g,b);l=(max+min)/2;if(max===min){h=s=0;}else{d=max-min;s=l>0.5?d/(2-max-min):d/(max+min);h=(function(){switch(max){case r:return(g-b)/d+(g1){t-=1;} +if(t<1/6){return p+(q-p)*6*t;} +if(t<1/2){return q;} +if(t<2/3){return p+(q-p)*(2/3-t)*6;} +return p;};Convert.rgbToHSV=function(r,g,b){var d,h,max,min,s,v;r/=255;g/=255;b/=255;max=Math.max(r,g,b);min=Math.min(r,g,b);v=max;d=max-min;s=max===0?0:d/max;if(max===min){h=0;}else{h=(function(){switch(max){case r:return(g-b)/d+(g0.04045){r=Math.pow((r+0.055)/1.055,2.4);}else{r/=12.92;} +if(g>0.04045){g=Math.pow((g+0.055)/1.055,2.4);}else{g/=12.92;} +if(b>0.04045){b=Math.pow((b+0.055)/1.055,2.4);}else{b/=12.92;} +x=r*0.4124+g*0.3576+b*0.1805;y=r*0.2126+g*0.7152+b*0.0722;z=r*0.0193+g*0.1192+b*0.9505;return{x:x*100,y:y*100,z:z*100};};Convert.xyzToRGB=function(x,y,z){var b,g,r;x/=100;y/=100;z/=100;r=(3.2406*x)+(-1.5372*y)+(-0.4986*z);g=(-0.9689*x)+(1.8758*y)+(0.0415*z);b=(0.0557*x)+(-0.2040*y)+(1.0570*z);if(r>0.0031308){r=(1.055*Math.pow(r,0.4166666667))-0.055;}else{r*=12.92;} +if(g>0.0031308){g=(1.055*Math.pow(g,0.4166666667))-0.055;}else{g*=12.92;} +if(b>0.0031308){b=(1.055*Math.pow(b,0.4166666667))-0.055;}else{b*=12.92;} +return{r:r*255,g:g*255,b:b*255};};Convert.xyzToLab=function(x,y,z){var a,b,l,whiteX,whiteY,whiteZ;if(typeof x==="object"){y=x.y;z=x.z;x=x.x;} +whiteX=95.047;whiteY=100.0;whiteZ=108.883;x/=whiteX;y/=whiteY;z/=whiteZ;if(x>0.008856451679){x=Math.pow(x,0.3333333333);}else{x=(7.787037037*x)+0.1379310345;} +if(y>0.008856451679){y=Math.pow(y,0.3333333333);}else{y=(7.787037037*y)+0.1379310345;} +if(z>0.008856451679){z=Math.pow(z,0.3333333333);}else{z=(7.787037037*z)+0.1379310345;} +l=116*y-16;a=500*(x-y);b=200*(y-z);return{l:l,a:a,b:b};};Convert.labToXYZ=function(l,a,b){var x,y,z;if(typeof l==="object"){a=l.a;b=l.b;l=l.l;} +y=(l+16)/116;x=y+(a/500);z=y-(b/200);if(x>0.2068965517){x=x*x*x;}else{x=0.1284185493*(x-0.1379310345);} +if(y>0.2068965517){y=y*y*y;}else{y=0.1284185493*(y-0.1379310345);} +if(z>0.2068965517){z=z*z*z;}else{z=0.1284185493*(z-0.1379310345);} +return{x:x*95.047,y:y*100.0,z:z*108.883};};Convert.rgbToLab=function(r,g,b){var xyz;if(typeof r==="object"){g=r.g;b=r.b;r=r.r;} +xyz=this.rgbToXYZ(r,g,b);return this.xyzToLab(xyz);};Convert.labToRGB=function(l,a,b){};return Convert;})();Convert=Caman.Convert;Caman.Event=(function(){function Event(){} +Event.events={};Event.types=["processStart","processComplete","renderStart","renderFinished","blockStarted","blockFinished"];Event.trigger=function(target,type,data){var event,_i,_len,_ref,_results;if(data==null){data=null;} +if(this.events[type]&&this.events[type].length){_ref=this.events[type];_results=[];for(_i=0,_len=_ref.length;_i<_len;_i++){event=_ref[_i];if(event.target===null||target.id===event.target.id){_results.push(event.fn.call(target,data));}else{_results.push(void 0);}} +return _results;}};Event.listen=function(target,type,fn){var _fn,_type;if(typeof target==="string"){_type=target;_fn=type;target=null;type=_type;fn=_fn;} +if(__indexOf.call(this.types,type)<0){return false;} +if(!this.events[type]){this.events[type]=[];} +this.events[type].push({target:target,fn:fn});return true;};return Event;})();Event=Caman.Event;Caman.Filter=(function(){function Filter(){} +Filter.Type={Single:1,Kernel:2,LayerDequeue:3,LayerFinished:4,LoadOverlay:5,Plugin:6};Filter.register=function(name,filterFunc){return Caman.prototype[name]=filterFunc;};return Filter;})();Filter=Caman.Filter;Caman.IO=(function(){function IO(){} +IO.domainRegex=/(?:(?:http|https):\/\/)((?:\w+)\.(?:(?:\w|\.)+))/;IO.isRemote=function(img){if(img==null){return false;} +if(this.corsEnabled(img)){return false;} +return this.isURLRemote(img.src);};IO.corsEnabled=function(img){var _ref;return(img.crossOrigin!=null)&&((_ref=img.crossOrigin.toLowerCase())==='anonymous'||_ref==='use-credentials');};IO.isURLRemote=function(url){var matches;matches=url.match(this.domainRegex);if(matches){return matches[1]!==document.domain;}else{return false;}};IO.remoteCheck=function(src){if(this.isURLRemote(src)){if(!Caman.remoteProxy.length){Log.info("Attempting to load a remote image without a configured proxy. URL: "+src);}else{if(Caman.isURLRemote(Caman.remoteProxy)){Log.info("Cannot use a remote proxy for loading images.");return;} +return this.proxyUrl(src);}}};IO.proxyUrl=function(src){return""+Caman.remoteProxy+"?"+Caman.proxyParam+"="+(encodeURIComponent(src));};IO.useProxy=function(lang){var langToExt;langToExt={ruby:'rb',python:'py',perl:'pl',javascript:'js'};lang=lang.toLowerCase();if(langToExt[lang]!=null){lang=langToExt[lang];} +return"proxies/caman_proxy."+lang;};return IO;})();Caman.prototype.save=function(){if(typeof exports!=="undefined"&&exports!==null){return this.nodeSave.apply(this,arguments);}else{return this.browserSave.apply(this,arguments);}};Caman.prototype.browserSave=function(type){var image;if(type==null){type="png";} +type=type.toLowerCase();image=this.toBase64(type).replace("image/"+type,"image/octet-stream");return document.location.href=image;};Caman.prototype.nodeSave=function(file,overwrite,callback){var e,stats;if(overwrite==null){overwrite=true;} +if(callback==null){callback=null;} +try{stats=fs.statSync(file);if(stats.isFile()&&!overwrite){return false;}}catch(_error){e=_error;Log.debug("Creating output file "+file);} +return fs.writeFile(file,this.canvas.toBuffer(),function(err){Log.debug("Finished writing to "+file);if(callback){return callback.call(this,err);}});};Caman.prototype.toImage=function(type){var img;img=new Image();img.src=this.toBase64(type);img.width=this.dimensions.width;img.height=this.dimensions.height;if(window.devicePixelRatio){img.width/=window.devicePixelRatio;img.height/=window.devicePixelRatio;} +return img;};Caman.prototype.toBase64=function(type){if(type==null){type="png";} +type=type.toLowerCase();return this.canvas.toDataURL("image/"+type);};IO=Caman.IO;Caman.Layer=(function(){function Layer(c){this.c=c;this.filter=this.c;this.options={blendingMode:'normal',opacity:1.0};this.layerID=Util.uniqid.get();this.canvas=typeof exports!=="undefined"&&exports!==null?new Canvas():document.createElement('canvas');this.canvas.width=this.c.dimensions.width;this.canvas.height=this.c.dimensions.height;this.context=this.canvas.getContext('2d');this.context.createImageData(this.canvas.width,this.canvas.height);this.imageData=this.context.getImageData(0,0,this.canvas.width,this.canvas.height);this.pixelData=this.imageData.data;} +Layer.prototype.newLayer=function(cb){return this.c.newLayer.call(this.c,cb);};Layer.prototype.setBlendingMode=function(mode){this.options.blendingMode=mode;return this;};Layer.prototype.opacity=function(opacity){this.options.opacity=opacity/100;return this;};Layer.prototype.copyParent=function(){var i,parentData,_i,_ref;parentData=this.c.pixelData;for(i=_i=0,_ref=this.c.pixelData.length;_i<_ref;i=_i+=4){this.pixelData[i]=parentData[i];this.pixelData[i+1]=parentData[i+1];this.pixelData[i+2]=parentData[i+2];this.pixelData[i+3]=parentData[i+3];} +return this;};Layer.prototype.fillColor=function(){return this.c.fillColor.apply(this.c,arguments);};Layer.prototype.overlayImage=function(image){if(typeof image==="object"){image=image.src;}else if(typeof image==="string"&&image[0]==="#"){image=$(image).src;} +if(!image){return this;} +this.c.renderer.renderQueue.push({type:Filter.Type.LoadOverlay,src:image,layer:this});return this;};Layer.prototype.applyToParent=function(){var i,layerData,parentData,result,rgbaLayer,rgbaParent,_i,_ref,_results;parentData=this.c.pixelStack[this.c.pixelStack.length-1];layerData=this.c.pixelData;_results=[];for(i=_i=0,_ref=layerData.length;_i<_ref;i=_i+=4){rgbaParent={r:parentData[i],g:parentData[i+1],b:parentData[i+2],a:parentData[i+3]};rgbaLayer={r:layerData[i],g:layerData[i+1],b:layerData[i+2],a:layerData[i+3]};result=Blender.execute(this.options.blendingMode,rgbaLayer,rgbaParent);result.r=Util.clampRGB(result.r);result.g=Util.clampRGB(result.g);result.b=Util.clampRGB(result.b);if(result.a==null){result.a=rgbaLayer.a;} +parentData[i]=rgbaParent.r-((rgbaParent.r-result.r)*(this.options.opacity*(result.a/255)));parentData[i+1]=rgbaParent.g-((rgbaParent.g-result.g)*(this.options.opacity*(result.a/255)));_results.push(parentData[i+2]=rgbaParent.b-((rgbaParent.b-result.b)*(this.options.opacity*(result.a/255))));} +return _results;};return Layer;})();Layer=Caman.Layer;Caman.Logger=(function(){function Logger(){var name,_i,_len,_ref;_ref=['log','info','warn','error'];for(_i=0,_len=_ref.length;_i<_len;_i++){name=_ref[_i];this[name]=(function(name){return function(){var args,e;args=1<=arguments.length?__slice.call(arguments,0):[];if(!Caman.DEBUG){return;} +try{return console[name].apply(console,args);}catch(_error){e=_error;return console[name](args);}};})(name);} +this.debug=this.log;} +return Logger;})();Log=new Caman.Logger();Caman.Pixel=(function(){Pixel.coordinatesToLocation=function(x,y,width){return(y*width+x)*4;};Pixel.locationToCoordinates=function(loc,width){var x,y;y=Math.floor(loc/(width*4));x=(loc%(width*4))/4;return{x:x,y:y};};function Pixel(r,g,b,a,c){this.r=r!=null?r:0;this.g=g!=null?g:0;this.b=b!=null?b:0;this.a=a!=null?a:255;this.c=c!=null?c:null;this.loc=0;} +Pixel.prototype.setContext=function(c){return this.c=c;};Pixel.prototype.locationXY=function(){var x,y;if(this.c==null){throw"Requires a CamanJS context";} +y=this.c.dimensions.height-Math.floor(this.loc/(this.c.dimensions.width*4));x=(this.loc%(this.c.dimensions.width*4))/4;return{x:x,y:y};};Pixel.prototype.pixelAtLocation=function(loc){if(this.c==null){throw"Requires a CamanJS context";} +return new Pixel(this.c.pixelData[loc],this.c.pixelData[loc+1],this.c.pixelData[loc+2],this.c.pixelData[loc+3],this.c);};Pixel.prototype.getPixelRelative=function(horiz,vert){var newLoc;if(this.c==null){throw"Requires a CamanJS context";} +newLoc=this.loc+(this.c.dimensions.width*4*(vert*-1))+(4*horiz);if(newLoc>this.c.pixelData.length||newLoc<0){return new Pixel(0,0,0,255,this.c);} +return this.pixelAtLocation(newLoc);};Pixel.prototype.putPixelRelative=function(horiz,vert,rgba){var nowLoc;if(this.c==null){throw"Requires a CamanJS context";} +nowLoc=this.loc+(this.c.dimensions.width*4*(vert*-1))+(4*horiz);if(newLoc>this.c.pixelData.length||newLoc<0){return;} +this.c.pixelData[newLoc]=rgba.r;this.c.pixelData[newLoc+1]=rgba.g;this.c.pixelData[newLoc+2]=rgba.b;this.c.pixelData[newLoc+3]=rgba.a;return true;};Pixel.prototype.getPixel=function(x,y){var loc;if(this.c==null){throw"Requires a CamanJS context";} +loc=this.coordinatesToLocation(x,y,this.width);return this.pixelAtLocation(loc);};Pixel.prototype.putPixel=function(x,y,rgba){var loc;if(this.c==null){throw"Requires a CamanJS context";} +loc=this.coordinatesToLocation(x,y,this.width);this.c.pixelData[loc]=rgba.r;this.c.pixelData[loc+1]=rgba.g;this.c.pixelData[loc+2]=rgba.b;return this.c.pixelData[loc+3]=rgba.a;};Pixel.prototype.toString=function(){return this.toKey();};Pixel.prototype.toHex=function(includeAlpha){var hex;if(includeAlpha==null){includeAlpha=false;} +hex='#'+this.r.toString(16)+this.g.toString(16)+this.b.toString(16);if(includeAlpha){return hex+this.a.toString(16);}else{return hex;}};return Pixel;})();Pixel=Caman.Pixel;Caman.Plugin=(function(){function Plugin(){} +Plugin.plugins={};Plugin.register=function(name,plugin){return this.plugins[name]=plugin;};Plugin.execute=function(context,name,args){return this.plugins[name].apply(context,args);};return Plugin;})();Plugin=Caman.Plugin;Caman.Renderer=(function(){Renderer.Blocks=Caman.NodeJS?require('os').cpus().length:4;function Renderer(c){this.c=c;this.processNext=__bind(this.processNext,this);this.renderQueue=[];this.modPixelData=null;} +Renderer.prototype.add=function(job){if(job==null){return;} +return this.renderQueue.push(job);};Renderer.prototype.processNext=function(){var layer;if(this.renderQueue.length===0){Event.trigger(this,"renderFinished");if(this.finishedFn!=null){this.finishedFn.call(this.c);} +return this;} +this.currentJob=this.renderQueue.shift();switch(this.currentJob.type){case Filter.Type.LayerDequeue:layer=this.c.canvasQueue.shift();this.c.executeLayer(layer);return this.processNext();case Filter.Type.LayerFinished:this.c.applyCurrentLayer();this.c.popContext();return this.processNext();case Filter.Type.LoadOverlay:return this.loadOverlay(this.currentJob.layer,this.currentJob.src);case Filter.Type.Plugin:return this.executePlugin();default:return this.executeFilter();}};Renderer.prototype.execute=function(callback){this.finishedFn=callback;this.modPixelData=Util.dataArray(this.c.pixelData.length);return this.processNext();};Renderer.prototype.eachBlock=function(fn){var blockN,blockPixelLength,bnum,end,f,i,lastBlockN,n,start,_i,_ref,_results,_this=this;this.blocksDone=0;n=this.c.pixelData.length;blockPixelLength=Math.floor((n/4)/Renderer.Blocks);blockN=blockPixelLength*4;lastBlockN=blockN+((n/4)%Renderer.Blocks)*4;_results=[];for(i=_i=0,_ref=Renderer.Blocks;0<=_ref?_i<_ref:_i>_ref;i=0<=_ref?++_i:--_i){start=i*blockN;end=start+(i===Renderer.Blocks-1?lastBlockN:blockN);if(Caman.NodeJS){f=Fiber(function(){return fn.call(_this,i,start,end);});bnum=f.run();_results.push(this.blockFinished(bnum));}else{_results.push(setTimeout((function(i,start,end){return function(){return fn.call(_this,i,start,end);};})(i,start,end),0));}} +return _results;};Renderer.prototype.executeFilter=function(){Event.trigger(this.c,"processStart",this.currentJob);if(this.currentJob.type===Filter.Type.Single){return this.eachBlock(this.renderBlock);}else{return this.eachBlock(this.renderKernel);}};Renderer.prototype.executePlugin=function(){Log.debug("Executing plugin "+this.currentJob.plugin);Plugin.execute(this.c,this.currentJob.plugin,this.currentJob.args);Log.debug("Plugin "+this.currentJob.plugin+" finished!");return this.processNext();};Renderer.prototype.renderBlock=function(bnum,start,end){var i,pixel,_i;Log.debug("Block #"+bnum+" - Filter: "+this.currentJob.name+", Start: "+start+", End: "+end);Event.trigger(this.c,"blockStarted",{blockNum:bnum,totalBlocks:Renderer.Blocks,startPixel:start,endPixel:end});pixel=new Pixel();pixel.setContext(this.c);for(i=_i=start;_i=builder;j=-builder<=builder?++_j:--_j){for(k=_k=builder;builder<=-builder?_k<=-builder:_k>=-builder;k=builder<=-builder?++_k:--_k){p=pixel.getPixelRelative(j,k);kernel[builderIndex*3]=p.r;kernel[builderIndex*3+1]=p.g;kernel[builderIndex*3+2]=p.b;builderIndex++;}} +res=this.processKernel(adjust,kernel,divisor,bias);this.modPixelData[i]=Util.clampRGB(res.r);this.modPixelData[i+1]=Util.clampRGB(res.g);this.modPixelData[i+2]=Util.clampRGB(res.b);this.modPixelData[i+3]=this.c.pixelData[i+3];} +if(Caman.NodeJS){return Fiber["yield"](bnum);}else{return this.blockFinished(bnum);}};Renderer.prototype.blockFinished=function(bnum){var i,_i,_ref;if(bnum>=0){Log.debug("Block #"+bnum+" finished! Filter: "+this.currentJob.name);} +this.blocksDone++;Event.trigger(this.c,"blockFinished",{blockNum:bnum,blocksFinished:this.blocksDone,totalBlocks:Renderer.Blocks});if(this.blocksDone===Renderer.Blocks){if(this.currentJob.type===Filter.Type.Kernel){for(i=_i=0,_ref=this.c.pixelData.length;0<=_ref?_i<_ref:_i>_ref;i=0<=_ref?++_i:--_i){this.c.pixelData[i]=this.modPixelData[i];}} +if(bnum>=0){Log.debug("Filter "+this.currentJob.name+" finished!");} +Event.trigger(this.c,"processComplete",this.currentJob);return this.processNext();}};Renderer.prototype.processKernel=function(adjust,kernel,divisor,bias){var i,val,_i,_ref;val={r:0,g:0,b:0};for(i=_i=0,_ref=adjust.length;0<=_ref?_i<_ref:_i>_ref;i=0<=_ref?++_i:--_i){val.r+=adjust[i]*kernel[i*3];val.g+=adjust[i]*kernel[i*3+1];val.b+=adjust[i]*kernel[i*3+2];} +val.r=(val.r/divisor)+bias;val.g=(val.g/divisor)+bias;val.b=(val.b/divisor)+bias;return val;};Renderer.prototype.loadOverlay=function(layer,src){var img,proxyUrl,_this=this;img=new Image();img.onload=function(){layer.context.drawImage(img,0,0,_this.c.dimensions.width,_this.c.dimensions.height);layer.imageData=layer.context.getImageData(0,0,_this.c.dimensions.width,_this.c.dimensions.height);layer.pixelData=layer.imageData.data;_this.c.pixelData=layer.pixelData;return _this.processNext();};proxyUrl=IO.remoteCheck(src);return img.src=proxyUrl!=null?proxyUrl:src;};return Renderer;})();Renderer=Caman.Renderer;Caman.Store=(function(){function Store(){} +Store.items={};Store.has=function(search){return this.items[search]!=null;};Store.get=function(search){return this.items[search];};Store.put=function(name,obj){return this.items[name]=obj;};Store.execute=function(search,callback){var _this=this;setTimeout(function(){return callback.call(_this.get(search),_this.get(search));},0);return this.get(search);};Store.flush=function(name){if(name==null){name=false;} +if(name){return delete this.items[name];}else{return this.items={};}};return Store;})();Store=Caman.Store;Blender.register("normal",function(rgbaLayer,rgbaParent){return{r:rgbaLayer.r,g:rgbaLayer.g,b:rgbaLayer.b};});Blender.register("multiply",function(rgbaLayer,rgbaParent){return{r:(rgbaLayer.r*rgbaParent.r)/255,g:(rgbaLayer.g*rgbaParent.g)/255,b:(rgbaLayer.b*rgbaParent.b)/255};});Blender.register("screen",function(rgbaLayer,rgbaParent){return{r:255-(((255-rgbaLayer.r)*(255-rgbaParent.r))/255),g:255-(((255-rgbaLayer.g)*(255-rgbaParent.g))/255),b:255-(((255-rgbaLayer.b)*(255-rgbaParent.b))/255)};});Blender.register("overlay",function(rgbaLayer,rgbaParent){var result;result={};result.r=rgbaParent.r>128?255-2*(255-rgbaLayer.r)*(255-rgbaParent.r)/255:(rgbaParent.r*rgbaLayer.r*2)/255;result.g=rgbaParent.g>128?255-2*(255-rgbaLayer.g)*(255-rgbaParent.g)/255:(rgbaParent.g*rgbaLayer.g*2)/255;result.b=rgbaParent.b>128?255-2*(255-rgbaLayer.b)*(255-rgbaParent.b)/255:(rgbaParent.b*rgbaLayer.b*2)/255;return result;});Blender.register("difference",function(rgbaLayer,rgbaParent){return{r:rgbaLayer.r-rgbaParent.r,g:rgbaLayer.g-rgbaParent.g,b:rgbaLayer.b-rgbaParent.b};});Blender.register("addition",function(rgbaLayer,rgbaParent){return{r:rgbaParent.r+rgbaLayer.r,g:rgbaParent.g+rgbaLayer.g,b:rgbaParent.b+rgbaLayer.b};});Blender.register("exclusion",function(rgbaLayer,rgbaParent){return{r:128-2*(rgbaParent.r-128)*(rgbaLayer.r-128)/255,g:128-2*(rgbaParent.g-128)*(rgbaLayer.g-128)/255,b:128-2*(rgbaParent.b-128)*(rgbaLayer.b-128)/255};});Blender.register("softLight",function(rgbaLayer,rgbaParent){var result;result={};result.r=rgbaParent.r>128?255-((255-rgbaParent.r)*(255-(rgbaLayer.r-128)))/255:(rgbaParent.r*(rgbaLayer.r+128))/255;result.g=rgbaParent.g>128?255-((255-rgbaParent.g)*(255-(rgbaLayer.g-128)))/255:(rgbaParent.g*(rgbaLayer.g+128))/255;result.b=rgbaParent.b>128?255-((255-rgbaParent.b)*(255-(rgbaLayer.b-128)))/255:(rgbaParent.b*(rgbaLayer.b+128))/255;return result;});Blender.register("lighten",function(rgbaLayer,rgbaParent){return{r:rgbaParent.r>rgbaLayer.r?rgbaParent.r:rgbaLayer.r,g:rgbaParent.g>rgbaLayer.g?rgbaParent.g:rgbaLayer.g,b:rgbaParent.b>rgbaLayer.b?rgbaParent.b:rgbaLayer.b};});Blender.register("darken",function(rgbaLayer,rgbaParent){return{r:rgbaParent.r>rgbaLayer.r?rgbaLayer.r:rgbaParent.r,g:rgbaParent.g>rgbaLayer.g?rgbaLayer.g:rgbaParent.g,b:rgbaParent.b>rgbaLayer.b?rgbaLayer.b:rgbaParent.b};});Filter.register("fillColor",function(){var color;if(arguments.length===1){color=Convert.hexToRGB(arguments[0]);}else{color={r:arguments[0],g:arguments[1],b:arguments[2]};} +return this.process("fillColor",function(rgba){rgba.r=color.r;rgba.g=color.g;rgba.b=color.b;rgba.a=255;return rgba;});});Filter.register("brightness",function(adjust){adjust=Math.floor(255*(adjust/100));return this.process("brightness",function(rgba){rgba.r+=adjust;rgba.g+=adjust;rgba.b+=adjust;return rgba;});});Filter.register("saturation",function(adjust){adjust*=-0.01;return this.process("saturation",function(rgba){var max;max=Math.max(rgba.r,rgba.g,rgba.b);if(rgba.r!==max){rgba.r+=(max-rgba.r)*adjust;} +if(rgba.g!==max){rgba.g+=(max-rgba.g)*adjust;} +if(rgba.b!==max){rgba.b+=(max-rgba.b)*adjust;} +return rgba;});});Filter.register("vibrance",function(adjust){adjust*=-1;return this.process("vibrance",function(rgba){var amt,avg,max;max=Math.max(rgba.r,rgba.g,rgba.b);avg=(rgba.r+rgba.g+rgba.b)/3;amt=((Math.abs(max-avg)*2/255)*adjust)/100;if(rgba.r!==max){rgba.r+=(max-rgba.r)*amt;} +if(rgba.g!==max){rgba.g+=(max-rgba.g)*amt;} +if(rgba.b!==max){rgba.b+=(max-rgba.b)*amt;} +return rgba;});});Filter.register("greyscale",function(adjust){return this.process("greyscale",function(rgba){var avg;avg=Calculate.luminance(rgba);rgba.r=avg;rgba.g=avg;rgba.b=avg;return rgba;});});Filter.register("contrast",function(adjust){adjust=Math.pow((adjust+100)/100,2);return this.process("contrast",function(rgba){rgba.r/=255;rgba.r-=0.5;rgba.r*=adjust;rgba.r+=0.5;rgba.r*=255;rgba.g/=255;rgba.g-=0.5;rgba.g*=adjust;rgba.g+=0.5;rgba.g*=255;rgba.b/=255;rgba.b-=0.5;rgba.b*=adjust;rgba.b+=0.5;rgba.b*=255;return rgba;});});Filter.register("hue",function(adjust){return this.process("hue",function(rgba){var b,g,h,hsv,r,_ref;hsv=Convert.rgbToHSV(rgba.r,rgba.g,rgba.b);h=hsv.h*100;h+=Math.abs(adjust);h=h%100;h/=100;hsv.h=h;_ref=Convert.hsvToRGB(hsv.h,hsv.s,hsv.v),r=_ref.r,g=_ref.g,b=_ref.b;rgba.r=r;rgba.g=g;rgba.b=b;return rgba;});});Filter.register("colorize",function(){var level,rgb;if(arguments.length===2){rgb=Convert.hexToRGB(arguments[0]);level=arguments[1];}else if(arguments.length===4){rgb={r:arguments[0],g:arguments[1],b:arguments[2]};level=arguments[3];} +return this.process("colorize",function(rgba){rgba.r-=(rgba.r-rgb.r)*(level/100);rgba.g-=(rgba.g-rgb.g)*(level/100);rgba.b-=(rgba.b-rgb.b)*(level/100);return rgba;});});Filter.register("invert",function(){return this.process("invert",function(rgba){rgba.r=255-rgba.r;rgba.g=255-rgba.g;rgba.b=255-rgba.b;return rgba;});});Filter.register("sepia",function(adjust){if(adjust==null){adjust=100;} +adjust/=100;return this.process("sepia",function(rgba){rgba.r=Math.min(255,(rgba.r*(1-(0.607*adjust)))+(rgba.g*(0.769*adjust))+(rgba.b*(0.189*adjust)));rgba.g=Math.min(255,(rgba.r*(0.349*adjust))+(rgba.g*(1-(0.314*adjust)))+(rgba.b*(0.168*adjust)));rgba.b=Math.min(255,(rgba.r*(0.272*adjust))+(rgba.g*(0.534*adjust))+(rgba.b*(1-(0.869*adjust))));return rgba;});});Filter.register("gamma",function(adjust){return this.process("gamma",function(rgba){rgba.r=Math.pow(rgba.r/255,adjust)*255;rgba.g=Math.pow(rgba.g/255,adjust)*255;rgba.b=Math.pow(rgba.b/255,adjust)*255;return rgba;});});Filter.register("noise",function(adjust){adjust=Math.abs(adjust)*2.55;return this.process("noise",function(rgba){var rand;rand=Calculate.randomRange(adjust*-1,adjust);rgba.r+=rand;rgba.g+=rand;rgba.b+=rand;return rgba;});});Filter.register("clip",function(adjust){adjust=Math.abs(adjust)*2.55;return this.process("clip",function(rgba){if(rgba.r>255-adjust){rgba.r=255;}else if(rgba.r255-adjust){rgba.g=255;}else if(rgba.g255-adjust){rgba.b=255;}else if(rgba.b0){rgba.r+=(255-rgba.r)*options.red;}else{rgba.r-=rgba.r*Math.abs(options.red);}} +if(options.green!=null){if(options.green>0){rgba.g+=(255-rgba.g)*options.green;}else{rgba.g-=rgba.g*Math.abs(options.green);}} +if(options.blue!=null){if(options.blue>0){rgba.b+=(255-rgba.b)*options.blue;}else{rgba.b-=rgba.b*Math.abs(options.blue);}} +return rgba;});});Filter.register("curves",function(){var algo,bezier,chans,cps,end,i,last,start,_i,_j,_ref,_ref1;chans=arguments[0],cps=2<=arguments.length?__slice.call(arguments,1):[];last=cps[cps.length-1];if(typeof last==="function"){algo=last;cps.pop();}else if(typeof last==="string"){algo=Calculate[last];cps.pop();}else{algo=Calculate.bezier;} +if(typeof chans==="string"){chans=chans.split("");} +if(chans[0]==="v"){chans=['r','g','b'];} +if(cps.length<2){throw"Invalid number of arguments to curves filter";} +bezier=algo(cps,0,255);start=cps[0];if(start[0]>0){for(i=_i=0,_ref=start[0];0<=_ref?_i<_ref:_i>_ref;i=0<=_ref?++_i:--_i){bezier[i]=start[1];}} +end=cps[cps.length-1];if(end[0]<255){for(i=_j=_ref1=end[0];_ref1<=255?_j<=255:_j>=255;i=_ref1<=255?++_j:--_j){bezier[i]=end[1];}} +return this.process("curves",function(rgba){var _k,_ref2;for(i=_k=0,_ref2=chans.length;0<=_ref2?_k<_ref2:_k>_ref2;i=0<=_ref2?++_k:--_k){rgba[chans[i]]=bezier[rgba[chans[i]]];} +return rgba;});});Filter.register("exposure",function(adjust){var ctrl1,ctrl2,p;p=Math.abs(adjust)/100;ctrl1=[0,255*p];ctrl2=[255-(255*p),255];if(adjust<0){ctrl1=ctrl1.reverse();ctrl2=ctrl2.reverse();} +return this.curves('rgb',[0,0],ctrl1,ctrl2,[255,255]);});Caman.Plugin.register("crop",function(width,height,x,y){var canvas,ctx;if(x==null){x=0;} +if(y==null){y=0;} +if(typeof exports!=="undefined"&&exports!==null){canvas=new Canvas(width,height);}else{canvas=document.createElement('canvas');Util.copyAttributes(this.canvas,canvas);canvas.width=width;canvas.height=height;} +ctx=canvas.getContext('2d');ctx.drawImage(this.canvas,x,y,width,height,0,0,width,height);this.cropCoordinates={x:x,y:y};this.cropped=true;return this.replaceCanvas(canvas);});Caman.Plugin.register("resize",function(newDims){var canvas,ctx;if(newDims==null){newDims=null;} +if(newDims===null||((newDims.width==null)&&(newDims.height==null))){Log.error("Invalid or missing dimensions given for resize");return;} +if(newDims.width==null){newDims.width=this.canvas.width*newDims.height/this.canvas.height;}else if(newDims.height==null){newDims.height=this.canvas.height*newDims.width/this.canvas.width;} +if(typeof exports!=="undefined"&&exports!==null){canvas=new Canvas(newDims.width,newDims.height);}else{canvas=document.createElement('canvas');Util.copyAttributes(this.canvas,canvas);canvas.width=newDims.width;canvas.height=newDims.height;} +ctx=canvas.getContext('2d');ctx.drawImage(this.canvas,0,0,this.canvas.width,this.canvas.height,0,0,newDims.width,newDims.height);this.resized=true;return this.replaceCanvas(canvas);});Caman.Filter.register("crop",function(){return this.processPlugin("crop",Array.prototype.slice.call(arguments,0));});Caman.Filter.register("resize",function(){return this.processPlugin("resize",Array.prototype.slice.call(arguments,0));});Caman.Filter.register("boxBlur",function(){return this.processKernel("Box Blur",[1,1,1,1,1,1,1,1,1]);});Caman.Filter.register("heavyRadialBlur",function(){return this.processKernel("Heavy Radial Blur",[0,0,1,0,0,0,1,1,1,0,1,1,1,1,1,0,1,1,1,0,0,0,1,0,0]);});Caman.Filter.register("gaussianBlur",function(){return this.processKernel("Gaussian Blur",[1,4,6,4,1,4,16,24,16,4,6,24,36,24,6,4,16,24,16,4,1,4,6,4,1]);});Caman.Filter.register("motionBlur",function(degrees){var kernel;if(degrees===0||degrees===180){kernel=[0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0];}else if((degrees>0&°rees<90)||(degrees>180&°rees<270)){kernel=[0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0];}else if(degrees===90||degrees===270){kernel=[0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0];}else{kernel=[1,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,1];} +return this.processKernel("Motion Blur",kernel);});Caman.Filter.register("sharpen",function(amt){if(amt==null){amt=100;} +amt/=100;return this.processKernel("Sharpen",[0,-amt,0,-amt,4*amt+1,-amt,0,-amt,0]);});vignetteFilters={brightness:function(rgba,amt,opts){rgba.r=rgba.r-(rgba.r*amt*opts.strength);rgba.g=rgba.g-(rgba.g*amt*opts.strength);rgba.b=rgba.b-(rgba.b*amt*opts.strength);return rgba;},gamma:function(rgba,amt,opts){rgba.r=Math.pow(rgba.r/255,Math.max(10*amt*opts.strength,1))*255;rgba.g=Math.pow(rgba.g/255,Math.max(10*amt*opts.strength,1))*255;rgba.b=Math.pow(rgba.b/255,Math.max(10*amt*opts.strength,1))*255;return rgba;},colorize:function(rgba,amt,opts){rgba.r-=(rgba.r-opts.color.r)*amt;rgba.g-=(rgba.g-opts.color.g)*amt;rgba.b-=(rgba.b-opts.color.b)*amt;return rgba;}};Filter.register("vignette",function(size,strength){var bezier,center,end,start;if(strength==null){strength=60;} +if(typeof size==="string"&&size.substr(-1)==="%"){if(this.dimensions.height>this.dimensions.width){size=this.dimensions.width*(parseInt(size.substr(0,size.length-1),10)/100);}else{size=this.dimensions.height*(parseInt(size.substr(0,size.length-1),10)/100);}} +strength/=100;center=[this.dimensions.width/2,this.dimensions.height/2];start=Math.sqrt(Math.pow(center[0],2)+Math.pow(center[1],2));end=start-size;bezier=Calculate.bezier([0,1],[30,30],[70,60],[100,80]);return this.process("vignette",function(rgba){var dist,div,loc;loc=rgba.locationXY();dist=Calculate.distance(loc.x,loc.y,center[0],center[1]);if(dist>end){div=Math.max(1,(bezier[Math.round(((dist-end)/size)*100)]/10)*strength);rgba.r=Math.pow(rgba.r/255,div)*255;rgba.g=Math.pow(rgba.g/255,div)*255;rgba.b=Math.pow(rgba.b/255,div)*255;} +return rgba;});});Filter.register("rectangularVignette",function(opts){var defaults,dim,percent,size,_i,_len,_ref;defaults={strength:50,cornerRadius:0,method:'brightness',color:{r:0,g:0,b:0}};opts=Util.extend(defaults,opts);if(!opts.size){return this;}else if(typeof opts.size==="string"){percent=parseInt(opts.size,10)/100;opts.size={width:this.dimensions.width*percent,height:this.dimensions.height*percent};}else if(typeof opts.size==="object"){_ref=["width","height"];for(_i=0,_len=_ref.length;_i<_len;_i++){dim=_ref[_i];if(typeof opts.size[dim]==="string"){opts.size[dim]=this.dimensions[dim]*(parseInt(opts.size[dim],10)/100);}}}else if(opts.size==="number"){size=opts.size;opts.size={width:size,height:size};} +if(typeof opts.cornerRadius==="string"){opts.cornerRadius=(opts.size.width/2)*(parseInt(opts.cornerRadius,10)/100);} +opts.strength/=100;opts.size.width=Math.floor(opts.size.width);opts.size.height=Math.floor(opts.size.height);opts.image={width:this.dimensions.width,height:this.dimensions.height};if(opts.method==="colorize"&&typeof opts.color==="string"){opts.color=Convert.hexToRGB(opts.color);} +opts.coords={left:(this.dimensions.width-opts.size.width)/2,right:this.dimensions.width-opts.coords.left,bottom:(this.dimensions.height-opts.size.height)/2,top:this.dimensions.height-opts.coords.bottom};opts.corners=[{x:opts.coords.left+opts.cornerRadius,y:opts.coords.top-opts.cornerRadius},{x:opts.coords.right-opts.cornerRadius,y:opts.coords.top-opts.cornerRadius},{x:opts.coords.right-opts.cornerRadius,y:opts.coords.bottom+opts.cornerRadius},{x:opts.coords.left+opts.cornerRadius,y:opts.coords.bottom+opts.cornerRadius}];opts.maxDist=Calculate.distance(0,0,opts.corners[3].x,opts.corners[3].y)-opts.cornerRadius;return this.process("rectangularVignette",function(rgba){var amt,loc,radialDist;loc=rgba.locationXY();if((loc.x>opts.corners[0].x&&loc.xopts.coords.bottom&&loc.yopts.coords.left&&loc.xopts.corners[3].y&&loc.yopts.corners[0].x&&loc.xopts.coords.top){amt=(loc.y-opts.coords.top)/opts.maxDist;}else if(loc.y>opts.corners[2].y&&loc.yopts.coords.right){amt=(loc.x-opts.coords.right)/opts.maxDist;}else if(loc.x>opts.corners[0].x&&loc.xopts.corners[2].y&&loc.y=opts.corners[0].y){radialDist=Caman.distance(loc.x,loc.y,opts.corners[0].x,opts.corners[0].y);amt=(radialDist-opts.cornerRadius)/opts.maxDist;}else if(loc.x>=opts.corners[1].x&&loc.y>=opts.corners[1].y){radialDist=Caman.distance(loc.x,loc.y,opts.corners[1].x,opts.corners[1].y);amt=(radialDist-opts.cornerRadius)/opts.maxDist;}else if(loc.x>=opts.corners[2].x&&loc.y<=opts.corners[2].y){radialDist=Caman.distance(loc.x,loc.y,opts.corners[2].x,opts.corners[2].y);amt=(radialDist-opts.cornerRadius)/opts.maxDist;}else if(loc.x<=opts.corners[3].x&&loc.y<=opts.corners[3].y){radialDist=Caman.distance(loc.x,loc.y,opts.corners[3].x,opts.corners[3].y);amt=(radialDist-opts.cornerRadius)/opts.maxDist;} +if(amt<0){return rgba;} +return vignetteFilters[opts.method](rgba,amt,opts);});});(function(){var BlurStack,getLinearGradientMap,getRadialGradientMap,mul_table,shg_table;mul_table=[512,512,456,512,328,456,335,512,405,328,271,456,388,335,292,512,454,405,364,328,298,271,496,456,420,388,360,335,312,292,273,512,482,454,428,405,383,364,345,328,312,298,284,271,259,496,475,456,437,420,404,388,374,360,347,335,323,312,302,292,282,273,265,512,497,482,468,454,441,428,417,405,394,383,373,364,354,345,337,328,320,312,305,298,291,284,278,271,265,259,507,496,485,475,465,456,446,437,428,420,412,404,396,388,381,374,367,360,354,347,341,335,329,323,318,312,307,302,297,292,287,282,278,273,269,265,261,512,505,497,489,482,475,468,461,454,447,441,435,428,422,417,411,405,399,394,389,383,378,373,368,364,359,354,350,345,341,337,332,328,324,320,316,312,309,305,301,298,294,291,287,284,281,278,274,271,268,265,262,259,257,507,501,496,491,485,480,475,470,465,460,456,451,446,442,437,433,428,424,420,416,412,408,404,400,396,392,388,385,381,377,374,370,367,363,360,357,354,350,347,344,341,338,335,332,329,326,323,320,318,315,312,310,307,304,302,299,297,294,292,289,287,285,282,280,278,275,273,271,269,267,265,263,261,259];shg_table=[9,11,12,13,13,14,14,15,15,15,15,16,16,16,16,17,17,17,17,17,17,17,18,18,18,18,18,18,18,18,18,19,19,19,19,19,19,19,19,19,19,19,19,19,19,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24];getLinearGradientMap=function(width,height,centerX,centerY,angle,length,mirrored){var cnv,context,gradient,x1,x2,y1,y2;cnv=typeof exports!=="undefined"&&exports!==null?new Canvas():document.createElement('canvas');cnv.width=width;cnv.height=height;x1=centerX+Math.cos(angle)*length*0.5;y1=centerY+Math.sin(angle)*length*0.5;x2=centerX-Math.cos(angle)*length*0.5;y2=centerY-Math.sin(angle)*length*0.5;context=cnv.getContext("2d");gradient=context.createLinearGradient(x1,y1,x2,y2);if(!mirrored){gradient.addColorStop(0,"white");gradient.addColorStop(1,"black");}else{gradient.addColorStop(0,"white");gradient.addColorStop(0.5,"black");gradient.addColorStop(1,"white");} +context.fillStyle=gradient;context.fillRect(0,0,width,height);return context.getImageData(0,0,width,height);};getRadialGradientMap=function(width,height,centerX,centerY,radius1,radius2){var cnv,context,gradient;cnv=typeof exports!=="undefined"&&exports!==null?new Canvas():document.createElement('canvas');cnv.width=width;cnv.height=height;context=cnv.getContext("2d");gradient=context.createRadialGradient(centerX,centerY,radius1,centerX,centerY,radius2);gradient.addColorStop(1,"white");gradient.addColorStop(0,"black");context.fillStyle=gradient;context.fillRect(0,0,width,height);return context.getImageData(0,0,width,height);};BlurStack=function(){this.r=0;this.g=0;this.b=0;this.a=0;return this.next=null;};Caman.Plugin.register("compoundBlur",function(radiusData,radius,increaseFactor,blurLevels){var b_in_sum,b_out_sum,b_sum,blend,currentIndex,div,g_in_sum,g_out_sum,g_sum,height,heightMinus1,i,iblend,idx,imagePixels,index,iradius,lookupValue,mul_sum,p,pb,pg,pixels,pr,r_in_sum,r_out_sum,r_sum,radiusPixels,radiusPlus1,rbs,shg_sum,stack,stackEnd,stackIn,stackOut,stackStart,steps,sumFactor,w4,wh,wh4,width,widthMinus1,x,y,yi,yp,yw,_i,_j,_k,_l,_m,_n,_o,_p,_q,_r;width=this.dimensions.width;height=this.dimensions.height;imagePixels=this.pixelData;radiusPixels=radiusData.data;wh=width*height;wh4=wh<<2;pixels=[];for(i=_i=0;0<=wh4?_iwh4;i=0<=wh4?++_i:--_i){pixels[i]=imagePixels[i];} +currentIndex=0;steps=blurLevels;blurLevels-=1;while(steps-->=0){iradius=(radius+0.5)|0;if(iradius===0){continue;} +if(iradius>256){iradius=256;} +div=iradius+iradius+1;w4=width<<2;widthMinus1=width-1;heightMinus1=height-1;radiusPlus1=iradius+1;sumFactor=radiusPlus1*(radiusPlus1+1)/2;stackStart=new BlurStack();stackEnd=void 0;stack=stackStart;for(i=_j=1;1<=div?_jdiv;i=1<=div?++_j:--_j){stack=stack.next=new BlurStack();if(i===radiusPlus1){stackEnd=stack;}} +stack.next=stackStart;stackIn=null;stackOut=null;yw=yi=0;mul_sum=mul_table[iradius];shg_sum=shg_table[iradius];for(y=_k=0;0<=height?_kheight;y=0<=height?++_k:--_k){r_in_sum=g_in_sum=b_in_sum=r_sum=g_sum=b_sum=0;r_out_sum=radiusPlus1*(pr=pixels[yi]);g_out_sum=radiusPlus1*(pg=pixels[yi+1]);b_out_sum=radiusPlus1*(pb=pixels[yi+2]);r_sum+=sumFactor*pr;g_sum+=sumFactor*pg;b_sum+=sumFactor*pb;stack=stackStart;for(i=_l=0;0<=radiusPlus1?_lradiusPlus1;i=0<=radiusPlus1?++_l:--_l){stack.r=pr;stack.g=pg;stack.b=pb;stack=stack.next;} +for(i=_m=1;1<=radiusPlus1?_mradiusPlus1;i=1<=radiusPlus1?++_m:--_m){p=yi+((widthMinus1width;x=0<=width?++_n:--_n){pixels[yi]=(r_sum*mul_sum)>>shg_sum;pixels[yi+1]=(g_sum*mul_sum)>>shg_sum;pixels[yi+2]=(b_sum*mul_sum)>>shg_sum;r_sum-=r_out_sum;g_sum-=g_out_sum;b_sum-=b_out_sum;r_out_sum-=stackIn.r;g_out_sum-=stackIn.g;b_out_sum-=stackIn.b;p=(yw+((p=x+radiusPlus1)width;x=0<=width?++_o:--_o){g_in_sum=b_in_sum=r_in_sum=g_sum=b_sum=r_sum=0;yi=x<<2;r_out_sum=radiusPlus1*(pr=pixels[yi]);g_out_sum=radiusPlus1*(pg=pixels[yi+1]);b_out_sum=radiusPlus1*(pb=pixels[yi+2]);r_sum+=sumFactor*pr;g_sum+=sumFactor*pg;b_sum+=sumFactor*pb;stack=stackStart;for(i=_p=0;0<=radiusPlus1?_pradiusPlus1;i=0<=radiusPlus1?++_p:--_p){stack.r=pr;stack.g=pg;stack.b=pb;stack=stack.next;} +yp=width;for(i=_q=1;1<=radiusPlus1?_qradiusPlus1;i=1<=radiusPlus1?++_q:--_q){yi=(yp+x)<<2;r_sum+=(stack.r=(pr=pixels[yi]))*(rbs=radiusPlus1-i);g_sum+=(stack.g=(pg=pixels[yi+1]))*rbs;b_sum+=(stack.b=(pb=pixels[yi+2]))*rbs;r_in_sum+=pr;g_in_sum+=pg;b_in_sum+=pb;stack=stack.next;if(iheight;y=0<=height?++_r:--_r){p=yi<<2;pixels[p]=(r_sum*mul_sum)>>shg_sum;pixels[p+1]=(g_sum*mul_sum)>>shg_sum;pixels[p+2]=(b_sum*mul_sum)>>shg_sum;r_sum-=r_out_sum;g_sum-=g_out_sum;b_sum-=b_out_sum;r_out_sum-=stackIn.r;g_out_sum-=stackIn.g;b_out_sum-=stackIn.b;p=(x+(((p=y+radiusPlus1)-1){idx=i<<2;lookupValue=(radiusPixels[idx+2]&0xff)/255.0*blurLevels;index=lookupValue|0;if(index===currentIndex){blend=256.0*(lookupValue-(lookupValue|0));iblend=256-blend;imagePixels[idx]=(imagePixels[idx]*iblend+pixels[idx]*blend)>>8;imagePixels[idx+1]=(imagePixels[idx+1]*iblend+pixels[idx+1]*blend)>>8;imagePixels[idx+2]=(imagePixels[idx+2]*iblend+pixels[idx+2]*blend)>>8;}else if(index===currentIndex+1){imagePixels[idx]=pixels[idx];imagePixels[idx+1]=pixels[idx+1];imagePixels[idx+2]=pixels[idx+2];}} +currentIndex++;} +return this;});Caman.Filter.register("tiltShift",function(opts){var defaults,gradient;defaults={center:{x:this.dimensions.width/2,y:this.dimensions.height/2},angle:45,focusWidth:200,startRadius:3,radiusFactor:1.5,steps:3};opts=Util.extend(defaults,opts);opts.angle*=Math.PI/180;gradient=getLinearGradientMap(this.dimensions.width,this.dimensions.height,opts.center.x,opts.center.y,opts.angle,opts.focusWidth,true);return this.processPlugin("compoundBlur",[gradient,opts.startRadius,opts.radiusFactor,opts.steps]);});return Caman.Filter.register("radialBlur",function(opts){var defaults,gradient,radius1,radius2;defaults={size:50,center:{x:this.dimensions.width/2,y:this.dimensions.height/2},startRadius:3,radiusFactor:1.5,steps:3,radius:null};opts=Util.extend(defaults,opts);if(!opts.radius){opts.radius=this.dimensions.widthdiv;i=1<=div?++_i:--_i){stack=stack.next=new BlurStack();if(i===radiusPlus1){stackEnd=stack;}} +stack.next=stackStart;stackIn=null;stackOut=null;yw=yi=0;mul_sum=mul_table[radius];shg_sum=shg_table[radius];for(y=_j=0;0<=height?_jheight;y=0<=height?++_j:--_j){r_in_sum=g_in_sum=b_in_sum=r_sum=g_sum=b_sum=0;r_out_sum=radiusPlus1*(pr=pixels[yi]);g_out_sum=radiusPlus1*(pg=pixels[yi+1]);b_out_sum=radiusPlus1*(pb=pixels[yi+2]);r_sum+=sumFactor*pr;g_sum+=sumFactor*pg;b_sum+=sumFactor*pb;stack=stackStart;for(i=_k=0;0<=radiusPlus1?_kradiusPlus1;i=0<=radiusPlus1?++_k:--_k){stack.r=pr;stack.g=pg;stack.b=pb;stack=stack.next;} +for(i=_l=1;1<=radiusPlus1?_lradiusPlus1;i=1<=radiusPlus1?++_l:--_l){p=yi+((widthMinus1width;x=0<=width?++_m:--_m){pixels[yi]=(r_sum*mul_sum)>>shg_sum;pixels[yi+1]=(g_sum*mul_sum)>>shg_sum;pixels[yi+2]=(b_sum*mul_sum)>>shg_sum;r_sum-=r_out_sum;g_sum-=g_out_sum;b_sum-=b_out_sum;r_out_sum-=stackIn.r;g_out_sum-=stackIn.g;b_out_sum-=stackIn.b;p=(yw+((p=x+radius+1)width;x=0<=width?++_n:--_n){g_in_sum=b_in_sum=r_in_sum=g_sum=b_sum=r_sum=0;yi=x<<2;r_out_sum=radiusPlus1*(pr=pixels[yi]);g_out_sum=radiusPlus1*(pg=pixels[yi+1]);b_out_sum=radiusPlus1*(pb=pixels[yi+2]);r_sum+=sumFactor*pr;g_sum+=sumFactor*pg;b_sum+=sumFactor*pb;stack=stackStart;for(i=_o=0;0<=radiusPlus1?_oradiusPlus1;i=0<=radiusPlus1?++_o:--_o){stack.r=pr;stack.g=pg;stack.b=pb;stack=stack.next;} +yp=width;for(i=_p=1;1<=radius?_p<=radius:_p>=radius;i=1<=radius?++_p:--_p){yi=(yp+x)<<2;r_sum+=(stack.r=(pr=pixels[yi]))*(rbs=radiusPlus1-i);g_sum+=(stack.g=(pg=pixels[yi+1]))*rbs;b_sum+=(stack.b=(pb=pixels[yi+2]))*rbs;r_in_sum+=pr;g_in_sum+=pg;b_in_sum+=pb;stack=stack.next;if(iheight;y=0<=height?++_q:--_q){p=yi<<2;pixels[p]=(r_sum*mul_sum)>>shg_sum;pixels[p+1]=(g_sum*mul_sum)>>shg_sum;pixels[p+2]=(b_sum*mul_sum)>>shg_sum;r_sum-=r_out_sum;g_sum-=g_out_sum;b_sum-=b_out_sum;r_out_sum-=stackIn.r;g_out_sum-=stackIn.g;b_out_sum-=stackIn.b;p=(x+(((p=y+radiusPlus1) + + + + + + + + + _Cacheable__manager_id + http_cache + + + __name__ + caman.full.min.js + + + content_type + text/javascript + + + precondition + + + + title + caman.full.min.js + + + + + diff --git a/bt5/erp5_document_scanner/bt/template_action_path_list b/bt5/erp5_document_scanner/bt/template_action_path_list index 1febd2b17a8925955e240bb6add1c682361b691c..6a5c64c903ca7749dc4f7b7fa985a63e130cb75e 100644 --- a/bt5/erp5_document_scanner/bt/template_action_path_list +++ b/bt5/erp5_document_scanner/bt/template_action_path_list @@ -1,5 +1,6 @@ Accounting Transaction | scan_document Internal Invoice Transaction | scan_document Payment Transaction | scan_document +Preference | document_scanner_preference Purchase Invoice Transaction | scan_document Sale Invoice Transaction | scan_document \ No newline at end of file diff --git a/bt5/erp5_document_scanner/bt/template_keep_last_workflow_history_only_path_list b/bt5/erp5_document_scanner/bt/template_keep_last_workflow_history_only_path_list new file mode 100644 index 0000000000000000000000000000000000000000..87e5720ada30b9f06ba73e7acd6249cb3fa589a0 --- /dev/null +++ b/bt5/erp5_document_scanner/bt/template_keep_last_workflow_history_only_path_list @@ -0,0 +1,3 @@ +web_page_module/rjs_gadget_document_scanner_css +web_page_module/rjs_gadget_document_scanner_html +web_page_module/rjs_gadget_document_scanner_js \ No newline at end of file diff --git a/bt5/erp5_document_scanner/bt/template_path_list b/bt5/erp5_document_scanner/bt/template_path_list index 87e5720ada30b9f06ba73e7acd6249cb3fa589a0..a084abccffedb0a10eecd5d1a765d781c8be623d 100644 --- a/bt5/erp5_document_scanner/bt/template_path_list +++ b/bt5/erp5_document_scanner/bt/template_path_list @@ -1,3 +1,4 @@ +portal_alarms/remove_outdated_active_process web_page_module/rjs_gadget_document_scanner_css web_page_module/rjs_gadget_document_scanner_html web_page_module/rjs_gadget_document_scanner_js \ No newline at end of file diff --git a/bt5/erp5_document_scanner/bt/template_portal_type_property_sheet_list b/bt5/erp5_document_scanner/bt/template_portal_type_property_sheet_list new file mode 100644 index 0000000000000000000000000000000000000000..daea8ebdd4ce230608175285c7624fdafdde2eff --- /dev/null +++ b/bt5/erp5_document_scanner/bt/template_portal_type_property_sheet_list @@ -0,0 +1 @@ +Active Process | Reference \ No newline at end of file diff --git a/bt5/erp5_document_scanner/bt/template_property_sheet_id_list b/bt5/erp5_document_scanner/bt/template_property_sheet_id_list new file mode 100644 index 0000000000000000000000000000000000000000..1158a56c5ae73d344d089ce68c11166f709831b1 --- /dev/null +++ b/bt5/erp5_document_scanner/bt/template_property_sheet_id_list @@ -0,0 +1 @@ +DocumentScannerPreference \ No newline at end of file diff --git a/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocument.zpt b/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocument.zpt index 4292695a2d7d28053ffb922a1da011fc670e2b63..45a597866e6d6fdb16d5d0d363e152268b3a747c 100644 --- a/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocument.zpt +++ b/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocument.zpt @@ -68,11 +68,7 @@ field_your_title Test Scan Document - + type field_your_language @@ -95,88 +91,171 @@
- + waitForElementPresent //button[@class="take-picture-btn ui-btn-icon-left ui-icon-circle"] - - waitForCondition - selenium.browserbot.getCurrentWindow().document.querySelector("video").readyState == 4 - 30000 - click //button[@class="take-picture-btn ui-btn-icon-left ui-icon-circle"] - waitForCondition - selenium.browserbot.getCurrentWindow().document.querySelector(".confirm-btn").style.display != "none" - 30000 + waitForElementPresent + //div[@class="cropper-wrap-box"] + + + + waitForElementPresent + //button[@class="reset-btn ui-btn-icon-left ui-icon-times"] + + click //button[@class="reset-btn ui-btn-icon-left ui-icon-times"] - waitForCondition - selenium.browserbot.getCurrentWindow().document.querySelector(".confirm-btn").style.display == "none" - 30000 + waitForElementPresent + //button[@class="take-picture-btn ui-btn-icon-left ui-icon-circle"] + + click //button[@class="take-picture-btn ui-btn-icon-left ui-icon-circle"] - waitForCondition - selenium.browserbot.getCurrentWindow().document.querySelector(".confirm-btn").style.display != "none" - 3000 + waitForElementPresent + //button[@class="confirm-btn ui-btn-icon-left ui-icon-check"] + + click //button[@class="confirm-btn ui-btn-icon-left ui-icon-check"] - - - - - + + waitForElementPresent + //button[@class="take-picture-btn ui-btn-icon-left ui-icon-circle"] + + + + + waitForElementPresent + //button[@class="ui-btn-icon-left ui-icon-spinner"] + +
- - + - storeValue - //input[@id="field_your_active_process_url"] - active_process_url + waitForElementNotPresent + //button[@class="ui-btn-icon-left ui-icon-spinner"] + - - - - - - - - open - ${base_url}/erp5/Base_assertActiveProcessHasOneImage?active_process_url=${active_process_url} + assertElementPresent + //button[@class="new-btn ui-btn-icon-left ui-icon-plus" and @disabled] + - assertTextPresent - OK + assertElementPresent + //img[@data-page="0" and @class="show-img"] + + + + + assertElementPresent + //img[@data-page="1" and @class="show-img"] + + + + + assertElementNotPresent + //img[@data-page="2" and @class="show-img"] + + + + + click + //img[@data-page="0" and @class="show-img"] + + + + + waitForElementPresent + //button[@class="delete-btn ui-btn-icon-left ui-icon-times"] + + assertElementNotPresent + //button[@class="new-btn ui-btn-icon-left ui-icon-plus" and @disabled] + + + + click + //button[@class="new-btn ui-btn-icon-left ui-icon-plus"] + + + + waitForElementPresent + //button[@class="take-picture-btn ui-btn-icon-left ui-icon-circle"] + + + + click + //button[@class="take-picture-btn ui-btn-icon-left ui-icon-circle"] + + + + waitForElementPresent + //div[@class="cropper-wrap-box"] + + + + waitForElementPresent + //button[@class="confirm-btn ui-btn-icon-left ui-icon-check"] + + + + + click + //button[@class="confirm-btn ui-btn-icon-left ui-icon-check"] + + + + waitForElementPresent + //button[@class="take-picture-btn ui-btn-icon-left ui-icon-circle"] + + + + waitForElementPresent + //button[@class="ui-btn-icon-left ui-icon-spinner"] + + + + assertElementPresent + //img[@data-page="2" and @class="show-img"] + + + + waitForElementNotPresent + //button[@class="ui-btn-icon-left ui-icon-spinner"] + + + + + + + + @@ -225,12 +304,12 @@ waitForTextPresent - of 2 + of 3 assertTextPresent - of 2 + of 3 @@ -239,17 +318,6 @@ - - \ No newline at end of file diff --git a/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocumentPreference.xml b/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocumentPreference.xml new file mode 100644 index 0000000000000000000000000000000000000000..b8b8f3db0456bdb3ca801c8f6554b5a445d7fdde --- /dev/null +++ b/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocumentPreference.xml @@ -0,0 +1,58 @@ + + + + + + + + + + _bind_names + + + + + + + + + + _asgns + + + + name_subpath + traverse_subpath + + + + + + + + + + + content_type + text/html + + + expand + 0 + + + id + testScanDocumentPreference + + + output_encoding + utf-8 + + + title + Test Scan Document Preference + + + + + diff --git a/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocumentPreference.zpt b/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocumentPreference.zpt new file mode 100644 index 0000000000000000000000000000000000000000..58597ecc82073bfbcb837f2240fcc27af02499a5 --- /dev/null +++ b/bt5/erp5_document_scanner_ui_test/PathTemplateItem/portal_tests/renderjs_erp5_document_scanner_zuite/testScanDocumentPreference.zpt @@ -0,0 +1,85 @@ + + + +Test Scan Document (expected failure) + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Test Scan Document (expected failure)
open${base_url}/Zuite_waitForActivities
assertTextPresentDone.
open${base_url}/web_site_module/renderjs_runner/
waitForTextPresentPreferences
click//a[text()="Preferences"]
waitForElementPresent//dd/a[text()="Document Scanner"]
click//dd/a[text()="Document Scanner"]
waitForTextPresentDocument Scanner
waitForElementPresent//input[@id="field_my_preferred_image_scanner_conversion_brightness"]
click//input[@id="field_my_preferred_image_scanner_conversion_enable_greyscale"]
type//input[@id="field_my_preferred_image_scanner_conversion_brightness"]20
type//input[@id="field_my_preferred_image_scanner_conversion_contrast"]20
click//button[@name="submit"]
waitForElementPresent//div[@class="visible"]/button[text()="Data updated."]
+ + \ No newline at end of file diff --git a/bt5/erp5_document_scanner_ui_test/TestTemplateItem/portal_components/test.erp5.testDocumentScanner.py b/bt5/erp5_document_scanner_ui_test/TestTemplateItem/portal_components/test.erp5.testDocumentScanner.py new file mode 100644 index 0000000000000000000000000000000000000000..3a2acfa08269cebcb2f31e602f0ed74563241795 --- /dev/null +++ b/bt5/erp5_document_scanner_ui_test/TestTemplateItem/portal_components/test.erp5.testDocumentScanner.py @@ -0,0 +1,78 @@ +############################################################################## +# +# Copyright (c) 2002-2020 Nexedi SA and Contributors. All Rights Reserved. +# +# WARNING: This program as such is intended to be used by professional +# programmers who take the whole responsibility of assessing all potential +# consequences resulting from its eventual inadequacies and bugs +# End users who are looking for a ready-to-use solution with commercial +# guarantees and support are strongly adviced to contract a Free Software +# Service Company +# +# 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +# +############################################################################## + +import json +from DateTime import DateTime +from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase + +class DocumentScanner(ERP5TypeTestCase): + """ + Document Scanner Test Case + """ + + def getTitle(self): + return "Test Document Scanner" + + def afterSetUp(self): + """ + This is ran before anything, used to set the environment + """ + + id_list = [o.getId() for o in self.portal.portal_catalog( + reference="document_scanner_js", + portal_type="Active Process")] + if id_list: + self.portal.portal_activities.manage_delObjects(ids=id_list) + self.tic() + + def test_remove_outdated_active_process(self): + data_dict = json.loads( + self.portal.Base_getDefaultBackendDataAsJSON()) + self.assertEqual(data_dict["image_list"], []) + active_process_url = data_dict["active_process"] + active_process = self.portal.restrictedTraverse(str(active_process_url)) + self.assertEqual(active_process.getResultList(), []) + data_png = ("" + "AEAAAABCAQAAAC1HAwCAAAAC0lEQVQYV2NgYAAAAAMAAWgm" + "WQ0AAAAASUVORK5CYII=") + response = self.portal.Base_storeNewImageCropped(data_png, + active_process.getRelativeUrl()) + first_uuid = json.loads(response)["uuid"] + self.assertIn(first_uuid, [r.reference for r in active_process.getResultList()]) + response = self.portal.Base_storeNewImageCropped(data_png, + active_process.getRelativeUrl()) + second_uuid = json.loads(response)["uuid"] + self.assertIn(second_uuid, [r.reference for r in active_process.getResultList()]) + self.assertIn(first_uuid, [r.reference for r in active_process.getResultList()]) + self.tic() + req = self.portal.erp5_sql_connection.manage_test + req("update catalog set modification_date='{date}' where uid={uid}".format( + date=(DateTime()-6).toZone('UTC'), + uid=active_process.getUid())) + self.portal.portal_alarms.remove_outdated_active_process.activeSense() + self.tic() + self.assertNotIn(active_process.getId(), list(self.portal.portal_activities.objectIds())) \ No newline at end of file diff --git a/bt5/erp5_document_scanner_ui_test/TestTemplateItem/portal_components/test.erp5.testDocumentScanner.xml b/bt5/erp5_document_scanner_ui_test/TestTemplateItem/portal_components/test.erp5.testDocumentScanner.xml new file mode 100644 index 0000000000000000000000000000000000000000..6f737ff7f155e509e4a4bd02f829e6938ba1f083 --- /dev/null +++ b/bt5/erp5_document_scanner_ui_test/TestTemplateItem/portal_components/test.erp5.testDocumentScanner.xml @@ -0,0 +1,127 @@ + + + + + + + + + + _recorded_property_dict + + AAAAAAAAAAI= + + + + default_reference + testDocumentScanner + + + description + + + + + + id + test.erp5.testDocumentScanner + + + portal_type + Test Component + + + sid + + + + + + text_content_error_message + + + + + + text_content_warning_message + + + + + + version + erp5 + + + workflow_history + + AAAAAAAAAAM= + + + + + + + + + + + + + data + + + + + + + + + + + + + + + data + + + + component_validation_workflow + + AAAAAAAAAAQ= + + + + + + + + + + + + + + + + _log + + + + + action + validate + + + validation_state + validated + + + + + + + + + diff --git a/bt5/erp5_document_scanner_ui_test/bt/template_test_id_list b/bt5/erp5_document_scanner_ui_test/bt/template_test_id_list index cd9f2ccdebab28a67954986061b2c16eebad7702..ff218781410b9d968ca815c59c18afc38805a15f 100644 --- a/bt5/erp5_document_scanner_ui_test/bt/template_test_id_list +++ b/bt5/erp5_document_scanner_ui_test/bt/template_test_id_list @@ -1 +1,2 @@ -test.erp5.testRenderJSDocumentScanner \ No newline at end of file +test.erp5.testRenderJSDocumentScanner +test.erp5.testDocumentScanner \ No newline at end of file diff --git a/bt5/erp5_web_renderjs_ui/PathTemplateItem/web_page_module/rjs_domsugar_js.js b/bt5/erp5_web_renderjs_ui/PathTemplateItem/web_page_module/rjs_domsugar_js.js new file mode 100644 index 0000000000000000000000000000000000000000..6a2d4bae583bf3367fbb6e3036f245d9d2cf969c --- /dev/null +++ b/bt5/erp5_web_renderjs_ui/PathTemplateItem/web_page_module/rjs_domsugar_js.js @@ -0,0 +1,136 @@ +// DOM sugar +// ================================================================== +// Modified version of "Sugared DOM" https://gist.github.com/jacobrask/3524145 +// +// Usage +// ------------------------------------------------------------------ +// var make = domsugar(document); +// +// make( 'p.foo#bar', { hidden: true }, [ make( 'span' ) ] ); +// => +// +// make( '.bar', [ '' ] ); +// make( '.bar', { text: '' } ); +// =>
<b></b>
+// +// make( 'div', [ make( 'b', [ 'Foo', make( 'i' ) ] ) ] ); +// make( 'div', { html: 'Foo' } ); +// =>
Foo
+// +// var myDiv = document.createElement( 'div' ); +// make( myDiv, { id: 'foo' } ); +// =>
+ +(function (window, document) { + 'use strict'; + + // Some properties need to be direct, other are common ones and setting + // them directly is faster than setAttribute. + var direct_property_dict = { + 'class': 'className', + className: 'className', + defaultValue: 'defaultValue', + 'for': 'htmlFor', + html: 'innerHTML', + id: 'id', + name: 'name', + src: 'src', + text: 'textContent', + title: 'title', + value: 'value' + }, + // Object lookup is faster than indexOf. + boolean_property_dict = { + checked: 1, + defaultChecked: 1, + disabled: 1, + hidden: 1, + multiple: 1, + selected: 1 + }; + // splitter = /(#|\.)/; + + function setProperty(el, key, value) { + var prop = direct_property_dict[key]; + if (prop) { + el[prop] = (value === null ? '' : String(value)); + } else if (boolean_property_dict[key]) { + el[key] = !!value; + } else if (value === null) { + el.removeAttribute(key); + } else { + el.setAttribute(key, String(value)); + } + } + + function appendChildren(el, children) { + var i, l, node; + for (i = 0, l = children.length; i < l; i += 1) { + node = children[i]; + if (node) { + if (node instanceof Array) { + appendChildren(el, node); + } else { + if (typeof node === 'string') { + node = document.createTextNode(node); + } + el.appendChild(node); + } + } + } + } + + window.domsugar = function (tag, props, children) { + if (props instanceof Array) { + children = props; + props = null; + } + var el, + prop; +/* + if ( !tag ) { tag = 'div'; createDocumentFragment } + + var parts, name, el, + i, j, l, node, prop; + if ( typeof tag === 'string' && splitter.test( tag ) ) { + parts = tag.split( splitter ); + tag = parts[0]; + if ( !props ) { props = {}; } + for ( i = 1, j = 2, l = parts.length; j < l; i += 2, j += 2 ) { + name = parts[j]; + if ( parts[i] === '#' ) { + props.id = name; + } else { + props.className = props.className ? + props.className + ' ' + name : name; + } + } + } + el = typeof tag === 'string' ? doc.createElement( tag ) : tag; +*/ + if (typeof tag === 'string') { + el = document.createElement(tag); + } else if (tag) { + el = tag; + // Empty the element + while (el.firstChild) { + el.firstChild.remove(); + } + } else { + el = document.createDocumentFragment(); + } + if (props) { + for (prop in props) { + if (props.hasOwnProperty(prop) && (props[prop] !== undefined)) { + setProperty(el, prop, props[prop]); + } + } + } + if (children) { + appendChildren(el, children); + } + return el; + }; + + /*global document, window*/ +}(window, document)); \ No newline at end of file diff --git a/bt5/erp5_web_renderjs_ui/PathTemplateItem/web_page_module/rjs_domsugar_js.xml b/bt5/erp5_web_renderjs_ui/PathTemplateItem/web_page_module/rjs_domsugar_js.xml new file mode 100644 index 0000000000000000000000000000000000000000..7977e3a5fcba1cc313708213fb0559a519a54d1e --- /dev/null +++ b/bt5/erp5_web_renderjs_ui/PathTemplateItem/web_page_module/rjs_domsugar_js.xml @@ -0,0 +1,330 @@ + + + + + + + + + + _Access_contents_information_Permission + + + Anonymous + Assignee + Assignor + Associate + Auditor + Manager + + + + + _Add_portal_content_Permission + + + Assignee + Assignor + Manager + + + + + _Change_local_roles_Permission + + + Assignor + Manager + + + + + _Modify_portal_content_Permission + + + Assignee + Assignor + Manager + + + + + _View_Permission + + + Anonymous + Assignee + Assignor + Associate + Auditor + Manager + + + + + content_md5 + + + + + + default_reference + domsugar.js + + + description + + + + + + id + rjs_domsugar_js + + + language + en + + + portal_type + Web Script + + + short_title + + + + + + title + domsugar + + + version + 001 + + + workflow_history + + AAAAAAAAAAI= + + + + + + + + + + + + + data + + + + document_publication_workflow + + AAAAAAAAAAM= + + + + edit_workflow + + AAAAAAAAAAQ= + + + + processing_status_workflow + + AAAAAAAAAAU= + + + + + + + + + + + + + + + + _log + + + + + action + publish_alive + + + actor + zope + + + comment + + + + error_message + + + + time + + + + + + + + + + + 1576588231.7 + UTC + + + + + + + validation_state + published_alive + + + + + + + + + + + + + + + + _log + + + + + action + edit + + + actor + zope + + + comment + + + + + + error_message + + + + serial + 980.35510.34638.45021 + + + state + current + + + time + + + + + + + + + + + 1576588238.9 + UTC + + + + + + + + + + + + + + + + + + + + _log + + + + + action + detect_converted_file + + + actor + zope + + + comment + + + + error_message + + + + external_processing_state + converted + + + serial + 0.0.0.0 + + + time + + + + + + + + + + + 1576588149.35 + UTC + + + + + + + + + + + + +