Initial commit
This commit is contained in:
208
LICENSE
208
LICENSE
@@ -1,201 +1,15 @@
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
The Apache License v2.0
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
Copyright 2020 Incentro Business Acceleration B.V.
|
||||
|
||||
1. Definitions.
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
|
||||
19
README.md
19
README.md
@@ -1,2 +1,17 @@
|
||||
# barcodescantorch
|
||||
Mendix Native barcode scanner with torch functionality
|
||||
## BarcodeScanTorch
|
||||
[Barcode scanner with torch functionality]
|
||||
|
||||
## Features
|
||||
[feature highlights]
|
||||
|
||||
## Usage
|
||||
[step by step instructions]
|
||||
|
||||
## Demo project
|
||||
[link to sandbox]
|
||||
|
||||
## Issues, suggestions and feature requests
|
||||
[link to GitHub issues]
|
||||
|
||||
## Development and contribution
|
||||
[specify contribute]
|
||||
|
||||
BIN
dist/1.0.0/incentro.BarcodeScanTorch.mpk
vendored
Normal file
BIN
dist/1.0.0/incentro.BarcodeScanTorch.mpk
vendored
Normal file
Binary file not shown.
28
dist/tmp/widgets/BarcodeScanTorch.xml
vendored
Normal file
28
dist/tmp/widgets/BarcodeScanTorch.xml
vendored
Normal file
@@ -0,0 +1,28 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<widget id="incentro.barcodescantorch.BarcodeScanTorch" supportedPlatform="Native" needsEntityContext="true" offlineCapable="true" pluginWidget="true" xmlns="http://www.mendix.com/widget/1.0/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.mendix.com/widget/1.0/ ../node_modules/mendix/custom_widget.xsd">
|
||||
<name>Barcode scanner w/Torch</name>
|
||||
<description>Scan barcode and QR code values with added torch functionality.</description>
|
||||
<icon>iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAAAElBMVEUAAABXV1dVVVVJsPhIsPdVVVWcEer3AAAABHRSTlMASeP9eof+WwAAAHJJREFUeAHtlzEKxTAMQ239r/tfuaHtFEpxIkog6C1e7AchixQXJsET5OQ2eIMo8LDNOQE7wegTOkEMspsAJGKE/iaBjDrlG7OAf6M89xdYYIEFBb4XtPF7n/sL1v2CWYoespSY56ysFw698uilS6995gADwwwpR7MpFwAAAABJRU5ErkJggg==</icon>
|
||||
<properties>
|
||||
<propertyGroup caption="General">
|
||||
<propertyGroup caption="Data source">
|
||||
<property key="barcode" type="attribute">
|
||||
<caption>Barcode</caption>
|
||||
<description>The attribute that will receive the scanned barcode value.</description>
|
||||
<attributeTypes>
|
||||
<attributeType name="String"/>
|
||||
</attributeTypes>
|
||||
</property>
|
||||
</propertyGroup>
|
||||
<propertyGroup caption="Events">
|
||||
<property key="onDetect" type="action" required="false">
|
||||
<caption>On detect</caption>
|
||||
<description/>
|
||||
</property>
|
||||
</propertyGroup>
|
||||
<propertyGroup caption="Common">
|
||||
<systemProperty key="Name"/>
|
||||
</propertyGroup>
|
||||
</propertyGroup>
|
||||
</properties>
|
||||
</widget>
|
||||
274
dist/tmp/widgets/incentro/barcodescantorch/BarcodeScanTorch.js
vendored
Normal file
274
dist/tmp/widgets/incentro/barcodescantorch/BarcodeScanTorch.js
vendored
Normal file
@@ -0,0 +1,274 @@
|
||||
module.exports =
|
||||
/******/ (function(modules) { // webpackBootstrap
|
||||
/******/ // The module cache
|
||||
/******/ var installedModules = {};
|
||||
/******/
|
||||
/******/ // The require function
|
||||
/******/ function __webpack_require__(moduleId) {
|
||||
/******/
|
||||
/******/ // Check if module is in cache
|
||||
/******/ if(installedModules[moduleId]) {
|
||||
/******/ return installedModules[moduleId].exports;
|
||||
/******/ }
|
||||
/******/ // Create a new module (and put it into the cache)
|
||||
/******/ var module = installedModules[moduleId] = {
|
||||
/******/ i: moduleId,
|
||||
/******/ l: false,
|
||||
/******/ exports: {}
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // Execute the module function
|
||||
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
||||
/******/
|
||||
/******/ // Flag the module as loaded
|
||||
/******/ module.l = true;
|
||||
/******/
|
||||
/******/ // Return the exports of the module
|
||||
/******/ return module.exports;
|
||||
/******/ }
|
||||
/******/
|
||||
/******/
|
||||
/******/ // expose the modules object (__webpack_modules__)
|
||||
/******/ __webpack_require__.m = modules;
|
||||
/******/
|
||||
/******/ // expose the module cache
|
||||
/******/ __webpack_require__.c = installedModules;
|
||||
/******/
|
||||
/******/ // define getter function for harmony exports
|
||||
/******/ __webpack_require__.d = function(exports, name, getter) {
|
||||
/******/ if(!__webpack_require__.o(exports, name)) {
|
||||
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
|
||||
/******/ }
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // define __esModule on exports
|
||||
/******/ __webpack_require__.r = function(exports) {
|
||||
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
||||
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
||||
/******/ }
|
||||
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // create a fake namespace object
|
||||
/******/ // mode & 1: value is a module id, require it
|
||||
/******/ // mode & 2: merge all properties of value into the ns
|
||||
/******/ // mode & 4: return value when already ns object
|
||||
/******/ // mode & 8|1: behave like require
|
||||
/******/ __webpack_require__.t = function(value, mode) {
|
||||
/******/ if(mode & 1) value = __webpack_require__(value);
|
||||
/******/ if(mode & 8) return value;
|
||||
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
|
||||
/******/ var ns = Object.create(null);
|
||||
/******/ __webpack_require__.r(ns);
|
||||
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
|
||||
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
|
||||
/******/ return ns;
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
||||
/******/ __webpack_require__.n = function(module) {
|
||||
/******/ var getter = module && module.__esModule ?
|
||||
/******/ function getDefault() { return module['default']; } :
|
||||
/******/ function getModuleExports() { return module; };
|
||||
/******/ __webpack_require__.d(getter, 'a', getter);
|
||||
/******/ return getter;
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // Object.prototype.hasOwnProperty.call
|
||||
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
|
||||
/******/
|
||||
/******/ // __webpack_public_path__
|
||||
/******/ __webpack_require__.p = "";
|
||||
/******/
|
||||
/******/
|
||||
/******/ // Load entry module and return exports
|
||||
/******/ return __webpack_require__(__webpack_require__.s = "./src/BarcodeScanTorch.tsx");
|
||||
/******/ })
|
||||
/************************************************************************/
|
||||
/******/ ({
|
||||
|
||||
/***/ "./src/BarcodeScanTorch.tsx":
|
||||
/*!**********************************!*\
|
||||
!*** ./src/BarcodeScanTorch.tsx ***!
|
||||
\**********************************/
|
||||
/*! exports provided: BarcodeScanTorch */
|
||||
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
||||
|
||||
"use strict";
|
||||
__webpack_require__.r(__webpack_exports__);
|
||||
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BarcodeScanTorch", function() { return BarcodeScanTorch; });
|
||||
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react");
|
||||
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
|
||||
/* harmony import */ var react_native__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-native */ "react-native");
|
||||
/* harmony import */ var react_native__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_native__WEBPACK_IMPORTED_MODULE_1__);
|
||||
/* harmony import */ var react_native_camera__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react-native-camera */ "react-native-camera");
|
||||
/* harmony import */ var react_native_camera__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react_native_camera__WEBPACK_IMPORTED_MODULE_2__);
|
||||
|
||||
|
||||
|
||||
;
|
||||
class BarcodeScanTorch extends react__WEBPACK_IMPORTED_MODULE_0__["Component"] {
|
||||
constructor(props) {
|
||||
super(props);
|
||||
this.onBarCodeReadHandler = this.onBarCodeRead.bind(this);
|
||||
this.manualBarcodeHandler = this.manualBarcode.bind(this);
|
||||
this.toggleTorch = this.toggleTorch.bind(this);
|
||||
this.toggleAutoDetect = this.toggleAutoDetect.bind(this);
|
||||
this.state = {
|
||||
torchON: false,
|
||||
autoDetect: true,
|
||||
textboxValue: '',
|
||||
};
|
||||
}
|
||||
toggleTorch() {
|
||||
this.setState({ torchON: !this.state.torchON });
|
||||
}
|
||||
toggleAutoDetect() {
|
||||
this.setState({ autoDetect: !this.state.autoDetect });
|
||||
}
|
||||
render() {
|
||||
return (Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["View"], { style: localStyle.container },
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native_camera__WEBPACK_IMPORTED_MODULE_2__["RNCamera"], { style: localStyle.preview, captureAudio: false, onBarCodeRead: this.onBarCodeReadHandler, flashMode: this.state.torchON ? react_native_camera__WEBPACK_IMPORTED_MODULE_2__["RNCamera"].Constants.FlashMode.torch : react_native_camera__WEBPACK_IMPORTED_MODULE_2__["RNCamera"].Constants.FlashMode.off }),
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["View"], { style: localStyle.bottom },
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["TouchableOpacity"], { onPress: this.toggleTorch, style: this.state.torchON ? localStyle.switchOn : localStyle.switchOff },
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["Text"], { style: this.state.torchON ? localStyle.textOn : localStyle.textOff },
|
||||
"\u21AF Lamp ",
|
||||
this.state.torchON ? "aan" : "uit")),
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["TouchableOpacity"], { onPress: this.toggleAutoDetect, style: this.state.autoDetect ? localStyle.switchOn : localStyle.switchOff },
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["Text"], { style: this.state.autoDetect ? localStyle.textOn : localStyle.textOff },
|
||||
"\u2551\u2588\u2551 Detectie ",
|
||||
this.state.autoDetect ? "aan" : "uit")),
|
||||
this.state.autoDetect ? Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["View"], null) :
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["View"], { style: localStyle.textBox },
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["Text"], { style: localStyle.textBarcode }, "Barcode: "),
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["TextInput"], { style: localStyle.textInput, placeholder: "Scan of vul handmatig", value: this.state.textboxValue, onChangeText: (text) => this.setState({ textboxValue: text }) }),
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["TouchableOpacity"], { onPress: this.manualBarcodeHandler, style: localStyle.switchOn },
|
||||
Object(react__WEBPACK_IMPORTED_MODULE_0__["createElement"])(react_native__WEBPACK_IMPORTED_MODULE_1__["Text"], { style: localStyle.textOn }, "Naar machine"))))));
|
||||
}
|
||||
onBarCodeRead(event) {
|
||||
if (this.state.autoDetect) {
|
||||
if (this.props.barcode.status !== "available" || event.data === this.props.barcode.value) {
|
||||
return;
|
||||
}
|
||||
this.props.barcode.setValue(event.data);
|
||||
if (this.props.onDetect && this.props.onDetect.canExecute) {
|
||||
react_native__WEBPACK_IMPORTED_MODULE_1__["Vibration"].vibrate(400);
|
||||
this.props.onDetect.execute();
|
||||
}
|
||||
}
|
||||
else {
|
||||
if (this.state.textboxValue !== event.data) {
|
||||
react_native__WEBPACK_IMPORTED_MODULE_1__["Vibration"].vibrate(400);
|
||||
this.setState({ textboxValue: event.data });
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
manualBarcode() {
|
||||
var _a;
|
||||
this.props.barcode.setValue(this.state.textboxValue);
|
||||
(_a = this.props.onDetect) === null || _a === void 0 ? void 0 : _a.execute();
|
||||
}
|
||||
}
|
||||
const localStyle = react_native__WEBPACK_IMPORTED_MODULE_1__["StyleSheet"].create({
|
||||
container: {
|
||||
flex: 1,
|
||||
backgroundColor: 'black'
|
||||
},
|
||||
preview: {
|
||||
flex: 1,
|
||||
alignItems: 'center',
|
||||
},
|
||||
bottom: {
|
||||
justifyContent: 'flex-end',
|
||||
backgroundColor: 'white',
|
||||
alignItems: 'center',
|
||||
},
|
||||
textBox: {
|
||||
backgroundColor: 'white',
|
||||
alignItems: 'center',
|
||||
},
|
||||
textInput: {
|
||||
height: 45,
|
||||
margin: 5,
|
||||
width: 300,
|
||||
borderBottomWidth: 1,
|
||||
borderBottomColor: '#ec7404',
|
||||
},
|
||||
switchOn: {
|
||||
height: 45,
|
||||
margin: 5,
|
||||
borderRadius: 30,
|
||||
backgroundColor: '#ec7404',
|
||||
alignItems: 'center',
|
||||
justifyContent: 'center',
|
||||
width: '85%',
|
||||
},
|
||||
switchOff: {
|
||||
height: 45,
|
||||
margin: 5,
|
||||
borderRadius: 30,
|
||||
backgroundColor: 'white',
|
||||
borderWidth: 1,
|
||||
borderColor: '#ec7404',
|
||||
alignItems: 'center',
|
||||
justifyContent: 'center',
|
||||
width: '85%',
|
||||
},
|
||||
textOn: {
|
||||
color: 'white',
|
||||
fontSize: 16,
|
||||
margin: 50,
|
||||
fontWeight: 'bold',
|
||||
},
|
||||
textOff: {
|
||||
color: '#ec7404',
|
||||
fontSize: 16,
|
||||
margin: 50,
|
||||
fontWeight: 'bold',
|
||||
},
|
||||
textBarcode: {
|
||||
color: '#ec7404',
|
||||
fontSize: 16,
|
||||
fontWeight: 'bold',
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "react":
|
||||
/*!************************!*\
|
||||
!*** external "react" ***!
|
||||
\************************/
|
||||
/*! no static exports found */
|
||||
/***/ (function(module, exports) {
|
||||
|
||||
module.exports = require("react");
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "react-native":
|
||||
/*!*******************************!*\
|
||||
!*** external "react-native" ***!
|
||||
\*******************************/
|
||||
/*! no static exports found */
|
||||
/***/ (function(module, exports) {
|
||||
|
||||
module.exports = require("react-native");
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "react-native-camera":
|
||||
/*!**************************************!*\
|
||||
!*** external "react-native-camera" ***!
|
||||
\**************************************/
|
||||
/*! no static exports found */
|
||||
/***/ (function(module, exports) {
|
||||
|
||||
module.exports = require("react-native-camera");
|
||||
|
||||
/***/ })
|
||||
|
||||
/******/ });
|
||||
//# sourceMappingURL=BarcodeScanTorch.js.map
|
||||
1
dist/tmp/widgets/incentro/barcodescantorch/BarcodeScanTorch.js.map
vendored
Normal file
1
dist/tmp/widgets/incentro/barcodescantorch/BarcodeScanTorch.js.map
vendored
Normal file
File diff suppressed because one or more lines are too long
11
dist/tmp/widgets/package.xml
vendored
Normal file
11
dist/tmp/widgets/package.xml
vendored
Normal file
@@ -0,0 +1,11 @@
|
||||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<package xmlns="http://www.mendix.com/package/1.0/">
|
||||
<clientModule name="BarcodeScanTorch" version="1.0.0" xmlns="http://www.mendix.com/clientModule/1.0/">
|
||||
<widgetFiles>
|
||||
<widgetFile path="BarcodeScanTorch.xml"/>
|
||||
</widgetFiles>
|
||||
<files>
|
||||
<file path="incentro/barcodescantorch"/>
|
||||
</files>
|
||||
</clientModule>
|
||||
</package>
|
||||
20550
package-lock.json
generated
Normal file
20550
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
34
package.json
Normal file
34
package.json
Normal file
@@ -0,0 +1,34 @@
|
||||
{
|
||||
"name": "barcodescantorch",
|
||||
"widgetName": "BarcodeScanTorch",
|
||||
"version": "1.0.0",
|
||||
"description": "Barcode scanner with torch functionality",
|
||||
"copyright": "2020 Incentro Business Acceleration B.V.",
|
||||
"author": "Bart Onstee",
|
||||
"config": {
|
||||
"projectPath": "../..//"
|
||||
},
|
||||
"packagePath": "incentro",
|
||||
"scripts": {
|
||||
"start": "npm run dev",
|
||||
"build": "pluggable-widgets-tools build:native",
|
||||
"dev": "pluggable-widgets-tools start:native",
|
||||
"lint": "pluggable-widgets-tools lint",
|
||||
"lint:fix": "pluggable-widgets-tools lint:fix",
|
||||
"prerelease": "npm run lint",
|
||||
"release": "pluggable-widgets-tools release:native"
|
||||
},
|
||||
"license": "Apache-2.0",
|
||||
"bugs": {
|
||||
"url": "https://github.com/Bart Onstee/barcodescantorch/issues"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@mendix/pluggable-widgets-tools": "^8.12.0",
|
||||
"@types/big.js": "^4.0.5",
|
||||
"@types/react": "~16.9.0",
|
||||
"@types/react-native": "~0.61.23",
|
||||
"react-native-camera": "^3.40.0"
|
||||
},
|
||||
"dependencies": {
|
||||
}
|
||||
}
|
||||
5
prettier.config.js
Normal file
5
prettier.config.js
Normal file
@@ -0,0 +1,5 @@
|
||||
const base = require("@mendix/pluggable-widgets-tools/configs/prettier.base.json");
|
||||
|
||||
module.exports = {
|
||||
...base
|
||||
};
|
||||
170
src/BarcodeScanTorch.tsx
Normal file
170
src/BarcodeScanTorch.tsx
Normal file
@@ -0,0 +1,170 @@
|
||||
import { Component, createElement } from "react";
|
||||
import { View, StyleSheet, TouchableOpacity, Text, TextInput, Vibration } from "react-native";
|
||||
import { RNCamera } from "react-native-camera";
|
||||
import { ValueStatus } from "mendix";
|
||||
import { Style } from "./utils/common";
|
||||
|
||||
export interface BarcodeScanTorchStyle extends Style {
|
||||
};
|
||||
|
||||
import { BarcodeScanTorchProps } from "../typings/BarcodeScanTorchProps";
|
||||
|
||||
export type Props = BarcodeScanTorchProps<BarcodeScanTorchStyle>;
|
||||
|
||||
interface State {
|
||||
torchON?: boolean;
|
||||
autoDetect?: boolean;
|
||||
textboxValue?: string;
|
||||
}
|
||||
|
||||
export class BarcodeScanTorch extends Component<Props, State> {
|
||||
onBarCodeReadHandler = this.onBarCodeRead.bind(this);
|
||||
manualBarcodeHandler = this.manualBarcode.bind(this);
|
||||
constructor(props: Props){
|
||||
super(props)
|
||||
this.toggleTorch = this.toggleTorch.bind(this)
|
||||
this.toggleAutoDetect = this.toggleAutoDetect.bind(this)
|
||||
this.state = {
|
||||
torchON: false,
|
||||
autoDetect: true,
|
||||
textboxValue: '',
|
||||
}
|
||||
}
|
||||
|
||||
toggleTorch(){
|
||||
this.setState({torchON: !this.state.torchON})
|
||||
}
|
||||
|
||||
toggleAutoDetect(){
|
||||
this.setState({autoDetect: !this.state.autoDetect})
|
||||
}
|
||||
|
||||
render(){
|
||||
return (
|
||||
<View style={localStyle.container}>
|
||||
<RNCamera
|
||||
style={localStyle.preview}
|
||||
captureAudio={false}
|
||||
onBarCodeRead={this.onBarCodeReadHandler}
|
||||
flashMode={this.state.torchON ? RNCamera.Constants.FlashMode.torch: RNCamera.Constants.FlashMode.off}
|
||||
/>
|
||||
<View style={localStyle.bottom}>
|
||||
<TouchableOpacity onPress={this.toggleTorch} style={this.state.torchON ? localStyle.switchOn : localStyle.switchOff}>
|
||||
<Text style={this.state.torchON ? localStyle.textOn : localStyle.textOff}>↯ Lamp {this.state.torchON ? "aan" : "uit"}</Text>
|
||||
</TouchableOpacity>
|
||||
<TouchableOpacity onPress={this.toggleAutoDetect} style={this.state.autoDetect ? localStyle.switchOn : localStyle.switchOff}>
|
||||
<Text style={this.state.autoDetect ? localStyle.textOn : localStyle.textOff}>║█║ Detectie {this.state.autoDetect ? "aan" : "uit"}</Text>
|
||||
</TouchableOpacity>
|
||||
{this.state.autoDetect ? <View></View> :
|
||||
<View style={localStyle.textBox}>
|
||||
<Text style={localStyle.textBarcode}>Barcode: </Text>
|
||||
<TextInput style={localStyle.textInput} placeholder="Scan of vul handmatig" value={this.state.textboxValue} onChangeText={(text) => this.setState({textboxValue: text})}/>
|
||||
<TouchableOpacity onPress={this.manualBarcodeHandler} style={localStyle.switchOn}>
|
||||
<Text style={localStyle.textOn}>Naar machine</Text>
|
||||
</TouchableOpacity>
|
||||
</View>
|
||||
}
|
||||
</View>
|
||||
</View>
|
||||
);
|
||||
}
|
||||
// Internal button for testing
|
||||
//<View style={localStyle.bottom}>
|
||||
//<TouchableOpacity onPress={this.toggleTorch} style={localStyle.switch}>
|
||||
//<Text style={{ color: 'white', fontSize: 16 }}>Zaklamp {this.state.torchON ? "uit" : "aan"}</Text>
|
||||
//</TouchableOpacity>
|
||||
//</View>
|
||||
//<Image style={localStyle.Image} source={this.state.torchOn ? flashon : flashoff} />
|
||||
|
||||
|
||||
private onBarCodeRead(event: { data: string }): void {
|
||||
if (this.state.autoDetect) {
|
||||
if (this.props.barcode.status !== ValueStatus.Available || event.data === this.props.barcode.value) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.props.barcode.setValue(event.data);
|
||||
|
||||
if (this.props.onDetect && this.props.onDetect.canExecute) {
|
||||
Vibration.vibrate(400);
|
||||
this.props.onDetect.execute();
|
||||
}
|
||||
}
|
||||
else {
|
||||
if (this.state.textboxValue !== event.data) {
|
||||
Vibration.vibrate(400);
|
||||
this.setState({textboxValue: event.data})
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private manualBarcode() {
|
||||
this.props.barcode.setValue(this.state.textboxValue);
|
||||
this.props.onDetect?.execute();
|
||||
}
|
||||
}
|
||||
|
||||
const localStyle = StyleSheet.create({
|
||||
container: {
|
||||
flex: 1,
|
||||
backgroundColor: 'black'
|
||||
},
|
||||
preview: {
|
||||
flex: 1,
|
||||
alignItems: 'center',
|
||||
},
|
||||
bottom:{
|
||||
justifyContent: 'flex-end',
|
||||
backgroundColor: 'white',
|
||||
alignItems: 'center',
|
||||
},
|
||||
textBox:{
|
||||
backgroundColor: 'white',
|
||||
alignItems: 'center',
|
||||
},
|
||||
textInput:{
|
||||
height: 45,
|
||||
margin: 5,
|
||||
width: 300,
|
||||
borderBottomWidth: 1,
|
||||
borderBottomColor: '#ec7404',
|
||||
},
|
||||
switchOn: {
|
||||
height: 45,
|
||||
margin: 5,
|
||||
borderRadius: 30,
|
||||
backgroundColor: '#ec7404',
|
||||
alignItems: 'center',
|
||||
justifyContent: 'center',
|
||||
width: '85%',
|
||||
},
|
||||
switchOff: {
|
||||
height: 45,
|
||||
margin: 5,
|
||||
borderRadius: 30,
|
||||
backgroundColor: 'white',
|
||||
borderWidth: 1,
|
||||
borderColor: '#ec7404',
|
||||
alignItems: 'center',
|
||||
justifyContent: 'center',
|
||||
width: '85%',
|
||||
},
|
||||
textOn: {
|
||||
color: 'white',
|
||||
fontSize: 16,
|
||||
margin: 50,
|
||||
fontWeight: 'bold',
|
||||
},
|
||||
textOff: {
|
||||
color: '#ec7404',
|
||||
fontSize: 16,
|
||||
margin: 50,
|
||||
fontWeight: 'bold',
|
||||
},
|
||||
textBarcode: {
|
||||
color: '#ec7404',
|
||||
fontSize: 16,
|
||||
fontWeight: 'bold',
|
||||
}
|
||||
})
|
||||
28
src/BarcodeScanTorch.xml
Normal file
28
src/BarcodeScanTorch.xml
Normal file
@@ -0,0 +1,28 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<widget id="incentro.barcodescantorch.BarcodeScanTorch" supportedPlatform="Native" needsEntityContext="true" offlineCapable="true" pluginWidget="true" xmlns="http://www.mendix.com/widget/1.0/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.mendix.com/widget/1.0/ ../node_modules/mendix/custom_widget.xsd">
|
||||
<name>Barcode scanner w/Torch</name>
|
||||
<description>Scan barcode and QR code values with added torch functionality.</description>
|
||||
<icon>iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAAAElBMVEUAAABXV1dVVVVJsPhIsPdVVVWcEer3AAAABHRSTlMASeP9eof+WwAAAHJJREFUeAHtlzEKxTAMQ239r/tfuaHtFEpxIkog6C1e7AchixQXJsET5OQ2eIMo8LDNOQE7wegTOkEMspsAJGKE/iaBjDrlG7OAf6M89xdYYIEFBb4XtPF7n/sL1v2CWYoespSY56ysFw698uilS6995gADwwwpR7MpFwAAAABJRU5ErkJggg==</icon>
|
||||
<properties>
|
||||
<propertyGroup caption="General">
|
||||
<propertyGroup caption="Data source">
|
||||
<property key="barcode" type="attribute">
|
||||
<caption>Barcode</caption>
|
||||
<description>The attribute that will receive the scanned barcode value.</description>
|
||||
<attributeTypes>
|
||||
<attributeType name="String"/>
|
||||
</attributeTypes>
|
||||
</property>
|
||||
</propertyGroup>
|
||||
<propertyGroup caption="Events">
|
||||
<property key="onDetect" type="action" required="false">
|
||||
<caption>On detect</caption>
|
||||
<description/>
|
||||
</property>
|
||||
</propertyGroup>
|
||||
<propertyGroup caption="Common">
|
||||
<systemProperty key="Name"/>
|
||||
</propertyGroup>
|
||||
</propertyGroup>
|
||||
</properties>
|
||||
</widget>
|
||||
11
src/package.xml
Normal file
11
src/package.xml
Normal file
@@ -0,0 +1,11 @@
|
||||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<package xmlns="http://www.mendix.com/package/1.0/">
|
||||
<clientModule name="BarcodeScanTorch" version="1.0.0" xmlns="http://www.mendix.com/clientModule/1.0/">
|
||||
<widgetFiles>
|
||||
<widgetFile path="BarcodeScanTorch.xml"/>
|
||||
</widgetFiles>
|
||||
<files>
|
||||
<file path="incentro/barcodescantorch"/>
|
||||
</files>
|
||||
</clientModule>
|
||||
</package>
|
||||
28
src/utils/common.ts
Normal file
28
src/utils/common.ts
Normal file
@@ -0,0 +1,28 @@
|
||||
import { ImageStyle, TextStyle, ViewStyle } from "react-native";
|
||||
|
||||
interface CustomStyle {
|
||||
[key: string]: string | number;
|
||||
}
|
||||
|
||||
export interface Style {
|
||||
[key: string]: CustomStyle | ViewStyle | TextStyle | ImageStyle;
|
||||
}
|
||||
|
||||
export function flattenStyles<T extends Style>(defaultStyle: T, overrideStyles: Array<T | undefined>): T {
|
||||
const styles = [defaultStyle, ...overrideStyles.filter((object): object is T => object !== undefined)];
|
||||
|
||||
return Object.keys(defaultStyle).reduce(
|
||||
(flattened, currentKey) => {
|
||||
const styleItems = styles.map(object => object[currentKey]);
|
||||
return {
|
||||
...flattened,
|
||||
[currentKey]: flattenObjects(styleItems)
|
||||
};
|
||||
},
|
||||
{} as T
|
||||
);
|
||||
}
|
||||
|
||||
function flattenObjects<T extends object>(objects: T[]): T {
|
||||
return objects.reduce((merged, object) => ({ ...merged, ...object }), {} as T);
|
||||
}
|
||||
3
tsconfig.json
Normal file
3
tsconfig.json
Normal file
@@ -0,0 +1,3 @@
|
||||
{
|
||||
"extends": "./node_modules/@mendix/pluggable-widgets-tools/configs/tsconfig.base.json"
|
||||
}
|
||||
20
typings/BarcodeScanTorchProps.d.ts
vendored
Normal file
20
typings/BarcodeScanTorchProps.d.ts
vendored
Normal file
@@ -0,0 +1,20 @@
|
||||
/**
|
||||
* This file was generated from BarcodeScanTorch.xml
|
||||
* WARNING: All changes made to this file will be overwritten
|
||||
* @author Mendix UI Content Team
|
||||
*/
|
||||
import { ActionValue, EditableValue } from "mendix";
|
||||
|
||||
export interface BarcodeScanTorchProps<Style> {
|
||||
name: string;
|
||||
style: Style[];
|
||||
barcode: EditableValue<string>;
|
||||
onDetect?: ActionValue;
|
||||
}
|
||||
|
||||
export interface BarcodeScanTorchPreviewProps {
|
||||
class: string;
|
||||
style: string;
|
||||
barcode: string;
|
||||
onDetect: {} | null;
|
||||
}
|
||||
Reference in New Issue
Block a user