Skip to content
This repository has been archived by the owner on Jun 20, 2023. It is now read-only.

Latest commit

 

History

History
361 lines (260 loc) · 12.6 KB

README.md

File metadata and controls

361 lines (260 loc) · 12.6 KB

Custom UI extensions SDK

⚠️ This package has been deprecated. Please use @pipedrive/app-extensions-sdk instead.

This SDK provides interactivity between custom UI extensions and Pipedrive.

Learn more about custom UI extensions from Developer documentation.

npm install --save @pipedrive/custom-app-surfaces-sdk

Table of contents

Initialization

In order to display a custom UI extension to a user, this SDK has to be initialized. In the iframe request, query id attribute is passed, which has to be provided to the SDK constructor. The SDK will try to read it from the URL query. If the URL is modified (e.g. with redirects), then it has to be passed manually.

import SurfaceSDK from '@pipedrive/custom-app-surfaces-sdk';

// SDK detects identifier from URL and uses default surface size
const sdk = await new SurfaceSDK().initialize();

// Pass in id manually and provide surface size
const sdk = await new SurfaceSDK({ identifier: '123abc' })
  .initialize({ size: { height: 500 } });

Commands

Commands can be invoked with the execute method. On successful command execution, promise resolves. On error, it rejects.

sdk.execute(/* ... */)
  .then((data) => {
    // handle data
  }).catch((err) => {
    // handle error
  })

try {
  const data = await sdk.execute(/* ... */)
} catch (err) {
  // handle error
}

Show snackbar

Shows snackbar with provided message and link

Parameters

Parameter Type Description Notes
message String Message displayed in snackbar required
link Object Link displayed next to the message optional
link.url string URL for link displayed in snackbar required
link.label string Label for link displayed in snackbar required

Example

await sdk.execute(Command.SHOW_SNACKBAR, {
  message: 'Action completed',
  link: {
    url: 'https://app.pipedrive.com',
    label: 'View'
  },
});

Show confirmation dialog

Shows confirmation dialog with provided title and description

Parameters

Parameter Type Description Notes
title String required
description String Longer description of what is confirmed optional
okText String Confirm button text optional, default is "OK"
cancelText String Cancel button text optional, default is "Cancel"
okColor Color Color of the confirmation button optional, default is Color.NEGATIVE.

Available colors:
Color.PRIMARY (green)
Color.SECONDARY (white)
Color.NEGATIVE (red)

Response

Parameter Type Description Notes
confirmed Boolean Result of confirmation

Example

const { confirmed } = await sdk.execute(Command.SHOW_CONFIRMATION, {
  title: 'Confirm',
  description: 'Are you sure you want to complete this action?'
});

Resize

Resizes custom UI extension with provided height and width

Custom panel - only height can be changed and the value must be between 100px and 750px.

Custom modal - both height and width can be changed. The minimum height is 120px and the minimum width is 320px . The maximum height and width are limited to the user's browser dimensions.

Parameters

Parameter Type Description Notes
height Number Height of the custom panel/modal optional
width Number Width of the custom panel/modal optional

Example

await sdk.execute(Command.RESIZE, { height: 500 });

Get signed token

A new JSON Web Token (JWT) that is valid for 5 minutes will be generated. It can be verified using the JWT secret which you can add from Marketplace Manager when configuring a surface. If it’s not specified, use app’s client secret instead. JWT contains Pipedrive user and company ids.

JWT can be used to assure that the surface is loaded by Pipedrive. It can be passed to your API requests and be verified on the server side. Note that JWT expires in 5 minutes so use this command to get a new one.

Response

Parameter Type Description Notes
token String

Example

const { token } = await sdk.execute(Command.GET_SIGNED_TOKEN);

Open modal

Opens an JSON modal, custom modal or a new Pipedrive Deal, Organization or Person modal

JSON modal action

Parameters for JSON modal

Parameter Type Description Notes
type Modal required
action_id String JSON modal action id or name required

Response

Parameter Type Description Notes
status String Indicates if modal was submitted or closed

Example

const { status } = await sdk.execute(Command.OPEN_MODAL, {
  type: Modal.JSON_MODAL,
  action_id: 'Open settings'
});

Custom modal

Parameters for custom modal

Parameter Type Description Notes
type Modal required
action_id String Custom modal id or name required
data Object Object to be passed as stringified JSON to iframe, should be used with caution taking into account the maximum length of HTTP GET request optional

Response

Parameter Type Description Notes
status String Indicates if modal was submitted or closed

Example

const { status } = await sdk.execute(Command.OPEN_MODAL, {
  type: Modal.CUSTOM_MODAL,
  action_id: 'Open settings',
  data: {
    item: 'xyz'
  }
});

New deal modal

Parameters for new deal modal

Parameter Type Description Notes
type Modal required
prefill Object Object to prefill some deal modal fields optional
prefill.title String Deal title optional
prefill.organization String Organization name to whom the deal belongs optional
prefill.person String Person name to whom the deal belongs optional

Response

Parameter Type Description Notes
status String Indicates if modal was submitted or closed
id Number ID of created deal if it was submitted optional

Example

const { status, id } = await sdk.execute(Command.OPEN_MODAL, {
  type: Modal.DEAL,
  prefill: {
    title: 'Important deal'
  }
});

New person modal

Parameters for new person modal

Parameter Type Description Notes
type Modal required
prefill Object Object to prefill some new person modal fields optional
prefill.name String Person name optional
prefill.organization String Organization name to whom the person belongs optional

Response

Parameter Type Description Notes
status String Indicates if modal was submitted or closed
id Number ID of added person if it was submitted optional

Example

const { status, id } = await sdk.execute(Command.OPEN_MODAL, {
  type: Modal.PERSON,
  prefill: {
    name: 'Some name',
    organization: 'Some organization'
  }
});

New organization modal

Parameters for new organization modal

Parameter Type Description Notes
type Modal required
prefill Object Object to prefill some new organization modal fields optional
prefill.name String Organization name optional

Response

Parameter Type Description Notes
status String Indicates if modal was submitted or closed
id Number ID of added organization if it was submitted optional

Example

const { status, id } = await sdk.execute(Command.OPEN_MODAL, {
  type: Modal.ORGANIZATION,
  prefill: {
    name: 'Some organization',
  }
});

Close modal

Closes an active modal window; applicable only for custom modal.

Example

await sdk.execute(Command.CLOSE_MODAL);

Events

Subscribe to events triggered by user.

const stopReceivingEvents = sdk.listen(event, ({ error, data }) => {
  // if error is present, handle error
  // handle data
});

stopReceivingEvents(); // Call this function to stop receiving events

Custom panel visibility

Subscribe to custom panel visibility changes that are triggered by the user.

Panel surface - user collapses or expands the panel

Response

Parameter Type Description Notes
is_visible Boolean Is surface visible to user

Example

sdk.listen(Event.VISIBILITY, ({ error, data }) => {
  // handle event
});

Close custom modal

Subscribe to custom modal events that are triggered by this SDK's CLOSE_MODAL command or user interaction with the custom modal.

Panel surface - user closes the custom modal

Example

sdk.listen(Event.CLOSE_CUSTOM_MODAL, () => {
  // handle event
});