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 CHANGED
@@ -1,4 +1,4 @@
1
1
  {
2
- "presets": ["@babel/preset-env"]
2
+ "presets": ["@babel/preset-env", "@babel/preset-react"]
3
3
  }
4
4
 
package/README.MD CHANGED
@@ -12,22 +12,22 @@ Ou
12
12
  yarn add react-native-expo-cropper
13
13
 
14
14
 
15
- EXPO SDK 53 -------------------------------------------------------------
15
+ EXPO SDK 54 -------------------------------------------------------------
16
16
 
17
17
  "peerDependencies": {
18
- "expo": "53.0.9",
19
- "react": "19.0.0",
20
- "react-native": "0.79.2"
18
+ "expo": "54.0.0",
19
+ "react": "19.1.0",
20
+ "react-native": "0.81.4"
21
21
  },
22
22
  "dependencies": {
23
- "expo": "53.0.9",
24
- "expo-camera": "16.1.6",
25
- "expo-image-manipulator": "13.1.6",
26
- "expo-image-picker": "16.1.4",
27
- "expo-media-library": "17.1.6",
28
- "expo-screen-orientation": "8.1.6",
29
- "@expo/vector-icons": "14.1.0",
30
- "react-native-svg": "15.11.2",
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.8",
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": "53.0.9",
19
- "react": "19.0.0",
20
- "react-native": "0.79.2"
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": "^54.0.0",
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 dist"
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
  }
@@ -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
- quality: 1,
44
- shutterSound: false,
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
- Alert.alert("Erreur");
47
+ console.log('Camera takePictureAsync error:', error);
48
+ Alert.alert("Erreur", error?.message || 'Capture failed');
54
49
  }
55
50
  }
56
51
  };