@unif/react-native-camera 1.2.6 → 2.1.0
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/LICENSE +1 -1
- package/README.md +92 -22
- package/lib/module/camera/Camera.js +163 -285
- package/lib/module/camera/Camera.js.map +1 -1
- package/lib/module/camera/Container.js +209 -49
- package/lib/module/camera/Container.js.map +1 -1
- package/lib/module/camera/Error.js +23 -18
- package/lib/module/camera/Error.js.map +1 -1
- package/lib/module/camera/FocusIndicator.js +35 -41
- package/lib/module/camera/FocusIndicator.js.map +1 -1
- package/lib/module/camera/ModalView.js +28 -21
- package/lib/module/camera/ModalView.js.map +1 -1
- package/lib/module/camera/NoCamera.js +38 -14
- package/lib/module/camera/NoCamera.js.map +1 -1
- package/lib/module/camera/NoPermission.js +44 -38
- package/lib/module/camera/NoPermission.js.map +1 -1
- package/lib/module/camera/capturePhotoHelper.js +24 -0
- package/lib/module/camera/capturePhotoHelper.js.map +1 -0
- package/lib/module/camera/footer/Footer.js +83 -140
- package/lib/module/camera/footer/Footer.js.map +1 -1
- package/lib/module/camera/footer/index.js +3 -2
- package/lib/module/camera/footer/index.js.map +1 -1
- package/lib/module/camera/index.js +11 -13
- package/lib/module/camera/index.js.map +1 -1
- package/lib/module/camera/preview/PreView.js +36 -93
- package/lib/module/camera/preview/PreView.js.map +1 -1
- package/lib/module/camera/preview/PreViewContainer.js +28 -29
- package/lib/module/camera/preview/PreViewContainer.js.map +1 -1
- package/lib/module/camera/preview/PreviewFooter.js +30 -21
- package/lib/module/camera/preview/PreviewFooter.js.map +1 -1
- package/lib/module/camera/preview/SinglePre.js +28 -60
- package/lib/module/camera/preview/SinglePre.js.map +1 -1
- package/lib/module/camera/preview/index.js +6 -12
- package/lib/module/camera/preview/index.js.map +1 -1
- package/lib/module/camera/setup/SetUp.js +67 -189
- package/lib/module/camera/setup/SetUp.js.map +1 -1
- package/lib/module/camera/setup/index.js +3 -2
- package/lib/module/camera/setup/index.js.map +1 -1
- package/lib/module/components/Carousel/Carousel.js +33 -40
- package/lib/module/components/Carousel/Carousel.js.map +1 -1
- package/lib/module/components/Carousel/SlideItem.js +22 -70
- package/lib/module/components/Carousel/SlideItem.js.map +1 -1
- package/lib/module/components/Carousel/index.js +4 -11
- package/lib/module/components/Carousel/index.js.map +1 -1
- package/lib/module/components/Loading.js +15 -61
- package/lib/module/components/Loading.js.map +1 -1
- package/lib/module/components/PreviewThumbnail.js +36 -33
- package/lib/module/components/PreviewThumbnail.js.map +1 -1
- package/lib/module/components/index.js +5 -8
- package/lib/module/components/index.js.map +1 -1
- package/lib/module/hooks/index.js +5 -11
- package/lib/module/hooks/index.js.map +1 -1
- package/lib/module/hooks/useCamera.js +44 -0
- package/lib/module/hooks/useCamera.js.map +1 -0
- package/lib/module/hooks/useConfirm.js +13 -49
- package/lib/module/hooks/useConfirm.js.map +1 -1
- package/lib/module/hooks/useCreation.js +18 -0
- package/lib/module/hooks/useCreation.js.map +1 -0
- package/lib/module/index.js +4 -24
- package/lib/module/index.js.map +1 -1
- package/lib/module/package.json +1 -0
- package/lib/module/utils/depsAreSame.js +7 -4
- package/lib/module/utils/depsAreSame.js.map +1 -1
- package/lib/module/utils/index.js +6 -14
- package/lib/module/utils/index.js.map +1 -1
- package/lib/module/utils/interface.js +1 -21
- package/lib/module/utils/interface.js.map +1 -1
- package/lib/module/utils/px-to-dp.js +6 -10
- package/lib/module/utils/px-to-dp.js.map +1 -1
- package/lib/module/utils/util.js +16 -40
- package/lib/module/utils/util.js.map +1 -1
- package/lib/typescript/jest.setup.d.ts +1 -0
- package/lib/typescript/jest.setup.d.ts.map +1 -0
- package/lib/typescript/package.json +1 -0
- package/lib/typescript/src/camera/Camera.d.ts +18 -10
- package/lib/typescript/src/camera/Camera.d.ts.map +1 -1
- package/lib/typescript/src/camera/Container.d.ts +7 -5
- package/lib/typescript/src/camera/Container.d.ts.map +1 -1
- package/lib/typescript/src/camera/Error.d.ts +3 -7
- package/lib/typescript/src/camera/Error.d.ts.map +1 -1
- package/lib/typescript/src/camera/FocusIndicator.d.ts +7 -7
- package/lib/typescript/src/camera/FocusIndicator.d.ts.map +1 -1
- package/lib/typescript/src/camera/ModalView.d.ts +7 -4
- package/lib/typescript/src/camera/ModalView.d.ts.map +1 -1
- package/lib/typescript/src/camera/NoCamera.d.ts +5 -3
- package/lib/typescript/src/camera/NoCamera.d.ts.map +1 -1
- package/lib/typescript/src/camera/NoPermission.d.ts +6 -3
- package/lib/typescript/src/camera/NoPermission.d.ts.map +1 -1
- package/lib/typescript/src/camera/capturePhotoHelper.d.ts +16 -0
- package/lib/typescript/src/camera/capturePhotoHelper.d.ts.map +1 -0
- package/lib/typescript/src/camera/footer/Footer.d.ts +13 -15
- package/lib/typescript/src/camera/footer/Footer.d.ts.map +1 -1
- package/lib/typescript/src/camera/footer/index.d.ts +1 -2
- package/lib/typescript/src/camera/footer/index.d.ts.map +1 -1
- package/lib/typescript/src/camera/index.d.ts +9 -5
- package/lib/typescript/src/camera/index.d.ts.map +1 -1
- package/lib/typescript/src/camera/preview/PreView.d.ts +6 -9
- package/lib/typescript/src/camera/preview/PreView.d.ts.map +1 -1
- package/lib/typescript/src/camera/preview/PreViewContainer.d.ts +8 -5
- package/lib/typescript/src/camera/preview/PreViewContainer.d.ts.map +1 -1
- package/lib/typescript/src/camera/preview/PreviewFooter.d.ts +6 -6
- package/lib/typescript/src/camera/preview/PreviewFooter.d.ts.map +1 -1
- package/lib/typescript/src/camera/preview/SinglePre.d.ts +5 -28
- package/lib/typescript/src/camera/preview/SinglePre.d.ts.map +1 -1
- package/lib/typescript/src/camera/preview/index.d.ts +4 -4
- package/lib/typescript/src/camera/preview/index.d.ts.map +1 -1
- package/lib/typescript/src/camera/setup/SetUp.d.ts +12 -11
- package/lib/typescript/src/camera/setup/SetUp.d.ts.map +1 -1
- package/lib/typescript/src/camera/setup/index.d.ts +1 -2
- package/lib/typescript/src/camera/setup/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Carousel/Carousel.d.ts +6 -8
- package/lib/typescript/src/components/Carousel/Carousel.d.ts.map +1 -1
- package/lib/typescript/src/components/Carousel/SlideItem.d.ts +4 -12
- package/lib/typescript/src/components/Carousel/SlideItem.d.ts.map +1 -1
- package/lib/typescript/src/components/Carousel/index.d.ts +2 -3
- package/lib/typescript/src/components/Carousel/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Loading.d.ts +1 -3
- package/lib/typescript/src/components/Loading.d.ts.map +1 -1
- package/lib/typescript/src/components/PreviewThumbnail.d.ts +7 -8
- package/lib/typescript/src/components/PreviewThumbnail.d.ts.map +1 -1
- package/lib/typescript/src/components/index.d.ts +2 -7
- package/lib/typescript/src/components/index.d.ts.map +1 -1
- package/lib/typescript/src/hooks/index.d.ts +3 -3
- package/lib/typescript/src/hooks/index.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useCamera.d.ts +4 -0
- package/lib/typescript/src/hooks/useCamera.d.ts.map +1 -0
- package/lib/typescript/src/hooks/useConfirm.d.ts +1 -5
- package/lib/typescript/src/hooks/useConfirm.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useCreation.d.ts +2 -0
- package/lib/typescript/src/hooks/useCreation.d.ts.map +1 -0
- package/lib/typescript/src/index.d.ts +3 -4
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/utils/depsAreSame.d.ts +1 -2
- package/lib/typescript/src/utils/depsAreSame.d.ts.map +1 -1
- package/lib/typescript/src/utils/index.d.ts +2 -4
- package/lib/typescript/src/utils/index.d.ts.map +1 -1
- package/lib/typescript/src/utils/interface.d.ts +30 -70
- package/lib/typescript/src/utils/interface.d.ts.map +1 -1
- package/lib/typescript/src/utils/px-to-dp.d.ts +1 -3
- package/lib/typescript/src/utils/px-to-dp.d.ts.map +1 -1
- package/lib/typescript/src/utils/util.d.ts +8 -9
- package/lib/typescript/src/utils/util.d.ts.map +1 -1
- package/package.json +123 -108
- package/src/camera/Camera.tsx +210 -331
- package/src/camera/Container.tsx +224 -50
- package/src/camera/Error.tsx +22 -23
- package/src/camera/FocusIndicator.tsx +36 -46
- package/src/camera/ModalView.tsx +26 -24
- package/src/camera/NoCamera.tsx +37 -14
- package/src/camera/NoPermission.tsx +45 -37
- package/src/camera/capturePhotoHelper.ts +37 -0
- package/src/camera/footer/Footer.tsx +104 -195
- package/src/camera/footer/index.tsx +1 -2
- package/src/camera/index.tsx +12 -13
- package/src/camera/preview/PreView.tsx +22 -103
- package/src/camera/preview/PreViewContainer.tsx +23 -27
- package/src/camera/preview/PreviewFooter.tsx +28 -22
- package/src/camera/preview/SinglePre.tsx +23 -68
- package/src/camera/preview/index.tsx +4 -13
- package/src/camera/setup/SetUp.tsx +80 -217
- package/src/camera/setup/index.tsx +1 -3
- package/src/components/Carousel/Carousel.tsx +22 -42
- package/src/components/Carousel/SlideItem.tsx +12 -87
- package/src/components/Carousel/index.tsx +2 -13
- package/src/components/Loading.tsx +7 -69
- package/src/components/PreviewThumbnail.tsx +38 -33
- package/src/components/index.tsx +2 -7
- package/src/hooks/index.ts +3 -12
- package/src/hooks/useCamera.tsx +42 -0
- package/src/hooks/useConfirm.tsx +10 -57
- package/src/hooks/useCreation.ts +26 -0
- package/src/index.tsx +3 -37
- package/src/utils/depsAreSame.ts +7 -8
- package/src/utils/index.ts +2 -12
- package/src/utils/interface.ts +26 -87
- package/src/utils/px-to-dp.tsx +5 -9
- package/src/utils/util.ts +17 -42
- package/UnifRNCamera.podspec +0 -41
- package/android/CMakeLists.txt +0 -15
- package/android/build.gradle +0 -124
- package/android/cpp-adapter.cpp +0 -8
- package/android/gradle.properties +0 -5
- package/android/src/main/AndroidManifest.xml +0 -3
- package/android/src/main/AndroidManifestNew.xml +0 -2
- package/android/src/main/java/com/unif/reactnativecamera/ReactNativeCameraModule.java +0 -34
- package/android/src/main/java/com/unif/reactnativecamera/ReactNativeCameraPackage.java +0 -45
- package/android/src/newarch/ReactNativeCameraSpec.java +0 -9
- package/android/src/oldarch/ReactNativeCameraSpec.java +0 -13
- package/cpp/unif-react-native-camera.cpp +0 -7
- package/cpp/unif-react-native-camera.h +0 -8
- package/ios/ReactNativeCamera.h +0 -15
- package/ios/ReactNativeCamera.mm +0 -51
- package/lib/commonjs/NativeReactNativeCamera.js +0 -17
- package/lib/commonjs/NativeReactNativeCamera.js.map +0 -1
- package/lib/commonjs/assets/close.png +0 -0
- package/lib/commonjs/assets/home/record.png +0 -0
- package/lib/commonjs/assets/home/take.png +0 -0
- package/lib/commonjs/assets/preview/back.png +0 -0
- package/lib/commonjs/assets/preview/del.png +0 -0
- package/lib/commonjs/assets/preview/rotate.png +0 -0
- package/lib/commonjs/assets/preview/save.png +0 -0
- package/lib/commonjs/assets/tools/auto.png +0 -0
- package/lib/commonjs/assets/tools/defaultEye.png +0 -0
- package/lib/commonjs/assets/tools/enlarge.png +0 -0
- package/lib/commonjs/assets/tools/fishEye.png +0 -0
- package/lib/commonjs/assets/tools/narrow.png +0 -0
- package/lib/commonjs/assets/tools/off.png +0 -0
- package/lib/commonjs/assets/tools/on.png +0 -0
- package/lib/commonjs/assets/tools/volumeOff.png +0 -0
- package/lib/commonjs/assets/tools/volumeOn.png +0 -0
- package/lib/commonjs/camera/Camera.js +0 -316
- package/lib/commonjs/camera/Camera.js.map +0 -1
- package/lib/commonjs/camera/Container.js +0 -64
- package/lib/commonjs/camera/Container.js.map +0 -1
- package/lib/commonjs/camera/Error.js +0 -30
- package/lib/commonjs/camera/Error.js.map +0 -1
- package/lib/commonjs/camera/FocusIndicator.js +0 -64
- package/lib/commonjs/camera/FocusIndicator.js.map +0 -1
- package/lib/commonjs/camera/ModalView.js +0 -37
- package/lib/commonjs/camera/ModalView.js.map +0 -1
- package/lib/commonjs/camera/NoCamera.js +0 -23
- package/lib/commonjs/camera/NoCamera.js.map +0 -1
- package/lib/commonjs/camera/NoPermission.js +0 -50
- package/lib/commonjs/camera/NoPermission.js.map +0 -1
- package/lib/commonjs/camera/footer/Footer.js +0 -159
- package/lib/commonjs/camera/footer/Footer.js.map +0 -1
- package/lib/commonjs/camera/footer/index.js +0 -14
- package/lib/commonjs/camera/footer/index.js.map +0 -1
- package/lib/commonjs/camera/index.js +0 -35
- package/lib/commonjs/camera/index.js.map +0 -1
- package/lib/commonjs/camera/preview/PreView.js +0 -109
- package/lib/commonjs/camera/preview/PreView.js.map +0 -1
- package/lib/commonjs/camera/preview/PreViewContainer.js +0 -42
- package/lib/commonjs/camera/preview/PreViewContainer.js.map +0 -1
- package/lib/commonjs/camera/preview/PreviewFooter.js +0 -35
- package/lib/commonjs/camera/preview/PreviewFooter.js.map +0 -1
- package/lib/commonjs/camera/preview/SinglePre.js +0 -72
- package/lib/commonjs/camera/preview/SinglePre.js.map +0 -1
- package/lib/commonjs/camera/preview/index.js +0 -28
- package/lib/commonjs/camera/preview/index.js.map +0 -1
- package/lib/commonjs/camera/setup/SetUp.js +0 -205
- package/lib/commonjs/camera/setup/SetUp.js.map +0 -1
- package/lib/commonjs/camera/setup/index.js +0 -14
- package/lib/commonjs/camera/setup/index.js.map +0 -1
- package/lib/commonjs/camera/watermark/Render.js +0 -110
- package/lib/commonjs/camera/watermark/Render.js.map +0 -1
- package/lib/commonjs/camera/watermark/ViewShotWatermark.js +0 -143
- package/lib/commonjs/camera/watermark/ViewShotWatermark.js.map +0 -1
- package/lib/commonjs/camera/watermark/index.js +0 -21
- package/lib/commonjs/camera/watermark/index.js.map +0 -1
- package/lib/commonjs/components/Back.js +0 -48
- package/lib/commonjs/components/Back.js.map +0 -1
- package/lib/commonjs/components/Carousel/Carousel.js +0 -51
- package/lib/commonjs/components/Carousel/Carousel.js.map +0 -1
- package/lib/commonjs/components/Carousel/SlideItem.js +0 -84
- package/lib/commonjs/components/Carousel/SlideItem.js.map +0 -1
- package/lib/commonjs/components/Carousel/index.js +0 -21
- package/lib/commonjs/components/Carousel/index.js.map +0 -1
- package/lib/commonjs/components/Delete.js +0 -36
- package/lib/commonjs/components/Delete.js.map +0 -1
- package/lib/commonjs/components/Loading.js +0 -75
- package/lib/commonjs/components/Loading.js.map +0 -1
- package/lib/commonjs/components/Modal/Confirm.js +0 -121
- package/lib/commonjs/components/Modal/Confirm.js.map +0 -1
- package/lib/commonjs/components/Modal/index.js +0 -14
- package/lib/commonjs/components/Modal/index.js.map +0 -1
- package/lib/commonjs/components/PreviewThumbnail.js +0 -44
- package/lib/commonjs/components/PreviewThumbnail.js.map +0 -1
- package/lib/commonjs/components/Rotate.js +0 -32
- package/lib/commonjs/components/Rotate.js.map +0 -1
- package/lib/commonjs/components/Save.js +0 -48
- package/lib/commonjs/components/Save.js.map +0 -1
- package/lib/commonjs/components/index.js +0 -73
- package/lib/commonjs/components/index.js.map +0 -1
- package/lib/commonjs/hooks/index.js +0 -21
- package/lib/commonjs/hooks/index.js.map +0 -1
- package/lib/commonjs/hooks/useCamera.tsx/index.js +0 -90
- package/lib/commonjs/hooks/useCamera.tsx/index.js.map +0 -1
- package/lib/commonjs/hooks/useConfirm.js +0 -61
- package/lib/commonjs/hooks/useConfirm.js.map +0 -1
- package/lib/commonjs/hooks/useCreation/index.js +0 -34
- package/lib/commonjs/hooks/useCreation/index.js.map +0 -1
- package/lib/commonjs/index.js +0 -39
- package/lib/commonjs/index.js.map +0 -1
- package/lib/commonjs/utils/common.js +0 -69
- package/lib/commonjs/utils/common.js.map +0 -1
- package/lib/commonjs/utils/depsAreSame.js +0 -14
- package/lib/commonjs/utils/depsAreSame.js.map +0 -1
- package/lib/commonjs/utils/index.js +0 -72
- package/lib/commonjs/utils/index.js.map +0 -1
- package/lib/commonjs/utils/interface.js +0 -24
- package/lib/commonjs/utils/interface.js.map +0 -1
- package/lib/commonjs/utils/px-to-dp.js +0 -21
- package/lib/commonjs/utils/px-to-dp.js.map +0 -1
- package/lib/commonjs/utils/render-item.js +0 -40
- package/lib/commonjs/utils/render-item.js.map +0 -1
- package/lib/commonjs/utils/util.js +0 -53
- package/lib/commonjs/utils/util.js.map +0 -1
- package/lib/commonjs/utils/watermark.js +0 -49
- package/lib/commonjs/utils/watermark.js.map +0 -1
- package/lib/module/NativeReactNativeCamera.js +0 -12
- package/lib/module/NativeReactNativeCamera.js.map +0 -1
- package/lib/module/assets/close.png +0 -0
- package/lib/module/assets/home/record.png +0 -0
- package/lib/module/assets/home/take.png +0 -0
- package/lib/module/assets/preview/back.png +0 -0
- package/lib/module/assets/preview/del.png +0 -0
- package/lib/module/assets/preview/rotate.png +0 -0
- package/lib/module/assets/preview/save.png +0 -0
- package/lib/module/assets/tools/auto.png +0 -0
- package/lib/module/assets/tools/defaultEye.png +0 -0
- package/lib/module/assets/tools/enlarge.png +0 -0
- package/lib/module/assets/tools/fishEye.png +0 -0
- package/lib/module/assets/tools/narrow.png +0 -0
- package/lib/module/assets/tools/off.png +0 -0
- package/lib/module/assets/tools/on.png +0 -0
- package/lib/module/assets/tools/volumeOff.png +0 -0
- package/lib/module/assets/tools/volumeOn.png +0 -0
- package/lib/module/camera/watermark/Render.js +0 -102
- package/lib/module/camera/watermark/Render.js.map +0 -1
- package/lib/module/camera/watermark/ViewShotWatermark.js +0 -133
- package/lib/module/camera/watermark/ViewShotWatermark.js.map +0 -1
- package/lib/module/camera/watermark/index.js +0 -13
- package/lib/module/camera/watermark/index.js.map +0 -1
- package/lib/module/components/Back.js +0 -40
- package/lib/module/components/Back.js.map +0 -1
- package/lib/module/components/Delete.js +0 -28
- package/lib/module/components/Delete.js.map +0 -1
- package/lib/module/components/Modal/Confirm.js +0 -111
- package/lib/module/components/Modal/Confirm.js.map +0 -1
- package/lib/module/components/Modal/index.js +0 -3
- package/lib/module/components/Modal/index.js.map +0 -1
- package/lib/module/components/Rotate.js +0 -24
- package/lib/module/components/Rotate.js.map +0 -1
- package/lib/module/components/Save.js +0 -40
- package/lib/module/components/Save.js.map +0 -1
- package/lib/module/hooks/useCamera.tsx/index.js +0 -81
- package/lib/module/hooks/useCamera.tsx/index.js.map +0 -1
- package/lib/module/hooks/useCreation/index.js +0 -27
- package/lib/module/hooks/useCreation/index.js.map +0 -1
- package/lib/module/utils/common.js +0 -62
- package/lib/module/utils/common.js.map +0 -1
- package/lib/module/utils/render-item.js +0 -32
- package/lib/module/utils/render-item.js.map +0 -1
- package/lib/module/utils/watermark.js +0 -39
- package/lib/module/utils/watermark.js.map +0 -1
- package/lib/typescript/src/NativeReactNativeCamera.d.ts +0 -6
- package/lib/typescript/src/NativeReactNativeCamera.d.ts.map +0 -1
- package/lib/typescript/src/camera/watermark/Render.d.ts +0 -26
- package/lib/typescript/src/camera/watermark/Render.d.ts.map +0 -1
- package/lib/typescript/src/camera/watermark/ViewShotWatermark.d.ts +0 -41
- package/lib/typescript/src/camera/watermark/ViewShotWatermark.d.ts.map +0 -1
- package/lib/typescript/src/camera/watermark/index.d.ts +0 -4
- package/lib/typescript/src/camera/watermark/index.d.ts.map +0 -1
- package/lib/typescript/src/components/Back.d.ts +0 -20
- package/lib/typescript/src/components/Back.d.ts.map +0 -1
- package/lib/typescript/src/components/Delete.d.ts +0 -7
- package/lib/typescript/src/components/Delete.d.ts.map +0 -1
- package/lib/typescript/src/components/Modal/Confirm.d.ts +0 -9
- package/lib/typescript/src/components/Modal/Confirm.d.ts.map +0 -1
- package/lib/typescript/src/components/Modal/index.d.ts +0 -3
- package/lib/typescript/src/components/Modal/index.d.ts.map +0 -1
- package/lib/typescript/src/components/Rotate.d.ts +0 -9
- package/lib/typescript/src/components/Rotate.d.ts.map +0 -1
- package/lib/typescript/src/components/Save.d.ts +0 -20
- package/lib/typescript/src/components/Save.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useCamera.tsx/index.d.ts +0 -5
- package/lib/typescript/src/hooks/useCamera.tsx/index.d.ts.map +0 -1
- package/lib/typescript/src/hooks/useCreation/index.d.ts +0 -3
- package/lib/typescript/src/hooks/useCreation/index.d.ts.map +0 -1
- package/lib/typescript/src/utils/common.d.ts +0 -14
- package/lib/typescript/src/utils/common.d.ts.map +0 -1
- package/lib/typescript/src/utils/render-item.d.ts +0 -10
- package/lib/typescript/src/utils/render-item.d.ts.map +0 -1
- package/lib/typescript/src/utils/watermark.d.ts +0 -11
- package/lib/typescript/src/utils/watermark.d.ts.map +0 -1
- package/src/NativeReactNativeCamera.ts +0 -15
- package/src/assets/close.png +0 -0
- package/src/assets/home/record.png +0 -0
- package/src/assets/home/take.png +0 -0
- package/src/assets/preview/back.png +0 -0
- package/src/assets/preview/del.png +0 -0
- package/src/assets/preview/rotate.png +0 -0
- package/src/assets/preview/save.png +0 -0
- package/src/assets/tools/auto.png +0 -0
- package/src/assets/tools/defaultEye.png +0 -0
- package/src/assets/tools/enlarge.png +0 -0
- package/src/assets/tools/fishEye.png +0 -0
- package/src/assets/tools/narrow.png +0 -0
- package/src/assets/tools/off.png +0 -0
- package/src/assets/tools/on.png +0 -0
- package/src/assets/tools/volumeOff.png +0 -0
- package/src/assets/tools/volumeOn.png +0 -0
- package/src/camera/watermark/Render.tsx +0 -128
- package/src/camera/watermark/ViewShotWatermark.tsx +0 -134
- package/src/camera/watermark/index.tsx +0 -12
- package/src/components/Back.tsx +0 -37
- package/src/components/Delete.tsx +0 -30
- package/src/components/Modal/Confirm.tsx +0 -116
- package/src/components/Modal/index.tsx +0 -3
- package/src/components/Rotate.tsx +0 -32
- package/src/components/Save.tsx +0 -37
- package/src/hooks/useCamera.tsx/index.tsx +0 -95
- package/src/hooks/useCreation/index.ts +0 -25
- package/src/utils/common.ts +0 -67
- package/src/utils/render-item.tsx +0 -39
- package/src/utils/watermark.ts +0 -55
|
@@ -1,75 +1,30 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
* @LastEditors: 刘利军
|
|
5
|
-
* @LastEditTime: 2024-12-27 10:55:55
|
|
6
|
-
* @Description:
|
|
7
|
-
* @PageName:
|
|
8
|
-
*/
|
|
9
|
-
import { Image, StyleSheet, View, type ImageResizeMode } from 'react-native';
|
|
10
|
-
import React from 'react';
|
|
11
|
-
import PreviewFooter from './PreviewFooter';
|
|
12
|
-
import { Back, Save } from '../../components';
|
|
13
|
-
import { formatUri, type CustomPhotoFile } from '../../utils';
|
|
14
|
-
import { useSafeAreaInsets } from 'react-native-safe-area-context';
|
|
1
|
+
import { Image, StyleSheet, View } from 'react-native';
|
|
2
|
+
import { Empty } from '@unif/react-native-design';
|
|
3
|
+
import type { CustomPhotoFile } from '../../utils';
|
|
15
4
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
}
|
|
20
|
-
export interface CommonProps {
|
|
21
|
-
onBack?: () => void;
|
|
22
|
-
onDel?: (photo?: CustomPhotoFile) => Promise<boolean> | undefined;
|
|
23
|
-
onSave?: () => void;
|
|
24
|
-
}
|
|
25
|
-
const SinglePre: React.FC<SingleProps> = ({
|
|
26
|
-
uri,
|
|
27
|
-
resizeMode,
|
|
28
|
-
onBack,
|
|
29
|
-
onSave,
|
|
30
|
-
}) => {
|
|
31
|
-
const inset = useSafeAreaInsets();
|
|
5
|
+
type Props = { file: CustomPhotoFile };
|
|
6
|
+
|
|
7
|
+
export function SinglePre({ file }: Props) {
|
|
32
8
|
return (
|
|
33
|
-
<View style={styles.
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
<
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
style={styles.image}
|
|
45
|
-
text="返回"
|
|
46
|
-
onPress={onBack}
|
|
47
|
-
/>,
|
|
48
|
-
<Save
|
|
49
|
-
key="save"
|
|
50
|
-
style={styles.image}
|
|
51
|
-
text="保存"
|
|
52
|
-
onPress={onSave}
|
|
53
|
-
/>,
|
|
54
|
-
]}
|
|
9
|
+
<View style={styles.root} testID="single-pre">
|
|
10
|
+
{file.mime === 'video/mp4' ? (
|
|
11
|
+
<Empty
|
|
12
|
+
title={`视频 · ${file.duration?.toFixed(1) ?? '0.0'}s`}
|
|
13
|
+
desc={file.path}
|
|
14
|
+
/>
|
|
15
|
+
) : (
|
|
16
|
+
<Image
|
|
17
|
+
source={{ uri: file.uri }}
|
|
18
|
+
style={StyleSheet.absoluteFill}
|
|
19
|
+
resizeMode="contain"
|
|
55
20
|
/>
|
|
56
|
-
|
|
21
|
+
)}
|
|
57
22
|
</View>
|
|
58
23
|
);
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
export default SinglePre;
|
|
62
|
-
|
|
63
|
-
export const styles = StyleSheet.create({
|
|
64
|
-
container: {
|
|
65
|
-
flex: 1,
|
|
66
|
-
},
|
|
24
|
+
}
|
|
67
25
|
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
bottom: 0,
|
|
73
|
-
},
|
|
74
|
-
image: { width: 60, height: 60 },
|
|
26
|
+
const styles = StyleSheet.create({
|
|
27
|
+
// 相机预览容器固定黑底:相机 UX 惯例(任何主题下都需要让照片 / 视频在纯黑上凸显),
|
|
28
|
+
// 不走 c.background token.
|
|
29
|
+
root: { flex: 1, backgroundColor: '#000' },
|
|
75
30
|
});
|
|
@@ -1,13 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
* @LastEditTime: 2024-12-17 10:17:04
|
|
6
|
-
* @Description:
|
|
7
|
-
* @PageName:
|
|
8
|
-
*/
|
|
9
|
-
import PreView from './PreView';
|
|
10
|
-
import SinglePre from './SinglePre';
|
|
11
|
-
import PreViewContainer from './PreViewContainer';
|
|
12
|
-
|
|
13
|
-
export { PreView, SinglePre, PreViewContainer };
|
|
1
|
+
export { SinglePre } from './SinglePre';
|
|
2
|
+
export { PreView } from './PreView';
|
|
3
|
+
export { PreviewFooter } from './PreviewFooter';
|
|
4
|
+
export { PreViewContainer } from './PreViewContainer';
|
|
@@ -1,230 +1,93 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
import { Image, StyleSheet, Text, TouchableOpacity, View } from 'react-native';
|
|
10
|
-
import React, { useState } from 'react';
|
|
11
|
-
import { CONTROL_BUTTON_SIZE } from '../../utils';
|
|
12
|
-
import type { FlashMode } from '../../utils';
|
|
13
|
-
import { useSafeAreaInsets } from 'react-native-safe-area-context';
|
|
1
|
+
import { StyleSheet, View } from 'react-native';
|
|
2
|
+
import {
|
|
3
|
+
Chip,
|
|
4
|
+
Icon,
|
|
5
|
+
r,
|
|
6
|
+
useColors,
|
|
7
|
+
type IconName,
|
|
8
|
+
} from '@unif/react-native-design';
|
|
14
9
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
const FlashAuto = require('../../assets/tools/auto.png');
|
|
18
|
-
const volumeOff = require('../../assets/tools/volumeOff.png');
|
|
19
|
-
const volumeOn = require('../../assets/tools/volumeOn.png');
|
|
10
|
+
export type FlashMode = 'off' | 'on' | 'auto';
|
|
11
|
+
export type AspectRatio = '4:3' | '16:9';
|
|
20
12
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
13
|
+
type Props = {
|
|
14
|
+
flash: FlashMode;
|
|
15
|
+
aspectRatio: AspectRatio;
|
|
16
|
+
onChangeFlash: (m: FlashMode) => void;
|
|
17
|
+
onChangeAspectRatio: (r: AspectRatio) => void;
|
|
18
|
+
onToggleLens: () => void;
|
|
19
|
+
lensLabel: string;
|
|
20
|
+
};
|
|
28
21
|
|
|
29
|
-
const
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
onFishEyeOpen: (val: 'default' | 'fishEye') => void;
|
|
36
|
-
}> = ({
|
|
37
|
-
isMultiCam,
|
|
38
|
-
onChange,
|
|
39
|
-
onAspectRationChange,
|
|
40
|
-
onScreenChange,
|
|
41
|
-
onVolumeChange,
|
|
42
|
-
onFishEyeOpen,
|
|
43
|
-
}) => {
|
|
44
|
-
const [flashImage, setFlashImage] = useState(FlashOff);
|
|
45
|
-
const [volumeImage, setVolumeImage] = useState(volumeOff);
|
|
46
|
-
const [flashOpen, setFlashOpen] = useState(false);
|
|
47
|
-
const [screenImage, setScreenImage] = useState(narrow);
|
|
48
|
-
const [fishEyeOpen, setFishEyeOpen] = useState(false);
|
|
49
|
-
const [fishEyeImage, setFishEyeImage] = useState(defaultEyeImage);
|
|
50
|
-
const [openHeader, setOpenHeader] = useState(true);
|
|
51
|
-
const insets = useSafeAreaInsets();
|
|
22
|
+
const flashLabel: Record<FlashMode, string> = {
|
|
23
|
+
off: '闪关',
|
|
24
|
+
on: '闪开',
|
|
25
|
+
auto: '自动',
|
|
26
|
+
};
|
|
27
|
+
const flashOrder: FlashMode[] = ['off', 'auto', 'on'];
|
|
52
28
|
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
break;
|
|
59
|
-
case 'auto':
|
|
60
|
-
setFlashImage(FlashAuto);
|
|
61
|
-
break;
|
|
62
|
-
default:
|
|
63
|
-
setFlashImage(FlashOff);
|
|
64
|
-
break;
|
|
65
|
-
}
|
|
66
|
-
onChange(type);
|
|
67
|
-
setFlashOpen(false);
|
|
68
|
-
setOpenHeader(true);
|
|
69
|
-
};
|
|
29
|
+
const flashIconMap: Record<FlashMode, IconName> = {
|
|
30
|
+
off: 'flash-off',
|
|
31
|
+
on: 'flash-on',
|
|
32
|
+
auto: 'flash-auto',
|
|
33
|
+
};
|
|
70
34
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
35
|
+
export function SetUp({
|
|
36
|
+
flash,
|
|
37
|
+
aspectRatio,
|
|
38
|
+
onChangeFlash,
|
|
39
|
+
onChangeAspectRatio,
|
|
40
|
+
onToggleLens,
|
|
41
|
+
lensLabel,
|
|
42
|
+
}: Props) {
|
|
43
|
+
const c = useColors();
|
|
44
|
+
const nextFlash = () => {
|
|
45
|
+
const i = flashOrder.indexOf(flash);
|
|
46
|
+
const next = flashOrder[(i + 1) % flashOrder.length] as FlashMode;
|
|
47
|
+
onChangeFlash(next);
|
|
77
48
|
};
|
|
78
|
-
|
|
79
49
|
return (
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
<Text onPress={() => falshChange('off')} style={styles.toolText}>
|
|
112
|
-
关闭
|
|
113
|
-
</Text>
|
|
114
|
-
</View>
|
|
115
|
-
)}
|
|
116
|
-
</View>
|
|
117
|
-
|
|
118
|
-
<View style={styles.tool}>
|
|
119
|
-
<TouchableOpacity
|
|
120
|
-
style={styles.toolImg}
|
|
121
|
-
onPress={() => {
|
|
122
|
-
if (volume) {
|
|
123
|
-
setVolumeImage(volumeOff);
|
|
124
|
-
} else {
|
|
125
|
-
setVolumeImage(volumeOn);
|
|
126
|
-
}
|
|
127
|
-
volume = !volume;
|
|
128
|
-
onVolumeChange(volume);
|
|
129
|
-
}}
|
|
130
|
-
>
|
|
131
|
-
<Image source={volumeImage} style={styles.toolImg} />
|
|
132
|
-
</TouchableOpacity>
|
|
133
|
-
</View>
|
|
134
|
-
|
|
135
|
-
<View style={styles.tool}>
|
|
136
|
-
<TouchableOpacity
|
|
137
|
-
style={styles.toolImg}
|
|
138
|
-
onPress={() => {
|
|
139
|
-
if (screen) {
|
|
140
|
-
setScreenImage(enlarge);
|
|
141
|
-
} else {
|
|
142
|
-
setScreenImage(narrow);
|
|
143
|
-
}
|
|
144
|
-
onScreenChange(screen ? 'contain' : 'cover');
|
|
145
|
-
onAspectRationChange(screen ? 4 : 16);
|
|
146
|
-
screen = !screen;
|
|
147
|
-
}}
|
|
148
|
-
>
|
|
149
|
-
<Image source={screenImage} style={styles.toolImg} />
|
|
150
|
-
</TouchableOpacity>
|
|
151
|
-
</View>
|
|
152
|
-
|
|
153
|
-
{isMultiCam && (
|
|
154
|
-
<View style={styles.tool}>
|
|
155
|
-
<TouchableOpacity
|
|
156
|
-
style={styles.toolImg}
|
|
157
|
-
onPress={() => {
|
|
158
|
-
setOpenHeader(false);
|
|
159
|
-
setFishEyeOpen((val) => !val);
|
|
160
|
-
}}
|
|
161
|
-
>
|
|
162
|
-
<Image source={fishEyeImage} style={styles.toolImg} />
|
|
163
|
-
</TouchableOpacity>
|
|
164
|
-
{fishEyeOpen && (
|
|
165
|
-
<View style={styles.toolSetting}>
|
|
166
|
-
<Text
|
|
167
|
-
onPress={() => fishEyeChange('default')}
|
|
168
|
-
style={styles.toolText}
|
|
169
|
-
>
|
|
170
|
-
默认
|
|
171
|
-
</Text>
|
|
172
|
-
<Text
|
|
173
|
-
onPress={() => fishEyeChange('fishEye')}
|
|
174
|
-
style={styles.toolText}
|
|
175
|
-
>
|
|
176
|
-
广角
|
|
177
|
-
</Text>
|
|
178
|
-
</View>
|
|
179
|
-
)}
|
|
180
|
-
</View>
|
|
181
|
-
)}
|
|
182
|
-
</View>
|
|
183
|
-
</>
|
|
50
|
+
<View style={styles.root}>
|
|
51
|
+
<Chip
|
|
52
|
+
label={flashLabel[flash]}
|
|
53
|
+
leading={
|
|
54
|
+
<Icon name={flashIconMap[flash]} size={r(14)} color={c.foreground} />
|
|
55
|
+
}
|
|
56
|
+
onPress={nextFlash}
|
|
57
|
+
selected={flash !== 'off'}
|
|
58
|
+
testID="flash-btn"
|
|
59
|
+
/>
|
|
60
|
+
<Chip
|
|
61
|
+
label={aspectRatio}
|
|
62
|
+
leading={
|
|
63
|
+
<Icon
|
|
64
|
+
name={aspectRatio === '4:3' ? 'aspect-4-3' : 'aspect-16-9'}
|
|
65
|
+
size={r(14)}
|
|
66
|
+
color={c.foreground}
|
|
67
|
+
/>
|
|
68
|
+
}
|
|
69
|
+
onPress={() =>
|
|
70
|
+
onChangeAspectRatio(aspectRatio === '4:3' ? '16:9' : '4:3')
|
|
71
|
+
}
|
|
72
|
+
testID="aspect-btn"
|
|
73
|
+
/>
|
|
74
|
+
<Chip
|
|
75
|
+
label={lensLabel}
|
|
76
|
+
leading={<Icon name="lens-flip" size={r(14)} color={c.foreground} />}
|
|
77
|
+
onPress={onToggleLens}
|
|
78
|
+
testID="lens-btn"
|
|
79
|
+
/>
|
|
80
|
+
</View>
|
|
184
81
|
);
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
export default SetUp;
|
|
82
|
+
}
|
|
188
83
|
|
|
189
84
|
const styles = StyleSheet.create({
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
zIndex: 9,
|
|
196
|
-
},
|
|
197
|
-
header: {
|
|
198
|
-
display: 'flex',
|
|
199
|
-
alignItems: 'center',
|
|
200
|
-
},
|
|
201
|
-
tools: {
|
|
202
|
-
display: 'flex',
|
|
203
|
-
width: '100%',
|
|
204
|
-
},
|
|
205
|
-
tool: {
|
|
206
|
-
display: 'flex',
|
|
207
|
-
flexDirection: 'row',
|
|
208
|
-
width: '100%',
|
|
209
|
-
height: CONTROL_BUTTON_SIZE / 2,
|
|
210
|
-
alignItems: 'center',
|
|
211
|
-
marginBottom: 8,
|
|
212
|
-
},
|
|
213
|
-
toolImg: {
|
|
214
|
-
width: CONTROL_BUTTON_SIZE / 2,
|
|
215
|
-
height: '100%',
|
|
216
|
-
},
|
|
217
|
-
toolSetting: {
|
|
218
|
-
display: 'flex',
|
|
219
|
-
flexDirection: 'row',
|
|
220
|
-
},
|
|
221
|
-
toolText: {
|
|
222
|
-
marginLeft: 8,
|
|
223
|
-
fontWeight: '900',
|
|
224
|
-
color: '#fff',
|
|
225
|
-
},
|
|
226
|
-
headerLeft: {
|
|
227
|
-
display: 'flex',
|
|
85
|
+
root: {
|
|
86
|
+
position: 'absolute',
|
|
87
|
+
top: r(60),
|
|
88
|
+
left: r(16),
|
|
89
|
+
right: r(16),
|
|
228
90
|
flexDirection: 'row',
|
|
91
|
+
justifyContent: 'space-between',
|
|
229
92
|
},
|
|
230
93
|
});
|
|
@@ -1,49 +1,29 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
* @PageName:
|
|
8
|
-
*/
|
|
9
|
-
import React from 'react';
|
|
10
|
-
import Carousel, {
|
|
11
|
-
type ICarouselInstance,
|
|
12
|
-
} from 'react-native-reanimated-carousel';
|
|
13
|
-
import { useSharedValue } from 'react-native-reanimated';
|
|
14
|
-
import {
|
|
15
|
-
pxToDpHeight,
|
|
16
|
-
pxToDpWidth,
|
|
17
|
-
renderItem,
|
|
18
|
-
type CustomPhotoFile,
|
|
19
|
-
} from '../../utils';
|
|
20
|
-
const CustomCarousel: React.FC<{
|
|
1
|
+
import { StyleSheet, useWindowDimensions, View } from 'react-native';
|
|
2
|
+
import RNCarousel from 'react-native-reanimated-carousel';
|
|
3
|
+
import type { CustomPhotoFile } from '../../utils';
|
|
4
|
+
import { SlideItem } from './SlideItem';
|
|
5
|
+
|
|
6
|
+
type Props = {
|
|
21
7
|
data: CustomPhotoFile[];
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
}> = ({ data, onSnapToItem, ref }) => {
|
|
25
|
-
const scrollOffsetValue = useSharedValue<number>(0);
|
|
8
|
+
onIndexChange?: (i: number) => void;
|
|
9
|
+
};
|
|
26
10
|
|
|
11
|
+
export function Carousel({ data, onIndexChange }: Props) {
|
|
12
|
+
const { width, height } = useWindowDimensions();
|
|
27
13
|
return (
|
|
28
|
-
|
|
29
|
-
<
|
|
30
|
-
ref={ref}
|
|
31
|
-
width={pxToDpWidth(679)}
|
|
32
|
-
height={pxToDpHeight(857)}
|
|
33
|
-
snapEnabled={true}
|
|
34
|
-
pagingEnabled={true}
|
|
14
|
+
<View style={styles.root}>
|
|
15
|
+
<RNCarousel
|
|
35
16
|
data={data}
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
}}
|
|
42
|
-
onSnapToItem={onSnapToItem}
|
|
43
|
-
renderItem={renderItem({ rounded: true, totalIndex: data.length })}
|
|
17
|
+
width={width}
|
|
18
|
+
height={height}
|
|
19
|
+
loop={false}
|
|
20
|
+
onSnapToItem={onIndexChange}
|
|
21
|
+
renderItem={({ item }) => <SlideItem file={item} />}
|
|
44
22
|
/>
|
|
45
|
-
|
|
23
|
+
</View>
|
|
46
24
|
);
|
|
47
|
-
}
|
|
25
|
+
}
|
|
48
26
|
|
|
49
|
-
|
|
27
|
+
const styles = StyleSheet.create({
|
|
28
|
+
root: { flex: 1 },
|
|
29
|
+
});
|
|
@@ -1,95 +1,20 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
* @Date: 2024-12-17 15:50:46
|
|
4
|
-
* @LastEditors: 刘利军
|
|
5
|
-
* @LastEditTime: 2024-12-20 14:22:58
|
|
6
|
-
* @Description:
|
|
7
|
-
* @PageName:
|
|
8
|
-
*/
|
|
9
|
-
import React, { useMemo } from 'react';
|
|
10
|
-
import {
|
|
11
|
-
type ImageSourcePropType,
|
|
12
|
-
type ImageStyle,
|
|
13
|
-
type StyleProp,
|
|
14
|
-
StyleSheet,
|
|
15
|
-
Text,
|
|
16
|
-
View,
|
|
17
|
-
type ViewProps,
|
|
18
|
-
} from 'react-native';
|
|
19
|
-
import type { AnimatedProps } from 'react-native-reanimated';
|
|
20
|
-
import Animated from 'react-native-reanimated';
|
|
21
|
-
import { pxToDpWidth } from '../../utils';
|
|
1
|
+
import { Image, StyleSheet, View } from 'react-native';
|
|
2
|
+
import type { CustomPhotoFile } from '../../utils';
|
|
22
3
|
|
|
23
|
-
|
|
24
|
-
style?: StyleProp<ImageStyle>;
|
|
25
|
-
index?: number;
|
|
26
|
-
totalIndex?: number;
|
|
27
|
-
rounded?: boolean;
|
|
28
|
-
source?: ImageSourcePropType;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
export const SlideItem: React.FC<Props> = (props) => {
|
|
32
|
-
const {
|
|
33
|
-
style,
|
|
34
|
-
index = 0,
|
|
35
|
-
totalIndex = 0,
|
|
36
|
-
rounded = false,
|
|
37
|
-
...animatedViewProps
|
|
38
|
-
} = props;
|
|
39
|
-
const source = useMemo(() => props.source, [props.source]);
|
|
4
|
+
export function SlideItem({ file }: { file: CustomPhotoFile }) {
|
|
40
5
|
return (
|
|
41
|
-
<
|
|
42
|
-
<
|
|
43
|
-
|
|
44
|
-
|
|
6
|
+
<View style={styles.root}>
|
|
7
|
+
<Image
|
|
8
|
+
source={{ uri: file.uri }}
|
|
9
|
+
style={StyleSheet.absoluteFill}
|
|
45
10
|
resizeMode="contain"
|
|
46
11
|
/>
|
|
47
|
-
|
|
48
|
-
<View style={styles.overlayTextContainer}>
|
|
49
|
-
<Text style={styles.overlayText}>
|
|
50
|
-
第{index + 1}/{totalIndex}笔
|
|
51
|
-
</Text>
|
|
52
|
-
</View>
|
|
53
|
-
</View>
|
|
54
|
-
</Animated.View>
|
|
12
|
+
</View>
|
|
55
13
|
);
|
|
56
|
-
}
|
|
14
|
+
}
|
|
57
15
|
|
|
58
16
|
const styles = StyleSheet.create({
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
backgroundColor: 'rgba(255,255,255,0.2)',
|
|
63
|
-
borderRadius: pxToDpWidth(10),
|
|
64
|
-
},
|
|
65
|
-
borderRadius: {
|
|
66
|
-
borderRadius: pxToDpWidth(10),
|
|
67
|
-
},
|
|
68
|
-
container: {
|
|
69
|
-
width: '100%',
|
|
70
|
-
height: '100%',
|
|
71
|
-
},
|
|
72
|
-
overlay: {
|
|
73
|
-
position: 'absolute',
|
|
74
|
-
bottom: -pxToDpWidth(20),
|
|
75
|
-
left: 0,
|
|
76
|
-
right: 0,
|
|
77
|
-
justifyContent: 'center',
|
|
78
|
-
alignItems: 'center',
|
|
79
|
-
},
|
|
80
|
-
overlayText: {
|
|
81
|
-
color: '#fff',
|
|
82
|
-
fontSize: 14,
|
|
83
|
-
fontWeight: 'bold',
|
|
84
|
-
letterSpacing: 2,
|
|
85
|
-
},
|
|
86
|
-
overlayTextContainer: {
|
|
87
|
-
backgroundColor: '#E96C00',
|
|
88
|
-
paddingHorizontal: 15,
|
|
89
|
-
paddingVertical: 5,
|
|
90
|
-
minWidth: 80,
|
|
91
|
-
justifyContent: 'center',
|
|
92
|
-
alignItems: 'center',
|
|
93
|
-
borderRadius: pxToDpWidth(25),
|
|
94
|
-
},
|
|
17
|
+
// 相机 slide 固定黑底:与 SinglePre / PreView 一致,
|
|
18
|
+
// 让照片在纯黑上凸显的 UX 惯例,不走 c.background token.
|
|
19
|
+
root: { flex: 1, backgroundColor: '#000' },
|
|
95
20
|
});
|
|
@@ -1,13 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
* @Date: 2024-12-17 16:01:04
|
|
4
|
-
* @LastEditors: 刘利军
|
|
5
|
-
* @LastEditTime: 2024-12-17 16:07:53
|
|
6
|
-
* @Description:
|
|
7
|
-
* @PageName:
|
|
8
|
-
*/
|
|
9
|
-
import MyCarousel from './Carousel';
|
|
10
|
-
|
|
11
|
-
import { SlideItem } from './SlideItem';
|
|
12
|
-
|
|
13
|
-
export { MyCarousel, SlideItem };
|
|
1
|
+
export { Carousel } from './Carousel';
|
|
2
|
+
export { SlideItem } from './SlideItem';
|