require(["esri/portal/PortalItem"], function(PortalItem) { /* code goes here */ });
Class: esri/portal/PortalItem
Inheritance: PortalItem Accessor
Since: ArcGIS API for JavaScript 4.0

An item (a unit of content) in the Portal. Each item has a unique identifier and a well known URL that is independent of the user owning the item. An item may have associated binary or textual data which is available via the item data resource. View the ArcGIS portal API REST documentation for the item for more details.

See also:

Constructors

new PortalItem(properties)
Parameter:
properties Object
optional

See the properties for a list of all the properties that may be passed into the constructor.

Example:
// Typical usage
var item = new PortalItem({
  id: "affa021c51944b5694132b2d61fe1057"
});
item.load();

Property Overview

Any properties can be set, retrieved or listened to. See the Working with Properties topic.
NameTypeSummaryClass
String

Indicates the level of access to this item: private, shared, org, or public.

more details
more detailsPortalItem
String

Information on the source of the item and its copyright status.

more details
more detailsPortalItem
Object[]

Contains an array of objects containing proxy information for premium platform services.

more details
more detailsPortalItem
Number

Average rating.

more details
more detailsPortalItem
String[]

An array of organization categories that are set on the item.

more details
more detailsPortalItem
Date

The date the item was created.

more details
more detailsPortalItem
String

The item's locale information (language and country).

more details
more detailsPortalItem
String

The name of the class.

more details
more detailsAccessor
String

The detailed description of the item.

more details
more detailsPortalItem
Extent

The geographic extent, or bounding rectangle, of the item.

more details
more detailsPortalItem
String[]

An array of group categories set on the item.

more details
more detailsPortalItem
String

The unique id for the item.

more details
more detailsPortalItem
Boolean

Indicates whether a layer can be created from this item using Layer.fromPortalItem().

more details
more detailsPortalItem
String

Indicates whether an item can be updated and deleted.

more details
more detailsPortalItem
String

The URL to the item.

more details
more detailsPortalItem
String

Information on license or restrictions related to the item.

more details
more detailsPortalItem
Boolean

Indicates whether the item's resources have loaded from the portal.

more details
more detailsPortalItem
Error

The Error object returned if an error occurred while loading.

more details
more detailsPortalItem
String

Represents the status of a load operation.

more details
more detailsPortalItem
Object[]

A list of warnings which occurred while loading.

more details
more detailsPortalItem
Date

The date the item was last modified.

more details
more detailsPortalItem
String

The name of the item.

more details
more detailsPortalItem
Number

Number of comments on the item.

more details
more detailsPortalItem
Number

Number of ratings on the item.

more details
more detailsPortalItem
Number

Number of views on the item.

more details
more detailsPortalItem
String

The username of the user who owns this item.

more details
more detailsPortalItem
String

The ID of the folder in which the owner has stored the item.

more details
more detailsPortalItem
Portal

The portal that contains the item.

more details
more detailsPortalItem
String[]

An array of string URLs.

more details
more detailsPortalItem
Number

The size of the item (in bytes).

more details
more detailsPortalItem
String

A summary description of the item.

more details
more detailsPortalItem
Object

The JSON used to create the property values when the PortalItem is loaded.

more details
more detailsPortalItem
String[]

User defined tags that describe the item.

more details
more detailsPortalItem
String

The URL to the thumbnail used for the item.

more details
more detailsPortalItem
String

The title for the item.

more details
more detailsPortalItem
String

The GIS content type of this item.

more details
more detailsPortalItem
String[]

Type keywords that describe the type of content of this item.

more details
more detailsPortalItem
String

The service URL of this item.

more details
more detailsPortalItem

Property Details

access String

Indicates the level of access to this item: private, shared, org, or public.

accessInformation String

Information on the source of the item and its copyright status.

applicationProxies Object[]readonly
Since: ArcGIS API for JavaScript 4.8

Contains an array of objects containing proxy information for premium platform services. This is most widely seen in registered applications that work with premium and subscriber services, e.g. routing and analysis services.

Properties:
sourceUrl String

The URL of the premium map service layer.

proxyUrl String

The proxy URL for the source URL.

proxyId String

The proxy ID registered in ArcGIS Online or ArcGIS Enterprise Portal.

avgRating Number

Average rating. Uses a weighted average called "Bayesian average."

categories String[]
Since: ArcGIS API for JavaScript 4.8

An array of organization categories that are set on the item.

created Date

The date the item was created.

culture String

The item's locale information (language and country).

declaredClass Stringreadonly inherited
Since: ArcGIS API for JavaScript 4.7

The name of the class. The declared class name is formatted as esri.folder.className.

description String

The detailed description of the item.

extent Extent

The geographic extent, or bounding rectangle, of the item.

groupCategories String[]
Since: ArcGIS API for JavaScript 4.8

An array of group categories set on the item. This varies slightly from categories as it only returns categories in the group content returned from PortalGroup.queryItems.

The unique id for the item. You can typically find the id for an item in its url.

Example:
// to access the portal item at this url
// http://www.arcgis.com/home/item.html?id=d7892b3c13b44391992ecd42bfa92d01
var item = new PortalItem({
  id: "d7892b3c13b44391992ecd42bfa92d01"
});
isLayer Booleanreadonly

Indicates whether a layer can be created from this item using Layer.fromPortalItem().

Example:
if (item.isLayer) {
  Layer.fromPortalItem({
    portalItem: item
  }).then(addLayerToMap);
}
itemControl Stringreadonly

Indicates whether an item can be updated and deleted.

Possible ValueDescription
adminThe item can be updated or deleted.
updateThe item can be updated, but not deleted.
nullThe item cannot be updated nor deleted.

Possible Values:"admin"|"update"|"null"

itemUrl Stringreadonly

The URL to the item.

licenseInfo String

Information on license or restrictions related to the item.

loaded Booleanreadonly

Indicates whether the item's resources have loaded from the portal. When true, all the properties of the object can be accessed.

Default Value:false
loadError Errorreadonly

The Error object returned if an error occurred while loading.

Default Value:null
loadStatus Stringreadonly

Represents the status of a load operation.

ValueDescription
not-loadedThe object's resources have not loaded.
loadingThe object's resources are currently loading.
loadedThe object's resources have loaded without errors.
failedThe object's resources failed to load. See loadError for more details.

Possible Values:"not-loaded"|"loading"|"failed"|"loaded"

Default Value:not-loaded
loadWarnings Object[]readonly

A list of warnings which occurred while loading.

modified Date

The date the item was last modified.

name String

The name of the item.

numComments Number

Number of comments on the item.

numRatings Number

Number of ratings on the item.

numViews Number

Number of views on the item.

owner String

The username of the user who owns this item.

ownerFolder String
Since: ArcGIS API for JavaScript 4.12

The ID of the folder in which the owner has stored the item. This is only returned to the item owner or the org administrator.

The portal that contains the item. It uses Portal.getDefault(). This, in turn, obtains the URL from config.portalUrl. It's suggested to use config.portalUrl instead of this property. If needing to work with multiple portal instances, either set the portal's url directly within the PortalItem or create separate portal instances before passing them into the PortalItem.portal property. Both examples are shown below.

Layer.fromPortalItem({
  portalItem: {
    id: "e691172598f04ea8881cd2a4adaa45ba",
    // autocastable to Portal
    portal: {
      url: "https://thePortalUrl"
    }
  }
});

let portalA = new Portal({
  url: "https://www.exampleA.com/arcgis" // First instance
});

let portalB = new Portal({
  url: "https://www.exampleB.com/arcgis" // Second instance
});

let item = new PortalItem({
  id: "e691172598f04ea8881cd2a4adaa45ba",
  portal: portalA // This loads the first portal instance set above
});

item.load();
screenshots String[]
Since: ArcGIS API for JavaScript 4.8

An array of string URLs. These URLs should point to screenshots (i.e. screen captures) associated with an application.

An example value could be something similar to "screenshots/Basic.png".

Default Value:null
size Number

The size of the item (in bytes).

snippet String

A summary description of the item.

sourceJSON Object
Since: ArcGIS API for JavaScript 4.13

The JSON used to create the property values when the PortalItem is loaded. Although most commonly used properties are exposed on the PortalItem class directly, this provides access to all information returned by the portal item. This property is useful if working in an application built using an older version of the API which requires access to a portal's item properties from a more recent version.

See also:

User defined tags that describe the item.

thumbnailUrl Stringreadonly

The URL to the thumbnail used for the item.

See also:
title String

The title for the item. This is the name that is displayed to users and used to refer to the item. Every item must have a title.

type String

The GIS content type of this item. Example types include Web Map, Map Service, Shapefile, and Web Mapping Application. See the ArcGIS REST API Items and Items Types Reference to get an understanding of the item type hierarchy.

Examples:
portalItem.type = "Web Map";
portalItem.type = "Web Mapping Application";
typeKeywords String[]

Type keywords that describe the type of content of this item.

url String

The service URL of this item. Only certain layer item types such as "Feature Service", "Map Service", "Image Service", "Scene Service", "WMS" and "KML" have service URLs.

Method Overview

NameReturn TypeSummaryClass
Promise<PortalRating>

Adds a rating to an accessible item.

more details
more detailsPortalItem

Cancels a load() operation if it is already in progress.

more details
more detailsPortalItem
PortalItem

Creates a clone of this object.

more details
more detailsPortalItem
Promise

Deletes a rating for the specified item.

more details
more detailsPortalItem
Promise

Requests a PortalItem in the format specified in responseType.

more details
more detailsPortalItem
Promise<PortalRating>

Returns the rating (if any) given to the item.

more details
more detailsPortalItem
Promise<PortalItem[]>

Gets all the related items of a certain relationship type for the portal item.

more details
more detailsPortalItem
*

Creates a new instance of this class and initializes it with values from a JSON object generated from a product in the ArcGIS platform.

more details
more detailsPortalItem
String

Get the URL to the thumbnail image for the item.

more details
more detailsPortalItem
Boolean

isFulfilled() may be used to verify if creating an instance of the class is fulfilled (either resolved or rejected).

more details
more detailsPortalItem
Boolean

isRejected() may be used to verify if creating an instance of the class is rejected.

more details
more detailsPortalItem
Boolean

isResolved() may be used to verify if creating an instance of the class is resolved.

more details
more detailsPortalItem
Promise

Loads the resources referenced by this class.

more details
more detailsPortalItem
Object

Converts an instance of this class to its ArcGIS portal JSON representation.

more details
more detailsPortalItem
Promise<PortalItem>

Updates the item's properties to the portal, and optionally its data.

more details
more detailsPortalItem
Promise<PortalItem>

Updates the item's thumbnail on the portal.

more details
more detailsPortalItem
Promise

when() may be leveraged once an instance of the class is created.

more details
more detailsPortalItem

Method Details

addRating(rating){Promise<PortalRating>}

Adds a rating to an accessible item.

Parameter:

Rating to set for the item. Rating must be a number between 1.0 and 5.0.

Returns:
TypeDescription
Promise<PortalRating>When resolved, a PortalRating is returned.
cancelLoad()

Cancels a load() operation if it is already in progress.

clone(){PortalItem}
Since: ArcGIS API for JavaScript 4.12

Creates a clone of this object. It is a deep clone except for the portal property.

Returns:
TypeDescription
PortalItemA clone of the PortalItem instance that invoked this method.
deleteRating(){Promise}

Deletes a rating for the specified item.

Returns:
TypeDescription
PromiseResolved when the rating successfully deletes.
fetchData(responseType, options){Promise}

Requests a PortalItem in the format specified in responseType.

Parameters:
responseType String
optional
Default Value: json

The format of the response.

options Object
optional

An object with the following properties.

Specification:
optional

Signal object that can be used to abort the asynchronous task. The returned promise will be rejected with an Error named AbortError when an abort is signaled. See also AbortController for more information on how to construct a controller that can be used to deliver abort signals.

Returns:
TypeDescription
PromiseWhen resolved, returns the requested data.
fetchRating(options){Promise<PortalRating>}

Returns the rating (if any) given to the item.

Parameters:
options Object
optional

An object with the following properties.

Specification:
optional

Signal object that can be used to abort the asynchronous task. The returned promise will be rejected with an Error named AbortError when an abort is signaled. See also AbortController for more information on how to construct a controller that can be used to deliver abort signals.

Returns:
TypeDescription
Promise<PortalRating>When resolved, a PortalRating is returned.
fetchRelatedItems(params, options){Promise<PortalItem[]>}

Gets all the related items of a certain relationship type for the portal item. An optional direction can be specified if the direction of the relationship is ambiguous. Otherwise, the service will try to infer it.

Parameters:
params Object

See the object specifications table below for the parameters that may be passed as properties in this object.

Specification:
relationshipType String

The type of relationship between the two items. See Relationship types for a complete listing of types.

direction String

The direction of the relationship. Can either be forward (from origin to destination) or reverse (from destination to origin).

Possible Values:"forward"|"reverse"

options Object
optional

An object with the following properties.

Specification:
optional

Signal object that can be used to abort the asynchronous task. The returned promise will be rejected with an Error named AbortError when an abort is signaled. See also AbortController for more information on how to construct a controller that can be used to deliver abort signals.

Returns:
TypeDescription
Promise<PortalItem[]>When resolved, resolves to an array of the related PortalItem.
Example:
var queryParam = {
   relationshipType: "Service2Data"
};

portalItem.fetchRelatedItems(queryParam).then(function(results){
   console.log("related portal item", results);
});
fromJSON(json){*}static

Creates a new instance of this class and initializes it with values from a JSON object generated from a product in the ArcGIS platform. The object passed into the input json parameter often comes from a response to a query operation in the REST API or a toJSON() method from another ArcGIS product. See the Using fromJSON() topic in the Guide for details and examples of when and how to use this function.

Parameter:
json Object

A JSON representation of the instance in the ArcGIS format. See the ArcGIS REST API documentation for examples of the structure of various input JSON objects.

Returns:
TypeDescription
*Returns a new instance of this class.
getThumbnailUrl(width){String}
Since: ArcGIS API for JavaScript 4.4

Get the URL to the thumbnail image for the item.

Available width sizes: 200, 400, 800 and 2400.

Parameter:
width Number
optional

The desired image width.

Returns:
TypeDescription
StringThe URL to the thumbnail image.
isFulfilled(){Boolean}

isFulfilled() may be used to verify if creating an instance of the class is fulfilled (either resolved or rejected). If it is fulfilled, true will be returned.

Returns:
TypeDescription
BooleanIndicates whether creating an instance of the class has been fulfilled (either resolved or rejected).
isRejected(){Boolean}

isRejected() may be used to verify if creating an instance of the class is rejected. If it is rejected, true will be returned.

Returns:
TypeDescription
BooleanIndicates whether creating an instance of the class has been rejected.
isResolved(){Boolean}

isResolved() may be used to verify if creating an instance of the class is resolved. If it is resolved, true will be returned.

Returns:
TypeDescription
BooleanIndicates whether creating an instance of the class has been resolved.
load(signal){Promise}

Loads the resources referenced by this class. This method automatically executes for a View and all of the resources it references in Map if the view is constructed with a map instance.

This method must be called by the developer when accessing a resource that will not be loaded in a View.

It's possible to provide a signal to stop being interested into a Loadable instance load status. When the signal is aborted, the instance does not stop its loading process, only cancelLoad can abort it.

Parameter:
optional

Signal object that can be used to abort the asynchronous task. The returned promise will be rejected with an Error named AbortError when an abort is signaled. See also AbortController for more information on how to construct a controller that can be used to deliver abort signals.

Returns:
TypeDescription
PromiseResolves when the resources have loaded.
toJSON(){Object}

Converts an instance of this class to its ArcGIS portal JSON representation. See the Using fromJSON() topic in the Guide for more information.

Returns:
TypeDescription
ObjectThe ArcGIS portal JSON representation of an instance of this class.
update(params){Promise<PortalItem>}

Updates the item's properties to the portal, and optionally its data.

Parameters:
params Object
optional

See the object specifications table below for the parameters that may be passed as properties in this object.

Specification:

Optional. The component used to stream the data represented by the item to the client.

Returns:
TypeDescription
Promise<PortalItem>Resolves when the portal item's properties have been updated.
updateThumbnail(params){Promise<PortalItem>}
Since: ArcGIS API for JavaScript 4.5

Updates the item's thumbnail on the portal.

Parameters:
Specification:
params Object

See the object specification table below for the parameters that may be passed as properties in this object.

Specification:
thumbnail Blob|String

A URL, Data URI, Blob, or File. The accepted formats are GIF, JPG, and PNG.

filename String
optional

The file name used for the thumbnail in thumbnailUrl.

Returns:
TypeDescription
Promise<PortalItem>Resolves when the portal item's thumbnail has been updated.
when(callback, errback){Promise}
Since: ArcGIS API for JavaScript 4.6

when() may be leveraged once an instance of the class is created. This method takes two input parameters: a callback function and an errback function. The callback executes when the instance of the class loads. The errback executes if the instance of the class fails to load.

Parameters:
callback Function
optional

The function to call when the promise resolves.

errback Function
optional

The function to execute when the promise fails.

Returns:
TypeDescription
PromiseReturns a new promise for the result of callback that may be used to chain additional functions.
Example:
// Although this example uses MapView, any class instance that is a promise may use then() in the same way
var view = new MapView();
view.when(function(){
  // This function will execute once the promise is resolved
}, function(error){
  // This function will execute if the promise is rejected due to an error
});

API Reference search results

NameTypeModule
Loading...