Hi all,
Environment: SharePoint Online
Background: Client have multiple tasks in SharePoint
OOTB Task list for different workflows and each workflow has its different business logic using Nintex workflows. Client requested to have bulk
approval as custom action on Ribbon Control on
the task list.
Challenge:
I am developing SharePoint Add-in to meet this above requirement.
- User selects Tasks from the SharePoint Task list.
- Click on Bulk Approval custom action.
-
I am able to show the selected IDs. As shown
below:
-
I need to show to user click Yes to approve
the selected tasks and No if he wishes to
cancel.
Q: How could I show Yes / No options (Javascript??) in the dialog box using custom ribbon action within the SharePoint Add-in?
This my custom action for ribbon control (Bulk Approval)
<?xml version="1.0" encoding="utf-8"?><Elements xmlns="http://schemas.microsoft.com/sharepoint/"><CustomAction Id="9809f0a6-4abc-4c2a-a6e6-c57ef9647647.BulkApprovalCustomAction" RegistrationType="List" RegistrationId="107" Location="CommandUI.Ribbon" Sequence="10001" Title="Bulk Approval" HostWebDialog="true" HostWebDialogHeight="300" HostWebDialogWidth="400"><CommandUIExtension><!-- Update the UI definitions below with the controls and the command actions that you want to enable for the custom action. --><CommandUIDefinitions><CommandUIDefinition Location="Ribbon.ListItem.Actions.Controls._children"><Button Id="Ribbon.ListItem.Actions.BulkApprovalCustomActionButton" Alt="Bulk Approval" Sequence="100" Command="Invoke_BulkApprovalCustomActionButtonRequest" LabelText="Bulk Approval" TemplateAlias="o1" Image32by32="" Image16by16="" /></CommandUIDefinition></CommandUIDefinitions><CommandUIHandlers><CommandUIHandler Command="Invoke_BulkApprovalCustomActionButtonRequest" CommandAction="~appWebUrl/Pages/Default.aspx?{StandardTokens}&SPListItemId={SelectedItemId}&SPListId={SelectedListId}"/></CommandUIHandlers></CommandUIExtension ></CustomAction></Elements
-
If a user choose the clicks Yes, then I need to
set the workflow statuses to be "Approved" for
all the document libraries and custom lists irrespective of the workflow business logic defined.
Q: How could I achieve this? Any sample code would be very beneficial.
This my App.js code for SharePoint Add-in code.
var context; var user; var hostweburl; var appweburl; var listItemIds; var countOfIDs var targetList = "Tasks" $(document).ready(function () { SP.SOD.executeFunc('sp.js', 'SP.ClientContext', constructURL); }); // This function is executed after the DOM is ready and SharePoint scripts are loaded // Place any code you want to run when Default.aspx is loaded in this function // The code creates a context object which is needed to use the SharePoint object model function constructURL() { hostweburl = getQueryStringParameter("SPHostUrl"); appweburl = getQueryStringParameter("SPAppWebUrl"); listItemIds = getQueryStringParameter("SPListItemId"); hostweburl = decodeURIComponent(hostweburl); appweburl = decodeURIComponent(appweburl); listItemIds = getQueryStringParameter("SPListItemId"); if (typeof listItemIds !== "undefined") { countOfIDs = listItemIds.split(',').length; } loadDependentScripts(); } function loadDependentScripts() { var scriptbase = hostweburl + "/_layouts/15/"; // Load the js files and continue to the successHandler $.getScript(scriptbase + "SP.Runtime.js", function () { $.getScript(scriptbase + "SP.js", function () { $.getScript(scriptbase + "SP.RequestExecutor.js", specificListFromHostWebUsingREST); } ); } ); } function specificListFromHostWebUsingREST() { var executor; //If User does not select any option if (!listItemIds) { listItemIds = "1, 2, 3"; } // although we're fetching data from the host web, SP.RequestExecutor gets initialized with the app web URL.. executor = new SP.RequestExecutor(appweburl); executor.executeAsync( { url: appweburl +"/_api/SP.AppContextSite(@target)/web/lists/getbytitle('" + targetList + "')/items?@target='" + hostweburl + "'&$select=Title", method: "GET", headers: { "Accept": "application/json; odata=verbose" }, success: Success, error: Fail } ); } function Success(data) { var jsonObject = JSON.parse(data.body); if (typeof countOfIDs !== "undefined") { $('#selectedIDs').text(countOfIDs.toString()); } for (var i = 0; i < jsonObject.d.results.length; i++) { //var currentObject = jsonObject[i] var result = jsonObject.d.results[i]; $('#Status').append("<div style='padding-gt;" + result.Title + "</div>"); } if (typeof countOfIDs !== "undefined") { $('#selectedIDs').text(countOfIDs.toString()); } } function Fail(data, errorCode, errorMessage) { alert('Failed to get host site. Error:' + errorMessage); } function getQueryStringParameter(paramToRetrieve) { var params = document.URL.split("?")[1].split("&"); for (var i = 0; i < params.length; i = i + 1) { var singleParam = params[i].split("="); if (singleParam[0] == paramToRetrieve) return singleParam[1];
- Thank in advance.
Sandy