HubTemplate

Class

Hub Template Class - this class encapsulates the standard operations for a "Solution" item despite the Hub team not "owning" this item type. Our primary goal is to allow editing of the item's meta information, manage sharing, etc.

Implements

Extends

Constructors

Constructor Parameters

Parameter Type Default Notes
entity Required IHubTemplate
context Required IArcGISContext

Properties

Property Type Notes
context Protected Inherited IArcGISContext
entity Protected Inherited IHubTemplate
isDestroyed Protected Inherited false
thumbnailCache Protected Inherited null

Accessors

Accessor Type Notes
canDelete Inherited boolean

Can the current user delete the Entity? In order to delete an item, the user must be the owner of the item or a full org_admin in the owner's organization.

canEdit Inherited boolean

Can the current user edit the Entity? In order to edit an item, the user must be the owner of the item or be a member of a shared editing group, to which the item is shared.

id Inherited string

Return the entity id

orgId Inherited string

The orgId of the Entity, if available

owner Inherited string

Return the entity owner

Methods

Method Returns Notes
Promise<HubTemplate>

Create a new HubTemplate, returning a HubTemplate instance. This does not automatically persist the Template into the backing store unless save is set to true

NOTE: we have no immediate plans to allow template creation from the context of the Hub application, but scaffolding this method for potential future implementation. The underlying createTemplate function will throw an error if attempted.

Promise<HubTemplate>

Fetch a HubTemplate from the backing store and return a HubTemplate instance

HubTemplate

Create an HubTemplate instance from an IHubTemplate object

Promise<void>

Delete the Hub Template's backing item and set a flag indicating it's been destroyed

Promise<IHubTemplate>

Transform editor values into a template entity

Promise<IEditorConfig>
Promise<void>

Save the HubTemplate to the backing store

Promise<IHubTemplateEditor>

Transform template entity into an editor object

void

Update the instance's internal entity state

void

** DEPRECATED: please use requestAssociation instead. This will be removed in the next breaking version **

Add an association to this entity

void

Add a policy to the entity

Promise<void>

Hook that subclasses should call to invoke shared post-save behavior

IPermissionAccessResponse

Check if current user has a specific permission, accounting for both system and entity level policies

Promise<void>

Remove the featured image from the item

void

Clear the thumbnail from the item, if one exists. Persisted on next .save() call

Promise<IGroup>

Returns the followers group

IEntityPermissionPolicy[]

Get all policies related to a specific permission

string

Return the full url to the thumbnail, optionally with a width parameter

IAssociationInfo[]

** DEPRECATED: This will be removed in the next breaking version **

Return a list of IAssociationInfo objects representing the associations this entity has, to the specified type

void

** DEPRECATED: please use breakAssociation instead. This will be removed in the next breaking version **

Remove an association from this entity

void

Remove a policy from the entity

Promise<void>

Set the access level of the backing item

Promise<void>

Set a featured image on the Entity, if one already exists it is cleared out before the new one is set to keep the number of resources in control

Promise<void>

Sets the access level of the followers group

Promise<void>

Sets whether or not the followers group is discussable

void

Store thumbnail information to be sent with the next .save() call

Promise<void>

Share the Entity with the specified group id

Promise<void>

Share the Entity with the specified group ids

Promise<IGroup[]>

Return a list of groups the Entity is shared to.

IHubTemplate

Return the backing entity as an object literal

Promise<void>

Unshare the Entity with the specified group id

Promise<void>

Unshare the Entity with the specified group ids

void

Updates the isDiscussable property

create

Static Static Class Method

Create a new HubTemplate, returning a HubTemplate instance. This does not automatically persist the Template into the backing store unless save is set to true

Parameters

Parameter Type Default Notes
partialTemplate Required Partial<IHubTemplate>
context Required IArcGISContext
save Optional boolean false

Returns

Promise<HubTemplate>

NOTE: we have no immediate plans to allow template creation from the context of the Hub application, but scaffolding this method for potential future implementation. The underlying createTemplate function will throw an error if attempted.

fetch

Static Static Class Method

Fetch a HubTemplate from the backing store and return a HubTemplate instance

Parameters

Parameter Type Default Notes
identifier Required string
context Required IArcGISContext

Returns

Promise<HubTemplate>

fromJson

Static Static Class Method

Create an HubTemplate instance from an IHubTemplate object

Parameters

Parameter Type Default Notes
json Required Partial<IHubTemplate>

JSON object to create a HubTemplate from

context Required IArcGISContext

ArcGIS context

Returns

delete

Class Method

Delete the Hub Template's backing item and set a flag indicating it's been destroyed

  • delete() : Promise<void>

Returns

Promise<void>

fromEditor

Class Method

Transform editor values into a template entity

Parameters

Parameter Type Default Notes
editor Required IHubTemplateEditor

Returns

Promise<IHubTemplate>

getEditorConfig

Class Method

Parameters

Parameter Type Default Notes
i18nScope Required string
type Required TemplateEditorType

Returns

Promise<IEditorConfig>

save

Class Method

Save the HubTemplate to the backing store

  • save() : Promise<void>

Returns

Promise<void>

toEditor

Class Method

Transform template entity into an editor object

Parameters

Parameter Type Default Notes
editorContext Optional IEntityEditorContext {}
include Optional string[] []

Returns

update

Class Method

Update the instance's internal entity state

Parameters

Parameter Type Default Notes
changes Required Partial<IHubTemplate>

Returns

void

addAssociation

Class Method

** DEPRECATED: please use requestAssociation instead. This will be removed in the next breaking version **

Parameters

Parameter Type Default Notes
info Required IAssociationInfo

Returns

void

Add an association to this entity

addPermissionPolicy

Class Method

Add a policy to the entity

Parameters

Parameter Type Default Notes
policy Required IEntityPermissionPolicy

Returns

void

afterSave

Class Method

Hook that subclasses should call to invoke shared post-save behavior

  • afterSave() : Promise<void>

Returns

Promise<void>

checkPermission

Class Method

Check if current user has a specific permission, accounting for both system and entity level policies

Parameters

Parameter Type Default Notes
permission Required Permission

Returns

clearFeaturedImage

Class Method

Remove the featured image from the item

  • clearFeaturedImage() : Promise<void>

Returns

Promise<void>

clearThumbnail

Class Method

Clear the thumbnail from the item, if one exists. Persisted on next .save() call

  • clearThumbnail() : void

Returns

void

getFollowersGroup

Class Method

Returns the followers group

  • getFollowersGroup() : Promise<IGroup>

Returns

Promise<IGroup>

getPermissionPolicies

Class Method

Get all policies related to a specific permission

Parameters

Parameter Type Default Notes
permission Required Permission

Returns

getThumbnailUrl

Class Method

Return the full url to the thumbnail, optionally with a width parameter

  • getThumbnailUrl(width: number) : string

Parameters

Parameter Type Default Notes
width Optional number 200

Returns

string

listAssociations

Class Method

** DEPRECATED: This will be removed in the next breaking version **

Parameters

Parameter Type Default Notes
type Required AssociationType

Returns


Return a list of IAssociationInfo objects representing the associations this entity has, to the specified type

removeAssociation

Class Method

** DEPRECATED: please use breakAssociation instead. This will be removed in the next breaking version **

Parameters

Parameter Type Default Notes
info Required IAssociationInfo

Returns

void

Remove an association from this entity

removePermissionPolicy

Class Method

Remove a policy from the entity

  • removePermissionPolicy(permission: Permission, id: string) : void

Parameters

Parameter Type Default Notes
permission Required Permission
id Required string

Returns

void

setAccess

Class Method

Set the access level of the backing item

Parameters

Parameter Type Default Notes
access Required SettableAccessLevel

Returns

Promise<void>

setFeaturedImage

Class Method

Set a featured image on the Entity, if one already exists it is cleared out before the new one is set to keep the number of resources in control

  • setFeaturedImage(file: any, clearExisting: boolean) : Promise<void>

Parameters

Parameter Type Default Notes
file Required any
clearExisting Optional boolean false

Returns

Promise<void>

setFollowersGroupAccess

Class Method

Sets the access level of the followers group

Parameters

Parameter Type Default Notes
access Required SettableAccessLevel

Returns

Promise<void>

setFollowersGroupIsDiscussable

Class Method

Sets whether or not the followers group is discussable

  • setFollowersGroupIsDiscussable(isDiscussable: boolean) : Promise<void>

Parameters

Parameter Type Default Notes
isDiscussable Required boolean

Returns

Promise<void>

setThumbnail

Class Method

Store thumbnail information to be sent with the next .save() call

  • setThumbnail(file: any, filename: string) : void

Parameters

Parameter Type Default Notes
file Required any
filename Required string

Returns

void

shareWithGroup

Class Method

Share the Entity with the specified group id

  • shareWithGroup(groupId: string) : Promise<void>

Parameters

Parameter Type Default Notes
groupId Required string

Returns

Promise<void>

shareWithGroups

Class Method

Share the Entity with the specified group ids

  • shareWithGroups(groupIds: string[]) : Promise<void>

Parameters

Parameter Type Default Notes
groupIds Required string[]

Returns

Promise<void>

sharedWith

Class Method

Return a list of groups the Entity is shared to.

  • sharedWith() : Promise<IGroup[]>

Returns

Promise<IGroup[]>

toJson

Class Method

Return the backing entity as an object literal

Returns

unshareWithGroup

Class Method

Unshare the Entity with the specified group id

  • unshareWithGroup(groupId: string) : Promise<void>

Parameters

Parameter Type Default Notes
groupId Required string

Returns

Promise<void>

unshareWithGroups

Class Method

Unshare the Entity with the specified group ids

  • unshareWithGroups(groupIds: string[]) : Promise<void>

Parameters

Parameter Type Default Notes
groupIds Required string[]

Returns

Promise<void>

updateIsDiscussable

Class Method

Updates the isDiscussable property

  • updateIsDiscussable(isDiscussable: boolean) : void

Parameters

Parameter Type Default Notes
isDiscussable Required boolean

whether to enable or disable discussions

Returns

void

Class defined in common/src/templates/HubTemplate.ts:25