1 | /**
|
2 | * Copyright (c) Meta Platforms, Inc. and affiliates.
|
3 | *
|
4 | * This source code is licensed under the MIT license found in the
|
5 | * LICENSE file in the root directory of this source tree.
|
6 | *
|
7 | * @format
|
8 | */
|
9 |
|
10 | /*
|
11 | * @see https://github.com/facebook/react-native/blob/master/Libraries/Image/ImageSource.js
|
12 | */
|
13 | export interface ImageURISource {
|
14 | /**
|
15 | * `uri` is a string representing the resource identifier for the image, which
|
16 | * could be an http address, a local file path, or the name of a static image
|
17 | * resource (which should be wrapped in the `require('./path/to/image.png')`
|
18 | * function).
|
19 | */
|
20 | uri?: string | undefined;
|
21 | /**
|
22 | * `bundle` is the iOS asset bundle which the image is included in. This
|
23 | * will default to [NSBundle mainBundle] if not set.
|
24 | * @platform ios
|
25 | */
|
26 | bundle?: string | undefined;
|
27 | /**
|
28 | * `method` is the HTTP Method to use. Defaults to GET if not specified.
|
29 | */
|
30 | method?: string | undefined;
|
31 | /**
|
32 | * `headers` is an object representing the HTTP headers to send along with the
|
33 | * request for a remote image.
|
34 | */
|
35 | headers?: {[key: string]: string} | undefined;
|
36 | /**
|
37 | * `cache` determines how the requests handles potentially cached
|
38 | * responses.
|
39 | *
|
40 | * - `default`: Use the native platforms default strategy. `useProtocolCachePolicy` on iOS.
|
41 | *
|
42 | * - `reload`: The data for the URL will be loaded from the originating source.
|
43 | * No existing cache data should be used to satisfy a URL load request.
|
44 | *
|
45 | * - `force-cache`: The existing cached data will be used to satisfy the request,
|
46 | * regardless of its age or expiration date. If there is no existing data in the cache
|
47 | * corresponding the request, the data is loaded from the originating source.
|
48 | *
|
49 | * - `only-if-cached`: The existing cache data will be used to satisfy a request, regardless of
|
50 | * its age or expiration date. If there is no existing data in the cache corresponding
|
51 | * to a URL load request, no attempt is made to load the data from the originating source,
|
52 | * and the load is considered to have failed.
|
53 | */
|
54 | cache?: 'default' | 'reload' | 'force-cache' | 'only-if-cached' | undefined;
|
55 | /**
|
56 | * `body` is the HTTP body to send with the request. This must be a valid
|
57 | * UTF-8 string, and will be sent exactly as specified, with no
|
58 | * additional encoding (e.g. URL-escaping or base64) applied.
|
59 | */
|
60 | body?: string | undefined;
|
61 | /**
|
62 | * `width` and `height` can be specified if known at build time, in which case
|
63 | * these will be used to set the default `<Image/>` component dimensions.
|
64 | */
|
65 | width?: number | undefined;
|
66 | height?: number | undefined;
|
67 | /**
|
68 | * `scale` is used to indicate the scale factor of the image. Defaults to 1.0 if
|
69 | * unspecified, meaning that one image pixel equates to one display point / DIP.
|
70 | */
|
71 | scale?: number | undefined;
|
72 | }
|
73 |
|
74 | export type ImageRequireSource = number;
|