Google Slides: Page; Duplicate

Duplicates the specified slide and inserts it on the next page. If no slide is specified, the last slide is duplicated.

2019-08-27 (C) Questetra, Inc. (MIT License)
https://support.questetra.com/addons/google-slides-page-duplicate/

Configs
  • A: Select OAuth2 Config Name (at [OAuth 2.0 Setting]) *
  • B: Set PRESENTATION-ID to Retrieve (44 chars in File URI) * #{EL}
  • C: Set OBJECT-ID of SLIDE (Chars following “id.”) #{EL}
  • D: Select STRING DATA for Object-ID of New Slide (update)
Script (click to open)

// (c) 2019, Questetra, Inc. (the MIT License)

//// == OAuth2 Setting example ==
// Authorization Endpoint URL:
//  "https://accounts.google.com/o/oauth2/auth?access_type=offline&approval_prompt=force"
// Token Endpoint URL:
//  "https://accounts.google.com/o/oauth2/token"
// Scope:
//  "https://www.googleapis.com/auth/presentations https://www.googleapis.com/auth/spreadsheets.readonly"
// Client ID:
//  ( from https://console.developers.google.com/ )
// Consumer Secret:
//  ( from https://console.developers.google.com/ )
//  *Redirect URLs: "https://s.questetra.net/oauth2callback"


//////// START "main()" ////////
main();
function main(){ 

//// == Config Retrieving / 工程コンフィグの参照 ==
const oauth2   = configs.get( "conf_OAuth2"  ) + "";
const presentationId = configs.get( "conf_PresentationId") + "";
let   objectId = configs.get( "conf_ObjectId") + "";
const dataIdD  = configs.get( "conf_DataIdD" ) + "";
// 'java.lang.String' (String Obj) to javascript primitive 'string'

engine.log( " AutomatedTask Config: Presentation ID: " + presentationId );
if( objectId === "" ){
  engine.log( " AutomatedTask Config: Object ID: not set" );
}else{
  engine.log( " AutomatedTask Config: Object ID: " + objectId );
}


//// == Data Retrieving / ワークフローデータの参照 ==
// (nothing)


//// == Calculating / 演算 ==
/// obtain OAuth2 Access Token
const token   = httpClient.getOAuth2Token( oauth2 );

/// get ID of Last-Slide
if( objectId === "" ){
  let apiRequest = httpClient.begin(); // HttpRequestWrapper
  apiRequest     = apiRequest.bearer( token );
  const apiUri = "https://slides.googleapis.com/v1/presentations/" + presentationId;
  engine.log( " AutomatedTask Trying: GET " + apiUri );
  const response = apiRequest.get( apiUri );
  const responseCode = response.getStatusCode() + "";
  engine.log( " AutomatedTask ApiResponse: Status " + responseCode );
  if( responseCode !== "200"){
    throw new Error( "\n AutomatedTask UnexpectedResponseError: "
           + responseCode + "\n" + response.getResponseAsString() + "\n" );
  }
  const responseStr = response.getResponseAsString() + "";
  const responseObj = JSON.parse( responseStr );
  const SlideNum = responseObj.slides.length;
  objectId = responseObj.slides[SlideNum - 1].objectId;
}

/// post DuplicateObjectRequest
let requestObj2 = {};
    requestObj2.requests = [];
    requestObj2.requests[0] = {};
    requestObj2.requests[0].duplicateObject = {};
    requestObj2.requests[0].duplicateObject.objectId = objectId;
let apiRequest2 = httpClient.begin(); // HttpRequestWrapper
apiRequest2 = apiRequest2.bearer( token );
apiRequest2 = apiRequest2.body( JSON.stringify( requestObj2 ), "application/json" )
const apiUri2 = "https://slides.googleapis.com/v1/presentations/"
                + presentationId + ":batchUpdate";
engine.log( " AutomatedTask Trying: POST " + apiUri2 );
const response2 = apiRequest2.post( apiUri2 );
const responseCode2 = response2.getStatusCode() + "";
engine.log( " AutomatedTask ApiResponse: Status " + responseCode2 );
if( responseCode2 !== "200"){
  throw new Error( "\n AutomatedTask UnexpectedResponseError: "
         + responseCode2 + "\n" + response2.getResponseAsString() + "\n" );
}
const responseStr2 = response2.getResponseAsString() + "";
const responseObj2 = JSON.parse( responseStr2 );
const duplicateObject = responseObj2.replies[0].duplicateObject.objectId;


//// == Data Updating / ワークフローデータへの代入 ==
if( dataIdD !== "" ){
  engine.setDataByNumber( dataIdD, duplicateObject );
}

} //////// END "main()" ////////

Download

Capture

Notes

  1. Presentation ID: https://docs.google.com/presentation/d/1p33hGJFUNYixBmMeaV81nsOVYGUUrZIFyErinFp3CI8/edit#slide=id.g613777c84a_0_0
  2. Slide Object ID: https://docs.google.com/presentation/d/1p33hGJFUNYixBmMeaV81nsOVYGUUrZIFyErinFp3CI8/edit#slide=id.g613777c84a_0_0

See also

2 thoughts on “Google Slides: Page; Duplicate”

  1. Pingback: Google Slides: Page; Generate PNG Image – Questetra Support

  2. Pingback: Google Slides: Page; Refresh All Chart – Questetra Support

Leave a Reply

This site uses Akismet to reduce spam. Learn how your comment data is processed.

%d bloggers like this: