Get Started(中文)
A useful media selector module base on native component. It will offer a meida selector in batteries-included way, including picture selection, photo shooting, video selection, album switch, preview and so on. We recommend strongly that u should install reac-native-awesome-navigation as navigation component in project when using this lib.
Using yarn
yarn add react-native-awesome-medialib
or using npm
npm install react-native-awesome-medialib
U need install all of following libraries:
(1) react-native-awesome-navigation,
(2) react-native-fast-image,
(3) react-native-gesture-handler,
(4) react-native-iphone-x-helper,
(5) react-native-root-toast,
(6) @types/react-native-video and react-native-video.
Ensure your build files match the following requirements:
1. (React Native 0.59 and lower) Define the react-native-awesome-medialib
project in android/settings.gradle:
// settings.gradle
include ':react-native-awesome-medialib'
project(':react-native-awesome-medialib').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-awesome-medialib/android')
2. (React Native 0.59 and lower) Add the react-native-awesome-medialib
as an dependency of your app in android/app/build.gradle:
// app/build.gradle
dependency {
...
implementation project(':react-native-awesome-medialib')
...
}
class MainApplication : Application(), ReactApplication {
private val mReactNativeHost: ReactNativeHost = object : ReactNativeHost(this) {
...
override fun getPackages(): List<ReactPackage> {
val packages: MutableList<ReactPackage> = PackageList(this).packages
packages.add(MediaLibPackage())
return packages
}
}
...
}
Using React Native Link (React Native 0.59 and lower)
Run
react-native link react-native-awesome-medialib
after which you should be able to use this library on iOS.
> u also can use other navigation lib such as `react-navigation`, and register by it. but we recommond use `react-native-awesome-navigation`, because media lib internal page's navigate is used it.
// registing.tsx
import {
MediaSelectorPage,
MediaLibraryPage,
CameraPage,
MediaLibraryPhotoPreviewPage,
PhotoPreviewPage,
VideoPreviewPage,
} from 'react-native-awesome-medialib'
import {Register} from 'react-native-awesome-navigation'
// ...
export const registing = async () => {
Register.beforeRegister()
Register.registerComponent('Your MediaLib enter page name', `Your MediaLib enter page`)
Register.registerComponent('MediaSelectorPage', MediaSelectorPage)
Register.registerComponent('CameraPage', CameraPage)
Register.registerComponent('PhotoPreviewPage', PhotoPreviewPage)
Register.registerComponent('MediaLibraryPage', MediaLibraryPage)
Register.registerComponent('VideoPreviewPage', VideoPreviewPage)
Register.registerComponent('MediaLibraryPhotoPreviewPage', MediaLibraryPhotoPreviewPage)
}
// index.tsx
import {registing} from '...'
registing()
// some place
const onPress() = () => {
// react-native-awesome-navigation (u should refer to their documentation!)
props.navigator.push('MediaSelectorPage')
// react-navigation and others (u should refer to their documentation!)
navigation.push...
}
return (
<>
...
<SomeView onPress={onPress} ...>...</SomeView>
...
</>
)
3. Then, get result by listening event in ur entrance of medialib, and the event value is type of Result
from this library.
// Ur entrance of medialib
useEffect(() => {
const subs = rxEventBus.listen(OnNextStepNotification).subscribe(value => {
// e.g. push this value to new page do something or other operation
props.navigator.push('Your results display page', value)
})
return () => {
subs.unsubscribe()
}
}, [props])
The type of result: ur can get a list of choosen images or a video, whitch is include id(android media strore id,), url(above android 10 is "content:\\...", otherwise absolute path),width, height, type, scale and so on.
// ResultModel.ts
export interface LocalMedia {
id?: number
url: string
width?: number
height?: number
scale?: number
type?: SourceType
}
export enum InvokeType {
main = 'main',
editor = 'editor',
avatar = 'avatar',
}
export enum SourceType {
image = 'image',
video = 'video',
}
export interface Result {
dataList: LocalMedia[]
from?: InvokeType
}
## Contributing
See the contributing guide to learn how to contribute to the repository and the development workflow.
MIT