react-native-expo-cropper 1.0.8 → 1.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.babelrc +1 -1
- package/README.MD +12 -12
- package/lib/CustomCamera.js +213 -0
- package/lib/ImageCropper.js +326 -0
- package/lib/ImageCropperStyles.js +177 -0
- package/lib/ImageProcessor.js +53 -0
- package/package.json +13 -6
- package/src/CustomCamera.js +7 -12
package/.babelrc
CHANGED
package/README.MD
CHANGED
|
@@ -12,22 +12,22 @@ Ou
|
|
|
12
12
|
yarn add react-native-expo-cropper
|
|
13
13
|
|
|
14
14
|
|
|
15
|
-
EXPO SDK
|
|
15
|
+
EXPO SDK 54 -------------------------------------------------------------
|
|
16
16
|
|
|
17
17
|
"peerDependencies": {
|
|
18
|
-
"expo": "
|
|
19
|
-
"react": "19.
|
|
20
|
-
"react-native": "0.
|
|
18
|
+
"expo": "54.0.0",
|
|
19
|
+
"react": "19.1.0",
|
|
20
|
+
"react-native": "0.81.4"
|
|
21
21
|
},
|
|
22
22
|
"dependencies": {
|
|
23
|
-
"expo": "
|
|
24
|
-
"expo
|
|
25
|
-
"expo-
|
|
26
|
-
"expo-image-
|
|
27
|
-
"expo-
|
|
28
|
-
"expo-
|
|
29
|
-
"
|
|
30
|
-
"react-native-svg": "15.
|
|
23
|
+
"@expo/vector-icons": "^15.0.2",
|
|
24
|
+
"expo": "^54.0.0",
|
|
25
|
+
"expo-camera": "~17.0.8",
|
|
26
|
+
"expo-image-manipulator": "~14.0.7",
|
|
27
|
+
"expo-image-picker": "~17.0.8",
|
|
28
|
+
"expo-media-library": "~18.2.0",
|
|
29
|
+
"expo-screen-orientation": "~9.0.7",
|
|
30
|
+
"react-native-svg": "15.12.1",
|
|
31
31
|
"react-native-view-shot": "4.0.3"
|
|
32
32
|
},
|
|
33
33
|
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = CustomCamera;
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _reactNative = require("react-native");
|
|
10
|
+
var _expoCamera = require("expo-camera");
|
|
11
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
|
|
12
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
13
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
14
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
15
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
16
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
17
|
+
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
18
|
+
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
|
|
19
|
+
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
20
|
+
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
21
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
22
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
23
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
24
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
25
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
26
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
27
|
+
var _Dimensions$get = _reactNative.Dimensions.get('window'),
|
|
28
|
+
width = _Dimensions$get.width;
|
|
29
|
+
function CustomCamera(_ref) {
|
|
30
|
+
var onPhotoCaptured = _ref.onPhotoCaptured;
|
|
31
|
+
var _useState = (0, _react.useState)(false),
|
|
32
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
33
|
+
isReady = _useState2[0],
|
|
34
|
+
setIsReady = _useState2[1];
|
|
35
|
+
var _useState3 = (0, _react.useState)(false),
|
|
36
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
37
|
+
loadingBeforeCapture = _useState4[0],
|
|
38
|
+
setLoadingBeforeCapture = _useState4[1];
|
|
39
|
+
var _useState5 = (0, _react.useState)(null),
|
|
40
|
+
_useState6 = _slicedToArray(_useState5, 1),
|
|
41
|
+
setHasPermission = _useState6[0];
|
|
42
|
+
var cameraRef = (0, _react.useRef)(null);
|
|
43
|
+
(0, _react.useEffect)(function () {
|
|
44
|
+
_asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() {
|
|
45
|
+
var _yield$Camera$request, status;
|
|
46
|
+
return _regenerator().w(function (_context) {
|
|
47
|
+
while (1) switch (_context.n) {
|
|
48
|
+
case 0:
|
|
49
|
+
_context.n = 1;
|
|
50
|
+
return _expoCamera.Camera.requestCameraPermissionsAsync();
|
|
51
|
+
case 1:
|
|
52
|
+
_yield$Camera$request = _context.v;
|
|
53
|
+
status = _yield$Camera$request.status;
|
|
54
|
+
setHasPermission(status === 'granted');
|
|
55
|
+
case 2:
|
|
56
|
+
return _context.a(2);
|
|
57
|
+
}
|
|
58
|
+
}, _callee);
|
|
59
|
+
}))();
|
|
60
|
+
}, []);
|
|
61
|
+
var takePicture = /*#__PURE__*/function () {
|
|
62
|
+
var _ref3 = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee2() {
|
|
63
|
+
var photo, _t;
|
|
64
|
+
return _regenerator().w(function (_context2) {
|
|
65
|
+
while (1) switch (_context2.p = _context2.n) {
|
|
66
|
+
case 0:
|
|
67
|
+
if (!cameraRef.current) {
|
|
68
|
+
_context2.n = 4;
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
71
|
+
_context2.p = 1;
|
|
72
|
+
setLoadingBeforeCapture(true);
|
|
73
|
+
_context2.n = 2;
|
|
74
|
+
return cameraRef.current.takePictureAsync({
|
|
75
|
+
quality: 1,
|
|
76
|
+
imageType: 'jpg'
|
|
77
|
+
});
|
|
78
|
+
case 2:
|
|
79
|
+
photo = _context2.v;
|
|
80
|
+
onPhotoCaptured(photo.uri);
|
|
81
|
+
setLoadingBeforeCapture(false);
|
|
82
|
+
_context2.n = 4;
|
|
83
|
+
break;
|
|
84
|
+
case 3:
|
|
85
|
+
_context2.p = 3;
|
|
86
|
+
_t = _context2.v;
|
|
87
|
+
setLoadingBeforeCapture(false);
|
|
88
|
+
console.log('Camera takePictureAsync error:', _t);
|
|
89
|
+
_reactNative.Alert.alert("Erreur", (_t === null || _t === void 0 ? void 0 : _t.message) || 'Capture failed');
|
|
90
|
+
case 4:
|
|
91
|
+
return _context2.a(2);
|
|
92
|
+
}
|
|
93
|
+
}, _callee2, null, [[1, 3]]);
|
|
94
|
+
}));
|
|
95
|
+
return function takePicture() {
|
|
96
|
+
return _ref3.apply(this, arguments);
|
|
97
|
+
};
|
|
98
|
+
}();
|
|
99
|
+
return /*#__PURE__*/_react["default"].createElement(_reactNative.SafeAreaView, {
|
|
100
|
+
style: styles.outerContainer
|
|
101
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
102
|
+
style: styles.cameraWrapper
|
|
103
|
+
}, /*#__PURE__*/_react["default"].createElement(_expoCamera.CameraView, {
|
|
104
|
+
style: styles.camera,
|
|
105
|
+
facing: "back",
|
|
106
|
+
ref: cameraRef,
|
|
107
|
+
onCameraReady: function onCameraReady() {
|
|
108
|
+
return setIsReady(true);
|
|
109
|
+
}
|
|
110
|
+
}), loadingBeforeCapture && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
111
|
+
style: styles.loadingOverlay
|
|
112
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNative.Image, {
|
|
113
|
+
source: require('../src/assets/loadingCamera.gif'),
|
|
114
|
+
style: styles.loadingGif,
|
|
115
|
+
resizeMode: "contain"
|
|
116
|
+
})), /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
117
|
+
style: styles.touchBlocker,
|
|
118
|
+
pointerEvents: "auto"
|
|
119
|
+
})), /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
120
|
+
style: styles.scanFrame
|
|
121
|
+
})), /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
122
|
+
style: styles.buttonContainer
|
|
123
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNative.TouchableOpacity, {
|
|
124
|
+
style: styles.button,
|
|
125
|
+
onPress: takePicture,
|
|
126
|
+
disabled: !isReady || loadingBeforeCapture
|
|
127
|
+
})));
|
|
128
|
+
}
|
|
129
|
+
var PRIMARY_GREEN = '#198754';
|
|
130
|
+
var DEEP_BLACK = '#0B0B0B';
|
|
131
|
+
var GLOW_WHITE = 'rgba(255, 255, 255, 0.85)';
|
|
132
|
+
var styles = _reactNative.StyleSheet.create({
|
|
133
|
+
outerContainer: {
|
|
134
|
+
flex: 1,
|
|
135
|
+
backgroundColor: DEEP_BLACK,
|
|
136
|
+
justifyContent: 'center',
|
|
137
|
+
alignItems: 'center'
|
|
138
|
+
},
|
|
139
|
+
cameraWrapper: {
|
|
140
|
+
width: width,
|
|
141
|
+
aspectRatio: 9 / 16,
|
|
142
|
+
borderRadius: 30,
|
|
143
|
+
overflow: 'hidden',
|
|
144
|
+
alignItems: 'center',
|
|
145
|
+
justifyContent: 'center',
|
|
146
|
+
position: 'relative'
|
|
147
|
+
},
|
|
148
|
+
camera: _objectSpread({}, _reactNative.StyleSheet.absoluteFillObject),
|
|
149
|
+
scanFrame: {
|
|
150
|
+
position: 'absolute',
|
|
151
|
+
width: '95%',
|
|
152
|
+
height: '80%',
|
|
153
|
+
borderWidth: 4,
|
|
154
|
+
borderColor: PRIMARY_GREEN,
|
|
155
|
+
borderRadius: 5,
|
|
156
|
+
backgroundColor: 'rgba(255,255,255,0.2)'
|
|
157
|
+
},
|
|
158
|
+
loadingOverlay: _objectSpread(_objectSpread({}, _reactNative.StyleSheet.absoluteFillObject), {}, {
|
|
159
|
+
backgroundColor: 'rgba(0, 0, 0, 0.5)',
|
|
160
|
+
zIndex: 20,
|
|
161
|
+
justifyContent: 'center',
|
|
162
|
+
alignItems: 'center'
|
|
163
|
+
}),
|
|
164
|
+
loadingGif: {
|
|
165
|
+
width: 100,
|
|
166
|
+
height: 100
|
|
167
|
+
},
|
|
168
|
+
touchBlocker: _objectSpread(_objectSpread({}, _reactNative.StyleSheet.absoluteFillObject), {}, {
|
|
169
|
+
zIndex: 21,
|
|
170
|
+
backgroundColor: 'transparent'
|
|
171
|
+
}),
|
|
172
|
+
cancelIcon: {
|
|
173
|
+
position: 'absolute',
|
|
174
|
+
top: 20,
|
|
175
|
+
left: 20,
|
|
176
|
+
backgroundColor: PRIMARY_GREEN,
|
|
177
|
+
borderRadius: 5,
|
|
178
|
+
padding: 8
|
|
179
|
+
},
|
|
180
|
+
buttonContainer: {
|
|
181
|
+
position: 'absolute',
|
|
182
|
+
bottom: 0,
|
|
183
|
+
marginBottom: 20,
|
|
184
|
+
flexDirection: 'row',
|
|
185
|
+
justifyContent: 'center'
|
|
186
|
+
},
|
|
187
|
+
button: {
|
|
188
|
+
width: 80,
|
|
189
|
+
height: 80,
|
|
190
|
+
borderRadius: 50,
|
|
191
|
+
backgroundColor: GLOW_WHITE,
|
|
192
|
+
borderWidth: 5,
|
|
193
|
+
borderColor: PRIMARY_GREEN,
|
|
194
|
+
alignItems: 'center',
|
|
195
|
+
justifyContent: 'center'
|
|
196
|
+
},
|
|
197
|
+
text: {
|
|
198
|
+
fontSize: 18,
|
|
199
|
+
color: GLOW_WHITE
|
|
200
|
+
},
|
|
201
|
+
container: {
|
|
202
|
+
flex: 1,
|
|
203
|
+
backgroundColor: DEEP_BLACK,
|
|
204
|
+
justifyContent: 'center',
|
|
205
|
+
alignItems: 'center',
|
|
206
|
+
padding: 20
|
|
207
|
+
},
|
|
208
|
+
iconText: {
|
|
209
|
+
fontSize: 18,
|
|
210
|
+
color: GLOW_WHITE,
|
|
211
|
+
fontWeight: '600'
|
|
212
|
+
}
|
|
213
|
+
});
|
|
@@ -0,0 +1,326 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _ImageCropperStyles = _interopRequireDefault(require("./ImageCropperStyles"));
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _reactNative = require("react-native");
|
|
11
|
+
var _reactNativeSvg = _interopRequireWildcard(require("react-native-svg"));
|
|
12
|
+
var _reactNativeViewShot = require("react-native-view-shot");
|
|
13
|
+
var _CustomCamera = _interopRequireDefault(require("./CustomCamera"));
|
|
14
|
+
var _ImageProcessor = require("./ImageProcessor");
|
|
15
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
|
|
16
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
17
|
+
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
18
|
+
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
|
|
19
|
+
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
20
|
+
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
21
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
22
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
23
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
24
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
25
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
26
|
+
function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
|
|
27
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
28
|
+
function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
|
|
29
|
+
function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
|
|
30
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
31
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
32
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
33
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
34
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
35
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
36
|
+
var ImageCropper = function ImageCropper(_ref) {
|
|
37
|
+
var onConfirm = _ref.onConfirm,
|
|
38
|
+
openCameraFirst = _ref.openCameraFirst,
|
|
39
|
+
initialImage = _ref.initialImage,
|
|
40
|
+
addheight = _ref.addheight;
|
|
41
|
+
var _useState = (0, _react.useState)(null),
|
|
42
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
43
|
+
image = _useState2[0],
|
|
44
|
+
setImage = _useState2[1];
|
|
45
|
+
var _useState3 = (0, _react.useState)([]),
|
|
46
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
47
|
+
points = _useState4[0],
|
|
48
|
+
setPoints = _useState4[1];
|
|
49
|
+
var _useState5 = (0, _react.useState)(false),
|
|
50
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
51
|
+
showResult = _useState6[0],
|
|
52
|
+
setShowResult = _useState6[1];
|
|
53
|
+
var _useState7 = (0, _react.useState)(false),
|
|
54
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
55
|
+
showCustomCamera = _useState8[0],
|
|
56
|
+
setShowCustomCamera = _useState8[1];
|
|
57
|
+
var viewRef = (0, _react.useRef)(null);
|
|
58
|
+
var imageMeasure = (0, _react.useRef)({
|
|
59
|
+
x: 0,
|
|
60
|
+
y: 0,
|
|
61
|
+
width: 0,
|
|
62
|
+
height: 0
|
|
63
|
+
});
|
|
64
|
+
var selectedPointIndex = (0, _react.useRef)(null);
|
|
65
|
+
var lastTap = (0, _react.useRef)(null);
|
|
66
|
+
var _useState9 = (0, _react.useState)(false),
|
|
67
|
+
_useState0 = _slicedToArray(_useState9, 2),
|
|
68
|
+
isLoading = _useState0[0],
|
|
69
|
+
setIsLoading = _useState0[1];
|
|
70
|
+
var _useState1 = (0, _react.useState)(false),
|
|
71
|
+
_useState10 = _slicedToArray(_useState1, 2),
|
|
72
|
+
showFullScreenCapture = _useState10[0],
|
|
73
|
+
setShowFullScreenCapture = _useState10[1];
|
|
74
|
+
var lastValidPosition = (0, _react.useRef)(null);
|
|
75
|
+
(0, _react.useEffect)(function () {
|
|
76
|
+
if (openCameraFirst) {
|
|
77
|
+
setShowCustomCamera(true);
|
|
78
|
+
} else if (initialImage) {
|
|
79
|
+
setImage(initialImage);
|
|
80
|
+
}
|
|
81
|
+
}, [openCameraFirst, initialImage]);
|
|
82
|
+
(0, _react.useEffect)(function () {
|
|
83
|
+
if (!image) return;
|
|
84
|
+
_reactNative.Image.getSize(image, function (imgWidth, imgHeight) {
|
|
85
|
+
var screenRatio = SCREEN_WIDTH / SCREEN_HEIGHT;
|
|
86
|
+
var imageRatio = imgWidth / imgHeight;
|
|
87
|
+
if (imageRatio > screenRatio) {
|
|
88
|
+
imageMeasure.current = {
|
|
89
|
+
width: SCREEN_WIDTH,
|
|
90
|
+
height: SCREEN_WIDTH / imageRatio
|
|
91
|
+
};
|
|
92
|
+
} else {
|
|
93
|
+
imageMeasure.current = {
|
|
94
|
+
width: SCREEN_HEIGHT * imageRatio,
|
|
95
|
+
height: SCREEN_HEIGHT
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
}, [image]);
|
|
100
|
+
var initializeCropBox = function initializeCropBox() {
|
|
101
|
+
var _imageMeasure$current = imageMeasure.current,
|
|
102
|
+
width = _imageMeasure$current.width,
|
|
103
|
+
height = _imageMeasure$current.height;
|
|
104
|
+
// if (width === 0 || height === 0 || points.length > 0) return;
|
|
105
|
+
var boxWidth = width * 0.6;
|
|
106
|
+
var boxHeight = height * 0.6;
|
|
107
|
+
var centerX = width / 2;
|
|
108
|
+
var centerY = height / 2;
|
|
109
|
+
setPoints([{
|
|
110
|
+
x: centerX - boxWidth / 2,
|
|
111
|
+
y: centerY - boxHeight / 2
|
|
112
|
+
}, {
|
|
113
|
+
x: centerX + boxWidth / 2,
|
|
114
|
+
y: centerY - boxHeight / 2
|
|
115
|
+
}, {
|
|
116
|
+
x: centerX + boxWidth / 2,
|
|
117
|
+
y: centerY + boxHeight / 2
|
|
118
|
+
}, {
|
|
119
|
+
x: centerX - boxWidth / 2,
|
|
120
|
+
y: centerY + boxHeight / 2
|
|
121
|
+
}]);
|
|
122
|
+
};
|
|
123
|
+
var onImageLayout = function onImageLayout(e) {
|
|
124
|
+
var layout = e.nativeEvent.layout;
|
|
125
|
+
imageMeasure.current = {
|
|
126
|
+
x: layout.x,
|
|
127
|
+
y: layout.y,
|
|
128
|
+
width: layout.width,
|
|
129
|
+
height: layout.height
|
|
130
|
+
};
|
|
131
|
+
initializeCropBox();
|
|
132
|
+
};
|
|
133
|
+
var createPath = function createPath() {
|
|
134
|
+
if (points.length < 1) return '';
|
|
135
|
+
var path = "M ".concat(points[0].x, " ").concat(points[0].y, " ");
|
|
136
|
+
points.forEach(function (point) {
|
|
137
|
+
return path += "L ".concat(point.x, " ").concat(point.y, " ");
|
|
138
|
+
});
|
|
139
|
+
return path + 'Z';
|
|
140
|
+
};
|
|
141
|
+
var handleTap = function handleTap(e) {
|
|
142
|
+
if (!image || showResult) return;
|
|
143
|
+
var now = Date.now();
|
|
144
|
+
var _e$nativeEvent = e.nativeEvent,
|
|
145
|
+
tapX = _e$nativeEvent.locationX,
|
|
146
|
+
tapY = _e$nativeEvent.locationY;
|
|
147
|
+
if (lastTap.current && now - lastTap.current < 300) {
|
|
148
|
+
var exists = points.some(function (p) {
|
|
149
|
+
return Math.abs(p.x - tapX) < 15 && Math.abs(p.y - tapY) < 15;
|
|
150
|
+
});
|
|
151
|
+
if (!exists) setPoints([].concat(_toConsumableArray(points), [{
|
|
152
|
+
x: tapX,
|
|
153
|
+
y: tapY
|
|
154
|
+
}]));
|
|
155
|
+
lastTap.current = null;
|
|
156
|
+
} else {
|
|
157
|
+
var index = points.findIndex(function (p) {
|
|
158
|
+
return Math.abs(p.x - tapX) < 20 && Math.abs(p.y - tapY) < 20;
|
|
159
|
+
});
|
|
160
|
+
if (index !== -1) {
|
|
161
|
+
selectedPointIndex.current = index;
|
|
162
|
+
lastValidPosition.current = _objectSpread({}, points[index]); // store original position before move
|
|
163
|
+
}
|
|
164
|
+
lastTap.current = now;
|
|
165
|
+
}
|
|
166
|
+
};
|
|
167
|
+
var handleMove = function handleMove(e) {
|
|
168
|
+
if (showResult || selectedPointIndex.current === null) return;
|
|
169
|
+
var _e$nativeEvent2 = e.nativeEvent,
|
|
170
|
+
moveX = _e$nativeEvent2.locationX,
|
|
171
|
+
moveY = _e$nativeEvent2.locationY;
|
|
172
|
+
var width = imageMeasure.current.width;
|
|
173
|
+
var height = imageMeasure.current.height;
|
|
174
|
+
var boundedX = Math.max(0, Math.min(moveX, width));
|
|
175
|
+
var boundedY = Math.max(0, Math.min(moveY, height));
|
|
176
|
+
var edgeThreshold = 10;
|
|
177
|
+
var isNearTopOrBottomEdge = boundedY <= edgeThreshold || boundedY >= height - edgeThreshold;
|
|
178
|
+
var isNearLeftOrRightEdge = boundedX <= edgeThreshold || boundedX >= width - edgeThreshold;
|
|
179
|
+
if (isNearTopOrBottomEdge || isNearLeftOrRightEdge) {
|
|
180
|
+
// Reset point to last known position
|
|
181
|
+
if (lastValidPosition.current && selectedPointIndex.current !== null) {
|
|
182
|
+
setPoints(function (prev) {
|
|
183
|
+
return prev.map(function (p, i) {
|
|
184
|
+
return i === selectedPointIndex.current ? lastValidPosition.current : p;
|
|
185
|
+
});
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
selectedPointIndex.current = null;
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
// Valid move — update point and store as new last valid position
|
|
193
|
+
var updatedPoint = {
|
|
194
|
+
x: boundedX,
|
|
195
|
+
y: boundedY
|
|
196
|
+
};
|
|
197
|
+
lastValidPosition.current = updatedPoint;
|
|
198
|
+
setPoints(function (prev) {
|
|
199
|
+
return prev.map(function (p, i) {
|
|
200
|
+
return i === selectedPointIndex.current ? updatedPoint : p;
|
|
201
|
+
});
|
|
202
|
+
});
|
|
203
|
+
};
|
|
204
|
+
var handleRelease = function handleRelease() {
|
|
205
|
+
selectedPointIndex.current = null;
|
|
206
|
+
};
|
|
207
|
+
var handleReset = function handleReset() {
|
|
208
|
+
// setPoints([]);
|
|
209
|
+
initializeCropBox();
|
|
210
|
+
};
|
|
211
|
+
return /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
212
|
+
style: _ImageCropperStyles["default"].container
|
|
213
|
+
}, showCustomCamera ? /*#__PURE__*/_react["default"].createElement(_CustomCamera["default"], {
|
|
214
|
+
onPhotoCaptured: function onPhotoCaptured(uri) {
|
|
215
|
+
setImage(uri);
|
|
216
|
+
setShowCustomCamera(false);
|
|
217
|
+
},
|
|
218
|
+
onCancel: function onCancel() {
|
|
219
|
+
return setShowCustomCamera(false);
|
|
220
|
+
}
|
|
221
|
+
}) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, !showResult && /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
222
|
+
style: image ? _ImageCropperStyles["default"].buttonContainer : _ImageCropperStyles["default"].centerButtonsContainer
|
|
223
|
+
}, image && /*#__PURE__*/_react["default"].createElement(_reactNative.TouchableOpacity, {
|
|
224
|
+
style: _ImageCropperStyles["default"].button,
|
|
225
|
+
onPress: handleReset
|
|
226
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNative.Text, {
|
|
227
|
+
style: _ImageCropperStyles["default"].buttonText
|
|
228
|
+
}, "Reset")), image && /*#__PURE__*/_react["default"].createElement(_reactNative.TouchableOpacity, {
|
|
229
|
+
style: _ImageCropperStyles["default"].button,
|
|
230
|
+
onPress: /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() {
|
|
231
|
+
var capturedUri, enhancedUri, name, _t;
|
|
232
|
+
return _regenerator().w(function (_context) {
|
|
233
|
+
while (1) switch (_context.p = _context.n) {
|
|
234
|
+
case 0:
|
|
235
|
+
// setShowFullScreenCapture(true);
|
|
236
|
+
setIsLoading(true);
|
|
237
|
+
setShowResult(true);
|
|
238
|
+
_context.p = 1;
|
|
239
|
+
_context.n = 2;
|
|
240
|
+
return new Promise(function (resolve) {
|
|
241
|
+
return requestAnimationFrame(resolve);
|
|
242
|
+
});
|
|
243
|
+
case 2:
|
|
244
|
+
_context.n = 3;
|
|
245
|
+
return (0, _reactNativeViewShot.captureRef)(viewRef, {
|
|
246
|
+
format: 'png',
|
|
247
|
+
quality: 1
|
|
248
|
+
});
|
|
249
|
+
case 3:
|
|
250
|
+
capturedUri = _context.v;
|
|
251
|
+
_context.n = 4;
|
|
252
|
+
return (0, _ImageProcessor.enhanceImage)(capturedUri, addheight);
|
|
253
|
+
case 4:
|
|
254
|
+
enhancedUri = _context.v;
|
|
255
|
+
name = "IMAGE XTK".concat(Date.now(), ".png");
|
|
256
|
+
if (onConfirm) {
|
|
257
|
+
onConfirm(enhancedUri, name);
|
|
258
|
+
}
|
|
259
|
+
_context.n = 6;
|
|
260
|
+
break;
|
|
261
|
+
case 5:
|
|
262
|
+
_context.p = 5;
|
|
263
|
+
_t = _context.v;
|
|
264
|
+
console.error("Erreur lors de la capture :", _t);
|
|
265
|
+
alert("Erreur lors de la capture !");
|
|
266
|
+
case 6:
|
|
267
|
+
_context.p = 6;
|
|
268
|
+
setShowResult(false);
|
|
269
|
+
setIsLoading(false);
|
|
270
|
+
setShowFullScreenCapture(false);
|
|
271
|
+
return _context.f(6);
|
|
272
|
+
case 7:
|
|
273
|
+
return _context.a(2);
|
|
274
|
+
}
|
|
275
|
+
}, _callee, null, [[1, 5, 6, 7]]);
|
|
276
|
+
}))
|
|
277
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNative.Text, {
|
|
278
|
+
style: _ImageCropperStyles["default"].buttonText
|
|
279
|
+
}, "Confirm"))), image && /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
280
|
+
ref: viewRef,
|
|
281
|
+
collapsable: false,
|
|
282
|
+
style: showFullScreenCapture ? _ImageCropperStyles["default"].fullscreenImageContainer : _ImageCropperStyles["default"].imageContainer,
|
|
283
|
+
onStartShouldSetResponder: function onStartShouldSetResponder() {
|
|
284
|
+
return true;
|
|
285
|
+
},
|
|
286
|
+
onResponderStart: handleTap,
|
|
287
|
+
onResponderMove: handleMove,
|
|
288
|
+
onResponderRelease: handleRelease
|
|
289
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNative.Image, {
|
|
290
|
+
source: {
|
|
291
|
+
uri: image
|
|
292
|
+
},
|
|
293
|
+
style: _ImageCropperStyles["default"].image,
|
|
294
|
+
onLayout: onImageLayout
|
|
295
|
+
}), /*#__PURE__*/_react["default"].createElement(_reactNativeSvg["default"], {
|
|
296
|
+
style: _ImageCropperStyles["default"].overlay
|
|
297
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNativeSvg.Path, {
|
|
298
|
+
d: "M 0 0 H ".concat(imageMeasure.current.width, " V ").concat(imageMeasure.current.height, " H 0 Z ").concat(createPath()),
|
|
299
|
+
fill: showResult ? 'white' : 'rgba(255, 255, 255, 0.8)',
|
|
300
|
+
fillRule: "evenodd"
|
|
301
|
+
}), !showResult && points.length > 0 && /*#__PURE__*/_react["default"].createElement(_reactNativeSvg.Path, {
|
|
302
|
+
d: createPath(),
|
|
303
|
+
fill: "transparent",
|
|
304
|
+
stroke: "white",
|
|
305
|
+
strokeWidth: 2
|
|
306
|
+
}), !showResult && points.map(function (point, index) {
|
|
307
|
+
return /*#__PURE__*/_react["default"].createElement(_reactNativeSvg.Circle, {
|
|
308
|
+
key: index,
|
|
309
|
+
cx: point.x,
|
|
310
|
+
cy: point.y,
|
|
311
|
+
r: 10,
|
|
312
|
+
fill: "white"
|
|
313
|
+
});
|
|
314
|
+
})))), /*#__PURE__*/_react["default"].createElement(_reactNative.Modal, {
|
|
315
|
+
visible: isLoading,
|
|
316
|
+
transparent: true,
|
|
317
|
+
animationType: "fade"
|
|
318
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNative.View, {
|
|
319
|
+
style: _ImageCropperStyles["default"].loadingOverlay
|
|
320
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactNative.Image, {
|
|
321
|
+
source: require('../src/assets/loadingCamera.gif'),
|
|
322
|
+
style: _ImageCropperStyles["default"].loadingGif,
|
|
323
|
+
resizeMode: "contain"
|
|
324
|
+
}))));
|
|
325
|
+
};
|
|
326
|
+
var _default = exports["default"] = ImageCropper;
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = void 0;
|
|
7
|
+
var _reactNative = require("react-native");
|
|
8
|
+
var _Dimensions$get = _reactNative.Dimensions.get('window'),
|
|
9
|
+
SCREEN_WIDTH = _Dimensions$get.width,
|
|
10
|
+
SCREEN_HEIGHT = _Dimensions$get.height;
|
|
11
|
+
var IMAGE_HEIGHT = SCREEN_HEIGHT;
|
|
12
|
+
var IMAGE_WIDTH = SCREEN_WIDTH;
|
|
13
|
+
var PRIMARY_GREEN = '#198754';
|
|
14
|
+
var DEEP_BLACK = '#0B0B0B';
|
|
15
|
+
var GLOW_WHITE = 'rgba(255, 255, 255, 0.85)';
|
|
16
|
+
var styles = _reactNative.StyleSheet.create({
|
|
17
|
+
container: {
|
|
18
|
+
flex: 1,
|
|
19
|
+
alignItems: 'center',
|
|
20
|
+
backgroundColor: DEEP_BLACK
|
|
21
|
+
},
|
|
22
|
+
buttonContainer: {
|
|
23
|
+
position: 'absolute',
|
|
24
|
+
bottom: 50,
|
|
25
|
+
left: 0,
|
|
26
|
+
right: 0,
|
|
27
|
+
flexDirection: 'row',
|
|
28
|
+
flexWrap: 'wrap',
|
|
29
|
+
justifyContent: 'center',
|
|
30
|
+
alignItems: 'center',
|
|
31
|
+
paddingHorizontal: 10,
|
|
32
|
+
zIndex: 10
|
|
33
|
+
},
|
|
34
|
+
button: {
|
|
35
|
+
flex: 1,
|
|
36
|
+
width: "100%",
|
|
37
|
+
padding: 10,
|
|
38
|
+
alignItems: "center",
|
|
39
|
+
justifyContent: "center",
|
|
40
|
+
backgroundColor: "#549433",
|
|
41
|
+
borderRadius: 5,
|
|
42
|
+
marginBottom: 20,
|
|
43
|
+
marginRight: 5
|
|
44
|
+
},
|
|
45
|
+
buttonText: {
|
|
46
|
+
color: 'white',
|
|
47
|
+
fontSize: 18,
|
|
48
|
+
fontWeight: '600',
|
|
49
|
+
textAlign: 'center'
|
|
50
|
+
},
|
|
51
|
+
iconText: {
|
|
52
|
+
color: PRIMARY_GREEN,
|
|
53
|
+
fontSize: 16,
|
|
54
|
+
fontWeight: '600',
|
|
55
|
+
textAlign: 'center'
|
|
56
|
+
},
|
|
57
|
+
imageContainer: {
|
|
58
|
+
width: IMAGE_WIDTH,
|
|
59
|
+
height: "80%",
|
|
60
|
+
justifyContent: 'center',
|
|
61
|
+
alignItems: 'center',
|
|
62
|
+
overflow: 'hidden',
|
|
63
|
+
backgroundColor: 'black'
|
|
64
|
+
},
|
|
65
|
+
image: {
|
|
66
|
+
width: '100%',
|
|
67
|
+
height: '100%',
|
|
68
|
+
resizeMode: 'contain'
|
|
69
|
+
},
|
|
70
|
+
overlay: {
|
|
71
|
+
position: 'absolute',
|
|
72
|
+
top: 0,
|
|
73
|
+
left: 0,
|
|
74
|
+
width: '100%',
|
|
75
|
+
height: '100%',
|
|
76
|
+
zIndex: 1
|
|
77
|
+
},
|
|
78
|
+
croppedImage: {
|
|
79
|
+
width: IMAGE_WIDTH,
|
|
80
|
+
height: IMAGE_HEIGHT,
|
|
81
|
+
resizeMode: 'cover',
|
|
82
|
+
marginTop: 10,
|
|
83
|
+
borderWidth: 2,
|
|
84
|
+
borderColor: 'white',
|
|
85
|
+
borderRadius: 10
|
|
86
|
+
},
|
|
87
|
+
fixedButtonContainer: {
|
|
88
|
+
position: 'absolute',
|
|
89
|
+
bottom: 100,
|
|
90
|
+
left: 0,
|
|
91
|
+
right: 0,
|
|
92
|
+
flexDirection: 'row',
|
|
93
|
+
justifyContent: 'center',
|
|
94
|
+
flexWrap: 'wrap',
|
|
95
|
+
gap: 10,
|
|
96
|
+
paddingHorizontal: 10
|
|
97
|
+
},
|
|
98
|
+
fixedButton: {
|
|
99
|
+
backgroundColor: PRIMARY_GREEN,
|
|
100
|
+
paddingVertical: 18,
|
|
101
|
+
paddingHorizontal: 30,
|
|
102
|
+
borderRadius: 12,
|
|
103
|
+
margin: 6,
|
|
104
|
+
alignItems: 'center',
|
|
105
|
+
justifyContent: 'center',
|
|
106
|
+
borderWidth: 0,
|
|
107
|
+
width: SCREEN_WIDTH * 0.4,
|
|
108
|
+
height: 60
|
|
109
|
+
},
|
|
110
|
+
centerButtonsContainer: {
|
|
111
|
+
position: 'absolute',
|
|
112
|
+
bottom: 20,
|
|
113
|
+
left: 0,
|
|
114
|
+
right: 0,
|
|
115
|
+
alignItems: 'center',
|
|
116
|
+
justifyContent: 'center',
|
|
117
|
+
zIndex: 10,
|
|
118
|
+
gap: 10
|
|
119
|
+
},
|
|
120
|
+
welcomeText: {
|
|
121
|
+
position: 'absolute',
|
|
122
|
+
top: '40%',
|
|
123
|
+
left: 20,
|
|
124
|
+
right: 20,
|
|
125
|
+
textAlign: 'center',
|
|
126
|
+
color: GLOW_WHITE,
|
|
127
|
+
fontSize: 40,
|
|
128
|
+
fontWeight: '800',
|
|
129
|
+
zIndex: 10
|
|
130
|
+
},
|
|
131
|
+
startButton: {
|
|
132
|
+
backgroundColor: PRIMARY_GREEN,
|
|
133
|
+
paddingVertical: 18,
|
|
134
|
+
paddingHorizontal: 30,
|
|
135
|
+
borderRadius: 12,
|
|
136
|
+
margin: 6,
|
|
137
|
+
alignItems: 'center',
|
|
138
|
+
justifyContent: 'center',
|
|
139
|
+
borderWidth: 0,
|
|
140
|
+
width: SCREEN_WIDTH * 0.9,
|
|
141
|
+
height: 70
|
|
142
|
+
},
|
|
143
|
+
startButtonText: {
|
|
144
|
+
color: 'white',
|
|
145
|
+
fontSize: 18,
|
|
146
|
+
fontWeight: '600',
|
|
147
|
+
textAlign: 'center'
|
|
148
|
+
},
|
|
149
|
+
loadingOverlay: {
|
|
150
|
+
flex: 1,
|
|
151
|
+
backgroundColor: 'rgba(0,0,0,0.5)',
|
|
152
|
+
justifyContent: 'center',
|
|
153
|
+
alignItems: 'center',
|
|
154
|
+
position: 'absolute',
|
|
155
|
+
top: 0,
|
|
156
|
+
bottom: 0,
|
|
157
|
+
left: 0,
|
|
158
|
+
right: 0,
|
|
159
|
+
zIndex: 9999
|
|
160
|
+
},
|
|
161
|
+
loadingGif: {
|
|
162
|
+
width: 120,
|
|
163
|
+
height: 120
|
|
164
|
+
},
|
|
165
|
+
fullscreenImageContainer: {
|
|
166
|
+
position: 'absolute',
|
|
167
|
+
top: 0,
|
|
168
|
+
left: 0,
|
|
169
|
+
width: SCREEN_WIDTH,
|
|
170
|
+
height: SCREEN_HEIGHT,
|
|
171
|
+
backgroundColor: 'black',
|
|
172
|
+
justifyContent: 'center',
|
|
173
|
+
alignItems: 'center',
|
|
174
|
+
zIndex: 9999
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
var _default = exports["default"] = styles;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.enhanceImage = void 0;
|
|
8
|
+
var ImageManipulator = _interopRequireWildcard(require("expo-image-manipulator"));
|
|
9
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
|
|
10
|
+
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
11
|
+
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
|
|
12
|
+
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
13
|
+
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
14
|
+
var enhanceImage = exports.enhanceImage = /*#__PURE__*/function () {
|
|
15
|
+
var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(uri, addheight) {
|
|
16
|
+
var imageInfo, ratio, maxHeight, newWidth, newHeight, result, _t;
|
|
17
|
+
return _regenerator().w(function (_context) {
|
|
18
|
+
while (1) switch (_context.p = _context.n) {
|
|
19
|
+
case 0:
|
|
20
|
+
_context.p = 0;
|
|
21
|
+
_context.n = 1;
|
|
22
|
+
return ImageManipulator.manipulateAsync(uri, []);
|
|
23
|
+
case 1:
|
|
24
|
+
imageInfo = _context.v;
|
|
25
|
+
ratio = imageInfo.height / imageInfo.width;
|
|
26
|
+
maxHeight = addheight;
|
|
27
|
+
newWidth = Math.round(maxHeight / ratio);
|
|
28
|
+
newHeight = Math.round(newWidth * ratio);
|
|
29
|
+
_context.n = 2;
|
|
30
|
+
return ImageManipulator.manipulateAsync(uri, [{
|
|
31
|
+
resize: {
|
|
32
|
+
width: newWidth,
|
|
33
|
+
height: newHeight
|
|
34
|
+
}
|
|
35
|
+
}], {
|
|
36
|
+
compress: 1,
|
|
37
|
+
format: ImageManipulator.SaveFormat.PNG
|
|
38
|
+
});
|
|
39
|
+
case 2:
|
|
40
|
+
result = _context.v;
|
|
41
|
+
return _context.a(2, result.uri);
|
|
42
|
+
case 3:
|
|
43
|
+
_context.p = 3;
|
|
44
|
+
_t = _context.v;
|
|
45
|
+
console.error("Erreur T404K:", _t);
|
|
46
|
+
return _context.a(2, uri);
|
|
47
|
+
}
|
|
48
|
+
}, _callee, null, [[0, 3]]);
|
|
49
|
+
}));
|
|
50
|
+
return function enhanceImage(_x, _x2) {
|
|
51
|
+
return _ref.apply(this, arguments);
|
|
52
|
+
};
|
|
53
|
+
}();
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-native-expo-cropper",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.10",
|
|
4
4
|
"description": "Recadrage polygonal d'images.",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"author": "PCS AGRI",
|
|
@@ -15,13 +15,13 @@
|
|
|
15
15
|
"react-native-component"
|
|
16
16
|
],
|
|
17
17
|
"peerDependencies": {
|
|
18
|
-
"expo": "
|
|
19
|
-
"react": "19.
|
|
20
|
-
"react-native": "0.
|
|
18
|
+
"expo": "54.0.0",
|
|
19
|
+
"react": "19.1.0",
|
|
20
|
+
"react-native": "0.81.4"
|
|
21
21
|
},
|
|
22
22
|
"dependencies": {
|
|
23
23
|
"@expo/vector-icons": "^15.0.2",
|
|
24
|
-
"expo": "
|
|
24
|
+
"expo": "54.0.0",
|
|
25
25
|
"expo-camera": "~17.0.8",
|
|
26
26
|
"expo-image-manipulator": "~14.0.7",
|
|
27
27
|
"expo-image-picker": "~17.0.8",
|
|
@@ -43,6 +43,13 @@
|
|
|
43
43
|
"homepage": "https://github.com/pcsagri/react-native-expo-cropper#readme",
|
|
44
44
|
"scripts": {
|
|
45
45
|
"test": "echo \"Error: no test specified\" && exit 1",
|
|
46
|
-
"build": "babel src --out-dir
|
|
46
|
+
"build": "babel src --out-dir lib",
|
|
47
|
+
"prepare": "npm run build"
|
|
48
|
+
},
|
|
49
|
+
"devDependencies": {
|
|
50
|
+
"@babel/cli": "^7.28.3",
|
|
51
|
+
"@babel/core": "^7.28.5",
|
|
52
|
+
"@babel/preset-env": "^7.28.5",
|
|
53
|
+
"@babel/preset-react": "^7.28.5"
|
|
47
54
|
}
|
|
48
55
|
}
|
package/src/CustomCamera.js
CHANGED
|
@@ -32,25 +32,20 @@ useEffect(() => {
|
|
|
32
32
|
const takePicture = async () => {
|
|
33
33
|
if (cameraRef.current) {
|
|
34
34
|
try {
|
|
35
|
+
setLoadingBeforeCapture(true);
|
|
35
36
|
|
|
36
|
-
setTimeout(() => {
|
|
37
|
-
setLoadingBeforeCapture(true);
|
|
38
|
-
}, 1000);
|
|
39
|
-
|
|
40
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
41
|
-
|
|
42
37
|
const photo = await cameraRef.current.takePictureAsync({
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
38
|
+
quality: 1,
|
|
39
|
+
imageType: 'jpg'
|
|
40
|
+
});
|
|
46
41
|
|
|
47
|
-
|
|
48
42
|
onPhotoCaptured(photo.uri);
|
|
49
|
-
|
|
43
|
+
|
|
50
44
|
setLoadingBeforeCapture(false);
|
|
51
45
|
} catch (error) {
|
|
52
46
|
setLoadingBeforeCapture(false);
|
|
53
|
-
|
|
47
|
+
console.log('Camera takePictureAsync error:', error);
|
|
48
|
+
Alert.alert("Erreur", error?.message || 'Capture failed');
|
|
54
49
|
}
|
|
55
50
|
}
|
|
56
51
|
};
|