---
modificationDate: May 06, 2026
title: MediaLibrary (next)
description: A library that provides access to the device's media library.
sourceCodeUrl: 'https://github.com/expo/expo/tree/sdk-56/packages/expo-media-library/src/next'
packageName: 'expo-media-library'
iconUrl: '/static/images/packages/expo-media-library.png'
platforms: ['android', 'ios', 'tvos', 'expo-go']
---

<AgentInstructions>

## Submitting Feedback

If this page contains errors, outdated information, or gaps that blocked you from completing a task, report it so the docs can be improved:

curl -X POST https://api.expo.dev/v2/feedback/docs-send -H 'Content-Type: application/json' -d '{"url":"/versions/v56.0.0/sdk/media-library-next/","feedback":"🤖 Agent feedback: <specific, actionable description>"}'

Only submit when you have something specific and actionable to report.

</AgentInstructions>

# Expo MediaLibrary (next)

A library that provides access to the device's media library.
Android, iOS, tvOS, Included in Expo Go

> For the complete documentation index, see [llms.txt](/llms.txt). Use this file to discover all available pages.

`expo-media-library` provides access to the user's media library, allowing apps to read existing images and videos, as well as save new ones.

> On Android, full access to the media library (the main purpose of this package) is allowed only for apps that require broad access to photos. See [details on Google Play's Photo and Video Permissions policy](https://support.google.com/googleplay/android-developer/answer/14115180).

## Installation

```sh
npx expo install expo-media-library
```

If you are installing this in an [existing React Native app](/bare/overview), make sure to [install `expo`](/bare/installing-expo-modules) in your project.

## Usage

Add a new asset from the web

```tsx
import { View, Text } from 'react-native';
import { Image } from 'expo-image';
import { useEffect, useState } from 'react';
import { File, Paths } from 'expo-file-system';
import { Asset, requestPermissionsAsync } from 'expo-media-library/next';

export default function SaveToMediaLibraryExample() {
  const [asset, setAsset] = useState<Asset | null>(null);

  const downloadFile = async () => {
    const url = 'https://picsum.photos/200/300';
    const destinationFile = new File(Paths.cache, 'test_image.jpg');
    if (destinationFile.exists) {
      return destinationFile;
    } else {
      return File.downloadFileAsync(url, destinationFile);
    }
  };

  useEffect(() => {
    const downloadAndSaveAsset = async () => {
      const file = await downloadFile();
      const { status } = await requestPermissionsAsync();
      if (status !== 'granted') {
        return;
      }
      const asset = await Asset.create(file.uri);
      setAsset(asset);
    };

    downloadAndSaveAsset();
  }, []);

  return (
    <View>
      {asset ? (
        <>
          <Text>{asset.id}</Text>
          <Image source={{ uri: asset.id }} style={{ width: 200, height: 300 }} />
        </>
      ) : (
        <Text>Downloading and creating asset...</Text>
      )}
    </View>
  );
}
```
Retrieve asset properties

```tsx
import { View, Text } from 'react-native';
import { useEffect, useState } from 'react';
import { AssetField, MediaType, Query, requestPermissionsAsync } from 'expo-media-library/next';

export default function RetrievingAssetPropertiesExample() {
  const [assetInfo, setAssetInfo] = useState<{
    id: string;
    filename: string;
    mediaType: string;
    width: number;
    height: number;
    creationTime: number | null;
    modificationTime: number | null;
  } | null>(null);

  useEffect(() => {
    const querySomeAsset = async () => {
      const { status } = await requestPermissionsAsync();
      if (status !== 'granted') {
        return;
      }

      const [asset] = await new Query().limit(1).eq(AssetField.MEDIA_TYPE, MediaType.IMAGE).exe();

      if (asset) {
        const filename = await asset.getFilename();
        const mediaType = (await asset.getMediaType()).toString();
        const width = await asset.getWidth();
        const height = await asset.getHeight();
        const creationTime = await asset.getCreationTime();
        const modificationTime = await asset.getModificationTime();
        setAssetInfo({
          id: asset.id,
          filename,
          mediaType,
          width,
          height,
          creationTime,
          modificationTime,
        });
      } else {
        console.log('No assets found in the media library.');
      }
    };

    querySomeAsset();
  }, []);

  return (
    <View>
      {assetInfo ? (
        <View>
          <Text>Asset ID: {assetInfo.id}</Text>
          <Text>Filename: {assetInfo.filename}</Text>
          <Text>Media Type: {assetInfo.mediaType}</Text>
          <Text>
            Dimensions: {assetInfo.width} x {assetInfo.height}
          </Text>
          <Text>
            Creation Time:{' '}
            {assetInfo.creationTime
              ? new Date(assetInfo.creationTime).toLocaleString()
              : 'Unavailable'}
          </Text>
          <Text>
            Modification Time:{' '}
            {assetInfo.modificationTime
              ? new Date(assetInfo.modificationTime).toLocaleString()
              : 'Unavailable'}
          </Text>
        </View>
      ) : (
        <Text>Fetching asset ...</Text>
      )}
    </View>
  );
}
```
Create a new album

```tsx
import { View, Text, FlatList, Image, Button } from 'react-native';
import { useState } from 'react';
import {
  Asset,
  AssetField,
  MediaType,
  Query,
  requestPermissionsAsync,
  Album,
} from 'expo-media-library/next';

export default function CreateAlbumExample() {
  const [assets, setAssets] = useState<Asset[]>([]);
  const [album, setAlbum] = useState<Album | null>(null);
  const [albumTitle, setAlbumTitle] = useState<string>('');

  const createAlbumWithAsset = async () => {
    await requestPermissionsAsync();

    const [asset] = await new Query().limit(1).eq(AssetField.MEDIA_TYPE, MediaType.IMAGE).exe();

    if (!asset) {
      console.log('No assets found in the media library.');
      return;
    }

    const newAlbum = await Album.create('MyNewAlbum', [asset]);

    setAlbum(newAlbum);
    setAlbumTitle(await newAlbum.getTitle());
    const albumAssets = await newAlbum.getAssets();
    setAssets(albumAssets);
  };

  return (
    <View style={{ flex: 1, padding: 20 }}>
      <Button title="Create Album and Add Asset" onPress={createAlbumWithAsset} />

      {assets.length > 0 ? (
        <>
          <Text style={{ marginTop: 20, fontSize: 18, fontWeight: 'bold' }}>
            Assets in {albumTitle}:
          </Text>
          <FlatList
            data={assets}
            keyExtractor={item => item.id}
            renderItem={({ item }) => (
              <View style={{ marginVertical: 10 }}>
                <Image
                  source={{ uri: item.id }}
                  style={{ width: 100, height: 100, borderRadius: 8 }}
                />
              </View>
            )}
          />
        </>
      ) : (
        <Text style={{ marginTop: 20 }}>{album ? 'Album is empty.' : 'No album created yet.'}</Text>
      )}
    </View>
  );
}
```

## API

## Hooks

### `usePermissions(options)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type |
| --- | --- |
| `options`(optional) | PermissionHookOptions<{ granularPermissions: [GranularPermission[]](#granularpermission), writeOnly: boolean }\> |

  

Check or request permissions to access the media library. This uses both `requestPermissionsAsync` and `getPermissionsAsync` to interact with the permissions.

Returns: `[PermissionResponse | null, RequestPermissionMethod<permissionresponse>, GetPermissionMethod]</permissionresponse>`

Example

```ts
const [permissionResponse, requestPermission] = MediaLibrary.usePermissions({
  writeOnly: true,
  granularPermissions: ['photo'],
});
```

## Classes

### `Album`

Supported platforms: Android, iOS, tvOS.

Type: Class extends [Album](#album)

Album Properties

### `id`

Supported platforms: Android, iOS, tvOS.

Type: `string`

Unique identifier of the album. Can be used to re-instantiate an [`Album`](#album) later.

Album Methods

### `add(assets)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `assets` | [Asset](/versions/latest/sdk/asset#asset) | [Asset[]](/versions/latest/sdk/asset#asset) | The [`Asset`](#asset) or list of [`Asset`](#asset) objects to add. |

  

Adds one or more assets to the album.

Returns: `Promise<void>`

A promise that resolves once the assets have been added.

Example

```ts
const asset = await Asset.create("file:///path/to/photo.png");
await album.add(asset);
```

Example

```ts
await album.add([asset1, asset2]);
```

### `create(name, assetsRefs, moveAssets)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `name` | `string` | Name of the new album. |
| `assetsRefs` | string[] | [Asset[]](/versions/latest/sdk/asset#asset) | List of [`Asset`](#asset) objects or file paths (file:///. .) to include. |
| `moveAssets`(optional) | `boolean` | On Android, whether to move assets into the album. Defaults to `true`. |

  

A static function. Creates a new album with a given name and assets. On Android, if assets are provided and `moveAssets` is true, the assets will be moved into the new album. If false or not supported, the assets will be copied.

Returns: `Promise<album>`

A promise resolving to the created [`Album`](#album).

Example

```ts
const album = await Album.create("My Album", [asset]);
console.log(await album.getTitle()); // "My Album"
```

### `delete()`

Supported platforms: Android, iOS, tvOS.

Permanently deletes the album from the device. On Android, it deletes the album and all its assets. On iOS, it deletes the album but keeps the assets in the main library.

Returns: `Promise<void>`

A promise that resolves once the deletion has completed.

Example

```ts
await album.delete();
```

### `delete(albums, deleteAssets)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `albums` | [Album[]](#album) | An array of [`Album`](#album) instances to delete. |
| `deleteAssets`(optional) | `boolean` | On iOS, whether to delete the assets in the albums as well. Defaults to `false`. |

  

A static function. Deletes multiple albums at once. On Android, assets are always deleted along with the album regardless of `deleteAssets`.

Returns: `Promise<void>`

A promise that resolves once the albums have been deleted.

Example

```ts
const album = await Album.create("My Album", [asset]);
await Album.delete([album]);
```

### `get(title)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `title` | `string` | The title of the album to retrieve. |

  

A static function. Retrieves an album by its title.

Returns: `Promise<album>`

A promise resolving to the [`Album`](#album) if found, or `null` if not found.

Example

```ts
const album = await Album.get("Camera");
if (album) {
  console.log(await album.getTitle()); // "Camera"
}
```

### `getAll()`

Supported platforms: Android, iOS, tvOS.

A static function. Retrieves all albums on the device.

Returns: `Promise<album[]>`

A promise resolving to an array of [`Album`](#album) objects.

Example

```ts
const albums = await Album.getAll();
```

### `getAssets()`

Supported platforms: Android, iOS, tvOS.

Retrieves all assets contained in the album.

Returns: `Promise<asset[]>`

A promise resolving to an array of [`Asset`](#asset) objects.

Example

```ts
const assets = await album.getAssets();
console.log(assets.length);
```

### `getTitle()`

Supported platforms: Android, iOS, tvOS.

Gets the display title (name) of the album. Note that album titles are not guaranteed to be unique.

Returns: `Promise<string>`

A promise resolving to the album’s title string.

Example

```ts
const title = await album.getTitle();
console.log(title); // "Camera"
```

### `removeAssets(assets)`

Supported platforms: iOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `assets` | [Asset[]](/versions/latest/sdk/asset#asset) | An array of [`Asset`](#asset) objects to remove from the album. |

  

Removes assets from the album without deleting them from the library. This is supported only on iOS.

On Android, an asset can belong to only one album. To remove it from an album, delete it or add it to another album.

Returns: `Promise<void>`

A promise that resolves once the assets have been removed.

Example

```ts
const assets = await album.getAssets();
await album.removeAssets(assets.slice(0, 2));
```

### `Asset`

Supported platforms: Android, iOS, tvOS.

Type: Class extends [Asset](/versions/latest/sdk/asset#asset)

Asset Properties

### `id`

Supported platforms: Android, iOS, tvOS.

Type: `string`

ID of the asset. Can be used to re-instantiate an [`Asset`](#asset) later. For android it is a contentUri and PHAsset localIdentifier URI for iOS.

Asset Methods

### `create(filePath, album)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `filePath` | `string` | Local filesystem path (for example, `file:///. .`) of the file to import. |
| `album`(optional) | [Album](#album) | Optional [`Album`](#album) instance to place the asset in. |

  

A static function. Creates a new asset from a given file path. Optionally associates the asset with an album. On Android, if not specified, the asset will be placed in the default "Pictures" directory.

Returns: `Promise<asset>`

A promise resolving to the created [`Asset`](#asset).

Example

```ts
const asset = await Asset.create("file:///storage/emulated/0/DCIM/Camera/IMG_20230915_123456.jpg");
console.log(await asset.getFilename()); // "IMG_20230915_123456.jpg"
```

### `delete()`

Supported platforms: Android, iOS, tvOS.

Deletes the asset from the device’s media store.

Returns: `Promise<void>`

A promise that resolves once the deletion has completed.

Example

```ts
await asset.delete();
```

### `delete(assets)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `assets` | [Asset[]](/versions/latest/sdk/asset#asset) | An array of [`Asset`](#asset) instances to delete. |

  

A static function. Deletes multiple assets from the device's media store.

Returns: `Promise<void>`

A promise that resolves once the deletion has completed.

### `getAlbums()`

Supported platforms: Android, iOS, tvOS.

Gets the albums containing this asset. On Android, an asset is typically associated with a single album. On iOS, an asset may belong to multiple albums.

Returns: `Promise<album[]>`

A promise resolving to an array of [`Album`](#album) objects.

Example

```ts
const albums = await asset.getAlbums();
console.log(albums.length);
```

### `getCreationTime()`

Supported platforms: Android, iOS, tvOS.

Gets the creation time of the asset.

Returns: `Promise<number>`

A promise resolving to the UNIX timestamp in milliseconds, or `null` if unavailable.

### `getDuration()`

Supported platforms: Android, iOS, tvOS.

Gets the duration of the asset. Applies only to assets with media type [`MediaType.audio`](#mediatypeaudio) or [`MediaType.video`](#mediatypevideo). For other media types, it returns `null`.

Returns: `Promise<number>`

A promise resolving to the duration in milliseconds, or `null` if not applicable.

### `getExif()`

Supported platforms: Android, iOS, tvOS.

Gets the exif data of the [`MediaType.image`](#mediatypeimage) asset. On Android, this method requires the `ACCESS_MEDIA_LOCATION` permission to access location metadata.

Returns: `Promise<undefined>`

A promise resolving to the exif data object or an empty object if the exif data is unavailable.

### `getFavorite()`

Supported platforms: iOS.

Gets whether the asset is marked as a favorite. On iOS, this checks if the asset is part of the system "Favorites" smart album.

Returns: `Promise<boolean>`

A promise resolving to `true` if the asset is a favorite, or `false` otherwise.

Example

```ts
const isFavorite = await asset.getFavorite();
console.log(isFavorite); // true or false
```

### `getFilename()`

Supported platforms: Android, iOS, tvOS.

Gets the filename of the asset, including its extension.

Returns: `Promise<string>`

A promise resolving to the filename string.

### `getHeight()`

Supported platforms: Android, iOS, tvOS.

Gets the height of the asset in pixels. Only applicable for image and video assets.

Returns: `Promise<number>`

A promise resolving to the height in pixels.

### `getInfo()`

Supported platforms: Android, iOS, tvOS.

Gets detailed information about the asset.

Returns: `Promise<assetinfo>`

A promise resolving to an [`AssetInfo`](#assetinfo)

### `getIsInCloud()`

Supported platforms: iOS.

Gets whether the asset is stored in iCloud and not available locally. This does not trigger a download of the asset.

Returns: `Promise<boolean>`

A promise resolving to `true` if the asset is stored in iCloud and not available locally.

### `getLivePhotoVideoUri()`

Supported platforms: iOS.

Gets the URI of the paired video for a Live Photo asset. The video is extracted to a temporary file.

Returns: `Promise<string>`

A promise resolving to a `file://` URI string, or `null` if the asset is not a Live Photo.

### `getLocation()`

Supported platforms: Android, iOS, tvOS.

Gets the location of the asset. On Android, this method requires the `ACCESS_MEDIA_LOCATION` permission to access location metadata.

Returns: `Promise<location>`

A promise resolving to the [`Location`](#location) object or `null` if the location data is unavailable.

### `getMediaSubtypes()`

Supported platforms: iOS.

Gets the media subtypes of the asset, describing specific variations such as Live Photo, panorama, HDR, etc.

Returns: `Promise<mediasubtype[]>`

A promise resolving to an array of [`MediaSubtype`](#mediasubtype) strings. Returns an empty array if no subtypes apply.

### `getMediaType()`

Supported platforms: Android, iOS, tvOS.

Gets the media type of the asset (image, video, audio or unknown).

Returns: `Promise<mediatype>`

A promise resolving to a [`MediaType`](#mediatype) enum value.

### `getModificationTime()`

Supported platforms: Android, iOS, tvOS.

Gets the last modification time of the asset.

Returns: `Promise<number>`

A promise resolving to the UNIX timestamp in milliseconds, or `null` if unavailable.

### `getOrientation()`

Supported platforms: iOS.

Gets the EXIF display orientation of the asset. Only applicable for assets with media type [`MediaType.image`](#mediatypeimage).

Returns: `Promise<number>`

A promise resolving to a value between 1 and 8 as defined by the [EXIF orientation specification](http://sylvana.net/jpegcrop/exif_orientation.html), or `null` if unavailable.

### `getShape()`

Supported platforms: Android, iOS, tvOS.

Gets the shape (width and height) of the asset.

Returns: `Promise<shape>`

A promise resolving to the [`Shape`](#shape) object, or `null` if any dimension is unavailable.

### `getUri()`

Supported platforms: Android, iOS, tvOS.

Gets the URI pointing to the asset’s location in the system. Example, for Android: `file:///storage/emulated/0/DCIM/Camera/IMG_20230915_123456.jpg`.

Returns: `Promise<string>`

A promise resolving to the string URI.

### `getWidth()`

Supported platforms: Android, iOS, tvOS.

Gets the width of the asset in pixels. Only applicable for image and video assets.

Returns: `Promise<number>`

A promise resolving to the width in pixels.

### `setFavorite(isFavorite)`

Supported platforms: iOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `isFavorite` | `boolean` | Whether the asset should be marked as favorite. |

  

Marks or unmarks the asset as a favorite. On iOS, this adds or removes the asset from the system "Favorites" smart album.

Returns: `Promise<void>`

A promise that resolves once the operation has completed.

Example

```ts
await asset.setFavorite(true);
```

### `Query`

Supported platforms: Android, iOS, tvOS.

Type: Class extends [Query](#query)

Query Methods

### `album(album)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `album` | [Album](#album) | The album to filter assets by. |

  

Filters assets to only those contained in the specified album.

Returns: `Query`

The updated query object for chaining.

### `eq(field, value)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `field` | `T` | an [`AssetField`](#assetfield) to filter by. |
| `value` | `AssetFieldValueMap[T]` | The value that the field should equal. Each field has a specific unique type. |

  

Filters assets where the specified field is equal to the given value.

Returns: `Query`

The updated query object for chaining.

### `exe()`

Supported platforms: Android, iOS, tvOS.

Executes the query and retrieves the matching assets.

Returns: `Promise<asset[]>`

A promise that resolves to an array of [`Asset`](#asset) objects that match the query criteria.

Example

```ts
const assets = await new Query()
 .eq(AssetField.MEDIA_TYPE, MediaType.IMAGE)
 .lte(AssetField.HEIGHT, 1080)
 .orderBy(AssetField.CREATION_TIME)
 .limit(20)
 .exe();
```

### `gt(field, value)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `field` | [AssetField](#assetfield) | an [`AssetField`](#assetfield) to filter by. |
| `value` | `number` | The value that the field should be greater than. |

  

Filters assets where the specified field is greater than the given value.

Returns: `Query`

The updated query object for chaining.

### `gte(field, value)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `field` | [AssetField](#assetfield) | an [`AssetField`](#assetfield) to filter by. |
| `value` | `number` | The value that the field should be greater than or equal to. |

  

Filters assets where the specified field is greater than or equal to the given value.

Returns: `Query`

### `limit(limit)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `limit` | `number` | The maximum number of results to return. |

  

Limits the number of results returned by the query.

Returns: `Query`

The updated query object for chaining.

### `lt(field, value)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `field` | [AssetField](#assetfield) | an [`AssetField`](#assetfield) to filter by. |
| `value` | `number` | The value that the field should be less than. |

  

Filters assets where the specified field is less than the given value.

Returns: `Query`

The updated query object for chaining.

### `lte(field, value)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `field` | [AssetField](#assetfield) | an [`AssetField`](#assetfield) to filter by. |
| `value` | `number` | The value that the field should be less than or equal to. |

  

Filters assets where the specified field is less than or equal to the given value.

Returns: `Query`

The updated query object for chaining.

### `offset(offset)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `offset` | `number` | The number of results to skip. |

  

Skips the specified number of results.

Returns: `Query`

The updated query object for chaining.

### `orderBy(sortDescriptors)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `sortDescriptors` | [AssetField](#assetfield) | [SortDescriptor](#sortdescriptor) | An instance of SortDescriptor or an AssetField. If an AssetField is provided, the sorting will be done in ascending order by default. |

  

Orders the results by the specified sort descriptor or asset field.

Returns: `Query`

### `within(field, value)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `field` | `T` | an [`AssetField`](#assetfield) to filter by. |
| `value` | `undefined` | An array of values that the field should match. Each field has a specific unique type. |

  

Filters assets where the specified field's value is in the given array of values.

Returns: `Query`

The updated query object for chaining.

## Methods

### `MediaLibrary (next).getPermissionsAsync(writeOnly, granularPermissions)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `writeOnly`(optional) | `boolean` | Whether to check write-only access without read permissions. Defaults to `false`. Default: `false` |
| `granularPermissions`(optional) | [GranularPermission[]](#granularpermission) | A list of [`GranularPermission`](#granularpermission) values. This parameter has an effect only on Android 13 and newer. By default, `expo-media-library` will ask for all possible permissions. |

  

Checks user's permissions for accessing media library.

Returns: `Promise<permissionresponse>`

A promise that fulfils with [`PermissionResponse`](#permissionresponse) object.

### `MediaLibrary (next).presentPermissionsPicker(mediaTypes)`

Supported platforms: Android 14+, iOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `mediaTypes`(optional) | [MediaTypeFilter[]](#mediatypefilter) | Limits the type(s) of media that the user will be granting access to. By default, a list that shows both photos and videos is presented. |

  

Allows the user to update the assets that your app has access to. The system modal is only displayed if the user originally allowed only `limited` access to their media library, otherwise this method is a no-op.

Returns: `Promise<void>`

A promise that either rejects if the method is unavailable, or resolves to `void`.

> **Note:** This method doesn't inform you if the user changes which assets your app has access to. That information is only exposed by iOS, and to obtain it, you need to subscribe for updates to the user's media library using [`addListener()`](#medialibraryaddlistenerlistener). If `hasIncrementalChanges` is `false`, the user changed their permissions.

### `MediaLibrary (next).requestPermissionsAsync(writeOnly, granularPermissions)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `writeOnly`(optional) | `boolean` | Whether to request write-only access without read permissions. Defaults to `false`. Default: `false` |
| `granularPermissions`(optional) | [GranularPermission[]](#granularpermission) | A list of [`GranularPermission`](#granularpermission) values. This parameter has an effect only on Android 13 and newer. By default, `expo-media-library` will ask for all possible permissions. When using granular permissions with a custom config plugin configuration, make sure that all the requested permissions are included in the plugin. |

  

Asks the user to grant permissions for accessing media in user's media library.

Returns: `Promise<permissionresponse>`

A promise that fulfils with [`PermissionResponse`](#permissionresponse) object.

## Event Subscriptions

### `MediaLibrary (next).addListener(listener)`

Supported platforms: Android, iOS, tvOS.

| Parameter | Type | Description |
| --- | --- | --- |
| `listener` | (event: [MediaLibraryAssetsChangeEvent](#medialibraryassetschangeevent)) => void | A callback that is fired when any assets have been inserted or deleted from the library. On Android it's invoked with an empty object. On iOS it's invoked with [`MediaLibraryAssetsChangeEvent`](#medialibraryassetschangeevent) object. |

  

Subscribes for updates in user's media library.

Returns: `EventSubscription`

An [`EventSubscription`](#eventsubscription) object that you can call `remove()` on when you would like to unsubscribe the listener.

### `MediaLibrary (next).removeAllListeners()`

Supported platforms: Android, iOS, tvOS.

Removes all listeners.

Returns: `void`

## Types

### `AssetFieldValueMap`

Supported platforms: Android, iOS, tvOS.

| Property | Type | Description |
| --- | --- | --- |
| creationTime | `number` | - |
| duration | `number` | - |
| height | `number` | - |
| mediaType | [MediaType](#mediatype) | - |
| modificationTime | `number` | - |
| width | `number` | - |

### `AssetInfo`

Supported platforms: Android, iOS, tvOS.

| Property | Type | Description |
| --- | --- | --- |
| creationTime | `number | null` | - |
| duration | `number | null` | - |
| filename | `string` | - |
| height | `number` | - |
| id | `string` | - |
| isFavorite(optional) | `boolean` | - |
| mediaType | [MediaType](#mediatype) | - |
| modificationTime | `number | null` | - |
| uri | `string` | - |
| width | `number` | - |

### `GranularPermission`

Supported platforms: Android, iOS, tvOS.

Literal Type: `string`

Acceptable values are: `'audio'` | `'photo'` | `'video'`

### `MediaLibraryAssetsChangeEvent`

Supported platforms: Android, iOS, tvOS.

An event emitted when assets in the media library change.

| Property | Type | Description |
| --- | --- | --- |
| deletedAssets(optional) | `string[]` | Supported platforms: iOS. Array of asset IDs (`ph://` URIs) that have been deleted from the library. Only populated when `hasIncrementalChanges` is `true`. |
| hasIncrementalChanges | `boolean` | Whether the media library's changes can be described as incremental changes. `true` indicates the changes are described by the `insertedAssets`, `deletedAssets` and `updatedAssets` values. `false` indicates that the scope of changes is too large and you should perform a full assets reload. On Android this is always `false` because the platform does not provide incremental change details. |
| insertedAssets(optional) | `string[]` | Supported platforms: iOS. Array of asset IDs (`ph://` URIs) that have been inserted to the library. Only populated when `hasIncrementalChanges` is `true`. |
| updatedAssets(optional) | `string[]` | Supported platforms: iOS. Array of asset IDs (`ph://` URIs) that have been updated. Only populated when `hasIncrementalChanges` is `true`. |

### `MediaTypeFilter`

Supported platforms: Android, iOS, tvOS.

Literal Type: `string`

Acceptable values are: `'photo'` | `'video'`

### `PermissionHookOptions`

Supported platforms: Android, iOS, tvOS.

Literal Type: `union`

Acceptable values are: `PermissionHookBehavior` | `Options`

### `SortDescriptor`

Supported platforms: Android, iOS, tvOS.

| Property | Type | Description |
| --- | --- | --- |
| ascending(optional) | `boolean` | - |
| key | [AssetField](#assetfield) | - |

## Enums

### `AssetField`

Supported platforms: Android, iOS, tvOS.

#### `CREATION_TIME`

`AssetField.CREATION_TIME = "creationTime"`

#### `DURATION`

`AssetField.DURATION = "duration"`

#### `HEIGHT`

`AssetField.HEIGHT = "height"`

#### `MEDIA_TYPE`

`AssetField.MEDIA_TYPE = "mediaType"`

#### `MODIFICATION_TIME`

`AssetField.MODIFICATION_TIME = "modificationTime"`

#### `WIDTH`

`AssetField.WIDTH = "width"`

### `MediaSubtype`

Supported platforms: iOS.

Describes specific variations of asset media. Maps to [`PHAssetMediaSubtype`](https://developer.apple.com/documentation/photokit/phassetmediasubtype).

#### `DEPTH_EFFECT`

`MediaSubtype.DEPTH_EFFECT = "depthEffect"`

#### `HDR`

`MediaSubtype.HDR = "hdr"`

#### `HIGH_FRAME_RATE`

`MediaSubtype.HIGH_FRAME_RATE = "highFrameRate"`

#### `LIVE_PHOTO`

`MediaSubtype.LIVE_PHOTO = "livePhoto"`

#### `PANORAMA`

`MediaSubtype.PANORAMA = "panorama"`

#### `SCREENSHOT`

`MediaSubtype.SCREENSHOT = "screenshot"`

#### `SPATIAL_MEDIA`

`MediaSubtype.SPATIAL_MEDIA = "spatialMedia"`

#### `STREAM`

`MediaSubtype.STREAM = "stream"`

#### `TIME_LAPSE`

`MediaSubtype.TIME_LAPSE = "timelapse"`

#### `VIDEO_CINEMATIC`

`MediaSubtype.VIDEO_CINEMATIC = "videoCinematic"`

### `MediaType`

Supported platforms: Android, iOS, tvOS.

#### `AUDIO`

`MediaType.AUDIO = "audio"`

#### `IMAGE`

`MediaType.IMAGE = "image"`

#### `UNKNOWN`

`MediaType.UNKNOWN = "unknown"`

#### `VIDEO`

`MediaType.VIDEO = "video"`
