From 407a20a82102ed1e1f6341222265bacef9e3c483 Mon Sep 17 00:00:00 2001 From: Josh McCarty Date: Fri, 27 Dec 2013 16:36:54 -0700 Subject: [PATCH] Creating release for 0.7.2 --- jquery.SPServices-0.7.2.zip | Bin 54878 -> 0 bytes jquery.SPServices-2013.01ALPHA1.js | 3987 --------------------------- jquery.SPServices-2013.01ALPHA2.js | 4040 --------------------------- jquery.SPServices-2013.01ALPHA3.js | 4068 --------------------------- jquery.SPServices-2013.01ALPHA4.js | 4068 --------------------------- jquery.SPServices-2013.01ALPHA5.js | 4070 ---------------------------- license.txt | 7 + 7 files changed, 7 insertions(+), 20233 deletions(-) delete mode 100644 jquery.SPServices-0.7.2.zip delete mode 100644 jquery.SPServices-2013.01ALPHA1.js delete mode 100644 jquery.SPServices-2013.01ALPHA2.js delete mode 100644 jquery.SPServices-2013.01ALPHA3.js delete mode 100644 jquery.SPServices-2013.01ALPHA4.js delete mode 100644 jquery.SPServices-2013.01ALPHA5.js create mode 100644 license.txt diff --git a/jquery.SPServices-0.7.2.zip b/jquery.SPServices-0.7.2.zip deleted file mode 100644 index e2b421163dbf110eb68927ec2b3c4bdac8b1f6c1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 54878 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 diff --git a/jquery.SPServices-2013.01ALPHA1.js b/jquery.SPServices-2013.01ALPHA1.js deleted file mode 100644 index 7cffd7b..0000000 --- a/jquery.SPServices-2013.01ALPHA1.js +++ /dev/null @@ -1,3987 +0,0 @@ -/* - * SPServices - Work with SharePoint's Web Services using jQuery - * Version 0.7.3 -> Note to Marc: Also change var VERSION below. - * @requires jQuery v1.4.2 or greater - jQuery 1.7+ recommended - * - * Copyright (c) 2009-2012 Sympraxis Consulting LLC - * Examples and docs at: - * http://spservices.codeplex.com - * Licensed under the MIT license: - * http://www.opensource.org/licenses/mit-license.php - */ -/** - * @description Work with SharePoint's Web Services using jQuery - * @type jQuery - * @name SPServices - * @category Plugins/SPServices - * @author Sympraxis Consulting LLC/marc.anderson@sympraxisconsulting.com - */ - -(function ($) { - - // Version info - var VERSION = "0.7.3"; - - // String constants - // General - var SLASH = "/"; - var TXTColumnNotFound = "Column not found on page"; - var SCHEMASharePoint = "http://schemas.microsoft.com/sharepoint"; - - // Web Service names - var ALERTS = "Alerts"; - var AUTHENTICATION = "Authentication"; - var COPY = "Copy"; - var FORMS = "Forms"; - var LISTS = "Lists"; - var MEETINGS = "Meetings"; - var PEOPLE = "People"; - var PERMISSIONS = "Permissions"; - var PUBLISHEDLINKSSERVICE = "PublishedLinksService"; - var SEARCH = "Search"; - var SHAREPOINTDIAGNOSTICS = "SharePointDiagnostics"; - var SITEDATA = "SiteData"; - var SITES = "Sites"; - var SOCIALDATASERVICE = "SocialDataService"; - var SPELLCHECK = "SpellCheck"; - var TAXONOMYSERVICE = "TaxonomyClientService"; - var USERGROUP = "usergroup"; - var USERPROFILESERVICE = "UserProfileService"; - var VERSIONS = "Versions"; - var VIEWS = "Views"; - var WEBPARTPAGES = "WebPartPages"; - var WEBS = "Webs"; - var WORKFLOW = "Workflow"; - - // Global variables - var thisSite = ""; // The current site - var thisList = ""; // The current list when in a list context - var i = 0; // Generic loop counter - var t = ""; // Temporary string variable - - // Array to store Web Service information - // WSops.OpName = [WebService, needs_SOAPAction]; - // OpName The name of the Web Service operation -> These names are unique - // WebService The name of the WebService this operation belongs to - // needs_SOAPAction Boolean indicating whether the operatio needs to have the SOAPAction passed in the setRequestHeaderfunction. - // true if the operation does a write, else false - - var WSops = []; - - WSops.GetAlerts = [ALERTS, false]; - WSops.DeleteAlerts = [ALERTS, true]; - - WSops.Mode = [AUTHENTICATION, false]; - WSops.Login = [AUTHENTICATION, false]; - - WSops.CopyIntoItems = [COPY, true]; - WSops.CopyIntoItemsLocal = [COPY, true]; - WSops.GetItem = [COPY, false]; - - WSops.GetForm = [FORMS, false]; - WSops.GetFormCollection = [FORMS, false]; - - WSops.AddAttachment = [LISTS, true]; - WSops.AddDiscussionBoardItem = [LISTS, true]; - WSops.AddList = [LISTS, true]; - WSops.AddListFromFeature = [LISTS, true]; - WSops.ApplyContentTypeToList = [LISTS, true]; - WSops.CheckInFile = [LISTS, true]; - WSops.CheckOutFile = [LISTS, true]; - WSops.CreateContentType = [LISTS, true]; - WSops.DeleteAttachment = [LISTS, true]; - WSops.DeleteContentType = [LISTS, true]; - WSops.DeleteContentTypeXmlDocument = [LISTS, true]; - WSops.DeleteList = [LISTS, true]; - WSops.GetAttachmentCollection = [LISTS, false]; - WSops.GetList = [LISTS, false]; - WSops.GetListAndView = [LISTS, false]; - WSops.GetListCollection = [LISTS, false]; - WSops.GetListContentType = [LISTS, false]; - WSops.GetListContentTypes = [LISTS, false]; - WSops.GetListItemChanges = [LISTS, false]; - WSops.GetListItemChangesSinceToken = [LISTS, false]; - WSops.GetListItems = [LISTS, false]; - WSops.GetVersionCollection = [LISTS, false]; - WSops.UndoCheckOut = [LISTS, true]; - WSops.UpdateContentType = [LISTS, true]; - WSops.UpdateContentTypesXmlDocument = [LISTS, true]; - WSops.UpdateContentTypeXmlDocument = [LISTS, true]; - WSops.UpdateList = [LISTS, true]; - WSops.UpdateListItems = [LISTS, true]; - - WSops.AddMeeting = [MEETINGS, true]; - WSops.CreateWorkspace = [MEETINGS, true]; - WSops.RemoveMeeting = [MEETINGS, true]; - WSops.SetWorkSpaceTitle = [MEETINGS, true]; - - WSops.ResolvePrincipals = [PEOPLE, false]; - WSops.SearchPrincipals = [PEOPLE, false]; - - WSops.AddPermission = [PERMISSIONS, true]; - WSops.AddPermissionCollection = [PERMISSIONS, true]; - WSops.GetPermissionCollection = [PERMISSIONS, true]; - WSops.RemovePermission = [PERMISSIONS, true]; - WSops.RemovePermissionCollection = [PERMISSIONS, true]; - WSops.UpdatePermission = [PERMISSIONS, true]; - - WSops.GetLinks = [PUBLISHEDLINKSSERVICE, true]; - - WSops.GetPortalSearchInfo = [SEARCH, false]; - WSops.GetQuerySuggestions = [SEARCH, false]; - WSops.GetSearchMetadata = [SEARCH, false]; - WSops.Query = [SEARCH, false]; - WSops.QueryEx = [SEARCH, false]; - WSops.Registration = [SEARCH, false]; - WSops.Status = [SEARCH, false]; - - WSops.SendClientScriptErrorReport = [SHAREPOINTDIAGNOSTICS,true]; - - WSops.GetAttachments = [SITEDATA, false]; - WSops.EnumerateFolder = [SITEDATA, false]; - WSops.SiteDataGetList = [SITEDATA, false]; - WSops.SiteDataGetListCollection = [SITEDATA, false]; - WSops.SiteDataGetSite = [SITEDATA, false]; - WSops.SiteDataGetSiteUrl = [SITEDATA, false]; - WSops.SiteDataGetWeb = [SITEDATA, false]; - - WSops.CreateWeb = [SITES, true]; - WSops.DeleteWeb = [SITES, false]; - WSops.GetSite = [SITES, false]; - WSops.GetSiteTemplates = [SITES, false]; - - WSops.AddComment = [SOCIALDATASERVICE, true]; - WSops.AddTag = [SOCIALDATASERVICE, true]; - WSops.AddTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.CountCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountTagsOfUser = [SOCIALDATASERVICE, false]; - WSops.DeleteComment = [SOCIALDATASERVICE, true]; - WSops.DeleteRating = [SOCIALDATASERVICE, true]; - WSops.DeleteTag = [SOCIALDATASERVICE, true]; - WSops.DeleteTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.DeleteTags = [SOCIALDATASERVICE, true]; - WSops.GetAllTagTerms = [SOCIALDATASERVICE, false]; - WSops.GetAllTagTermsForUrlFolder = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrls = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrlsByKeyword = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingAverageOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetSocialDataForFullReplication = [SOCIALDATASERVICE, false]; - WSops.GetTags = [SOCIALDATASERVICE, true]; - WSops.GetTagsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTerms = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOnUrl = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUserByKeyword = [SOCIALDATASERVICE, true]; - WSops.GetTagUrls = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsByKeyword = [SOCIALDATASERVICE, true]; - WSops.SetRating = [SOCIALDATASERVICE, true]; - WSops.UpdateComment = [SOCIALDATASERVICE, true]; - - WSops.SpellCheck = [SPELLCHECK, false]; - - // Taxonomy Service Calls - // Updated 2011.01.27 by Thomas McMillan - WSops.AddTerms = [TAXONOMYSERVICE, true]; - WSops.GetChildTermsInTerm = [TAXONOMYSERVICE, false]; - WSops.GetChildTermsInTermSet = [TAXONOMYSERVICE, false]; - WSops.GetKeywordTermsByGuids = [TAXONOMYSERVICE, false]; - WSops.GetTermsByLabel = [TAXONOMYSERVICE, false]; - WSops.GetTermSets = [TAXONOMYSERVICE, false]; - - WSops.AddGroup = [USERGROUP, true]; - WSops.AddGroupToRole = [USERGROUP, true]; - WSops.AddRole = [USERGROUP, true]; - WSops.AddRoleDef = [USERGROUP, true]; - WSops.AddUserCollectionToGroup = [USERGROUP, true]; - WSops.AddUserCollectionToRole = [USERGROUP, true]; - WSops.AddUserToGroup = [USERGROUP, true]; - WSops.AddUserToRole = [USERGROUP, true]; - WSops.GetAllUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupCollection = [USERGROUP, false]; - WSops.GetGroupCollectionFromRole = [USERGROUP, false]; - WSops.GetGroupCollectionFromSite = [USERGROUP, false]; - WSops.GetGroupCollectionFromUser = [USERGROUP, false]; - WSops.GetGroupCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupInfo = [USERGROUP, false]; - WSops.GetRoleCollection = [USERGROUP, false]; - WSops.GetRoleCollectionFromGroup = [USERGROUP, false]; - WSops.GetRoleCollectionFromUser = [USERGROUP, false]; - WSops.GetRoleCollectionFromWeb = [USERGROUP, false]; - WSops.GetRoleInfo = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForCurrentUser = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForSite = [USERGROUP, false]; - WSops.GetUserCollection = [USERGROUP, false]; - WSops.GetUserCollectionFromGroup = [USERGROUP, false]; - WSops.GetUserCollectionFromRole = [USERGROUP, false]; - WSops.GetUserCollectionFromSite = [USERGROUP, false]; - WSops.GetUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetUserInfo = [USERGROUP, false]; - WSops.GetUserLoginFromEmail = [USERGROUP, false]; - WSops.RemoveGroup = [USERGROUP, true]; - WSops.RemoveGroupFromRole = [USERGROUP, true]; - WSops.RemoveRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromGroup = [USERGROUP, true]; - WSops.RemoveUserCollectionFromRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromSite = [USERGROUP, true]; - WSops.RemoveUserFromGroup = [USERGROUP, true]; - WSops.RemoveUserFromRole = [USERGROUP, true]; - WSops.RemoveUserFromSite = [USERGROUP, true]; - WSops.RemoveUserFromWeb = [USERGROUP, true]; - WSops.UpdateGroupInfo = [USERGROUP, true]; - WSops.UpdateRoleDefInfo = [USERGROUP, true]; - WSops.UpdateRoleInfo = [USERGROUP, true]; - WSops.UpdateUserInfo = [USERGROUP, true]; - - WSops.AddColleague = [USERPROFILESERVICE, true]; - WSops.AddLink = [USERPROFILESERVICE, true]; - WSops.AddMembership = [USERPROFILESERVICE, true]; - WSops.AddPinnedLink = [USERPROFILESERVICE, true]; - WSops.CreateMemberGroup = [USERPROFILESERVICE, true]; - WSops.CreateUserProfileByAccountName = [USERPROFILESERVICE, true]; - WSops.GetCommonColleagues = [USERPROFILESERVICE, false]; - WSops.GetCommonManager = [USERPROFILESERVICE, false]; - WSops.GetCommonMemberships = [USERPROFILESERVICE, false]; - WSops.GetInCommon = [USERPROFILESERVICE, false]; - WSops.GetPropertyChoiceList = [USERPROFILESERVICE, false]; - WSops.GetUserColleagues = [USERPROFILESERVICE, false]; - WSops.GetUserLinks = [USERPROFILESERVICE, false]; - WSops.GetUserMemberships = [USERPROFILESERVICE, false]; - WSops.GetUserPinnedLinks = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByGuid = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByIndex = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByName = [USERPROFILESERVICE, false]; - WSops.GetUserProfileCount = [USERPROFILESERVICE, false]; - WSops.GetUserProfileSchema = [USERPROFILESERVICE, false]; - WSops.ModifyUserPropertyByAccountName = [USERPROFILESERVICE, true]; - WSops.RemoveAllColleagues = [USERPROFILESERVICE, true]; - WSops.RemoveAllLinks = [USERPROFILESERVICE, true]; - WSops.RemoveAllMemberships = [USERPROFILESERVICE, true]; - WSops.RemoveAllPinnedLinks = [USERPROFILESERVICE, true]; - WSops.RemoveColleague = [USERPROFILESERVICE, true]; - WSops.RemoveLink = [USERPROFILESERVICE, true]; - WSops.RemoveMembership = [USERPROFILESERVICE, true]; - WSops.RemovePinnedLink = [USERPROFILESERVICE, true]; - WSops.UpdateColleaguePrivacy = [USERPROFILESERVICE, true]; - WSops.UpdateLink = [USERPROFILESERVICE, true]; - WSops.UpdateMembershipPrivacy = [USERPROFILESERVICE, true]; - WSops.UpdatePinnedLink = [USERPROFILESERVICE, true]; - - WSops.DeleteAllVersions = [VERSIONS, true]; - WSops.DeleteVersion = [VERSIONS, true]; - WSops.GetVersions = [VERSIONS, false]; - WSops.RestoreVersion = [VERSIONS, true]; - - WSops.AddView = [VIEWS, true]; - WSops.DeleteView = [VIEWS, true]; - WSops.GetView = [VIEWS, false]; - WSops.GetViewHtml = [VIEWS, false]; - WSops.GetViewCollection = [VIEWS, false]; - WSops.UpdateView = [VIEWS, true]; - WSops.UpdateViewHtml = [VIEWS, true]; - - WSops.AddWebPart = [WEBPARTPAGES, true]; - WSops.AddWebPartToZone = [WEBPARTPAGES, true]; - WSops.GetWebPart2 = [WEBPARTPAGES, false]; - WSops.GetWebPartPage = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties2 = [WEBPARTPAGES, false]; - - WSops.CreateContentType = [WEBS, true]; - WSops.GetColumns = [WEBS, false]; - WSops.GetContentType = [WEBS, false]; - WSops.GetContentTypes = [WEBS, false]; - WSops.GetCustomizedPageStatus = [WEBS, false]; - WSops.GetListTemplates = [WEBS, false]; - WSops.GetObjectIdFromUrl = [WEBS, false]; // 2010 - WSops.GetWeb = [WEBS, false]; - WSops.GetWebCollection = [WEBS, false]; - WSops.GetAllSubWebCollection = [WEBS, false]; - WSops.UpdateColumns = [WEBS, true]; - WSops.UpdateContentType = [WEBS, true]; - WSops.WebUrlFromPageUrl = [WEBS, false]; - - WSops.AlterToDo = [WORKFLOW, true]; - WSops.GetTemplatesForItem = [WORKFLOW, false]; - WSops.GetToDosForItem = [WORKFLOW, false]; - WSops.GetWorkflowDataForItem = [WORKFLOW, false]; - WSops.GetWorkflowTaskData = [WORKFLOW, false]; - WSops.StartWorkflow = [WORKFLOW, true]; - - // Set up SOAP envelope - var SOAPEnvelope = {}; - SOAPEnvelope.header = ""; - SOAPEnvelope.footer = ""; - SOAPEnvelope.payload = ""; - var SOAPAction; - - - // Main function, which calls SharePoint's Web Services directly. - $.fn.SPServices = function(options) { - - // If there are no options passed in, use the defaults. Extend replaces each default with the passed option. - var opt = $.extend({}, $.fn.SPServices.defaults, options); - - // Put together operation header and SOAPAction for the SOAP call based on which Web Service we're calling - SOAPEnvelope.opheader = "<" + opt.operation + " "; - switch(WSops[opt.operation][0]) { - case ALERTS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/2002/1/alerts/' >"; - SOAPAction = SCHEMASharePoint + "/soap/2002/1/alerts/"; - break; - case MEETINGS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/meetings/' >"; - SOAPAction = SCHEMASharePoint + "/soap/meetings/"; - break; - case PERMISSIONS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case PUBLISHEDLINKSSERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/"; - break; - case SEARCH: - SOAPEnvelope.opheader += "xmlns='urn:Microsoft.Search' >"; - SOAPAction = "urn:Microsoft.Search/"; - break; - case SHAREPOINTDIAGNOSTICS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/diagnostics/' >"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/diagnostics/"; - break; - case SOCIALDATASERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/SocialDataService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/SocialDataService/"; - break; - case SPELLCHECK: - SOAPEnvelope.opheader += "xmlns='http://schemas.microsoft.com/sharepoint/publishing/spelling/'"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/publishing/spelling/SpellCheck"; - break; - case TAXONOMYSERVICE: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/taxonomy/soap/' >"; - SOAPAction = SCHEMASharePoint + "/taxonomy/soap/"; - break; - case USERGROUP: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case USERPROFILESERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/UserProfileService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/UserProfileService/"; - break; - case WEBPARTPAGES: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/sharepoint/webpartpages' >"; - SOAPAction = "http://microsoft.com/sharepoint/webpartpages/"; - break; - case WORKFLOW: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/workflow/' >"; - SOAPAction = SCHEMASharePoint + "/soap/workflow/"; - break; - default: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/'>"; - SOAPAction = SCHEMASharePoint + "/soap/"; - break; - } - - // Add the operation to the SOAPAction and opfooter - SOAPAction += opt.operation; - SOAPEnvelope.opfooter = ""; - - // Build the URL for the Ajax call based on which operation we're calling - // If the webURL has been provided, then use it, else use the current site - var ajaxURL = "_vti_bin/" + WSops[opt.operation][0] + ".asmx"; - if(opt.webURL.charAt(opt.webURL.length - 1) === SLASH) { - ajaxURL = opt.webURL + ajaxURL; - } else if(opt.webURL.length > 0) { - ajaxURL = opt.webURL + SLASH + ajaxURL; - } else { - ajaxURL = $().SPServices.SPGetCurrentSite() + SLASH + ajaxURL; - } - - SOAPEnvelope.payload = ""; - // Each operation requires a different set of values. This switch statement sets them up in the SOAPEnvelope.payload. - switch(opt.operation) { - // ALERT OPERATIONS - case "GetAlerts": - break; - case "DeleteAlerts": - SOAPEnvelope.payload += ""; - for (i=0; i < opt.IDs.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.IDs[i]); - } - SOAPEnvelope.payload += ""; - break; - - // AUTHENTICATION OPERATIONS - case "Mode": - break; - case "Login": - addToPayload(opt, ["username", "password"]); - break; - - // COPY OPERATIONS - case "CopyIntoItems": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - addToPayload(opt, ["Fields", "Stream", "Results"]); - break; - case "CopyIntoItemsLocal": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - break; - case "GetItem": - addToPayload(opt, ["Url", "Fields", "Stream"]); - break; - - // FORM OPERATIONS - case "GetForm": - addToPayload(opt, ["listName", "formUrl"]); - break; - case "GetFormCollection": - addToPayload(opt, ["listName"]); - break; - - // LIST OPERATIONS - case "AddAttachment": - addToPayload(opt, ["listName", "listItemID", "fileName", "attachment"]); - break; - case "AddDiscussionBoardItem": - addToPayload(opt, ["listName", "message"]); - break; - case "AddList": - addToPayload(opt, ["listName", "description", "templateID"]); - break; - case "AddListFromFeature": - addToPayload(opt, ["listName", "description", "featureID", "templateID"]); - break; - case "ApplyContentTypeToList": - addToPayload(opt, ["webUrl", "contentTypeId", "listName"]); - break; - case "CheckInFile": - addToPayload(opt, ["pageUrl", "comment", "CheckinType"]); - break; - case "CheckOutFile": - addToPayload(opt, ["pageUrl", "checkoutToLocal", "lastmodified"]); - break; - case "CreateContentType": - addToPayload(opt, ["listName", "displayName", "parentType", "fields", "contentTypeProperties", "addToView"]); - break; - case "DeleteAttachment": - addToPayload(opt, ["listName", "listItemID", "url"]); - break; - case "DeleteContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "DeleteContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "documentUri"]); - break; - case "DeleteList": - addToPayload(opt, ["listName"]); - break; - case "GetAttachmentCollection": - addToPayload(opt, ["listName", ["listItemID", "ID"]]); - break; - case "GetList": - addToPayload(opt, ["listName"]); - break; - case "GetListAndView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetListCollection": - break; - case "GetListContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "GetListContentTypes": - addToPayload(opt, ["listName"]); - break; - case "GetListItems": - addToPayload(opt, ["listName", "viewName", ["query", "CAMLQuery"], ["viewFields", "CAMLViewFields"], ["rowLimit", "CAMLRowLimit"], ["queryOptions", "CAMLQueryOptions"]]); - break; - case "GetListItemChanges": - addToPayload(opt, ["listName", "viewFields", "since", "contains"]); - break; - case "GetListItemChangesSinceToken": - addToPayload(opt, ["listName", "viewName", "query", "viewFields", "rowLimit", "queryOptions", "changeToken", "contains"]); - break; - case "GetVersionCollection": - addToPayload(opt, ["strlistID", "strlistItemID", "strFieldName"]); - break; - case "UndoCheckOut": - addToPayload(opt, ["pageUrl"]); - break; - case "UpdateContentType": - addToPayload(opt, ["listName", "contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields", "addToView"]); - break; - case "UpdateContentTypesXmlDocument": - addToPayload(opt, ["listName", "newDocument"]); - break; - case "UpdateContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "newDocument"]); - break; - case "UpdateList": - addToPayload(opt, ["listName", "listProperties", "newFields", "updateFields", "deleteFields", "listVersion"]); - break; - case "UpdateListItems": - addToPayload(opt, ["listName"]); - if(opt.updates !== undefined && opt.updates.length > 0) { - addToPayload(opt, ["updates"]); - } else { - SOAPEnvelope.payload += ""; - for (i=0; i < opt.valuepairs.length; i++) { - SOAPEnvelope.payload += "" + escapeColumnValue(opt.valuepairs[i][1]) + ""; - } - if(opt.batchCmd !== "New") { - SOAPEnvelope.payload += "" + opt.ID + ""; - } - SOAPEnvelope.payload += ""; - } - break; - - // MEETINGS OPERATIONS - case "AddMeeting": - addToPayload(opt, ["organizerEmail", "uid", "sequence", "utcDateStamp", "title", "location", "utcDateStart", "utcDateEnd", "nonGregorian"]); - break; - case "CreateWorkspace": - addToPayload(opt, ["title", "templateName", "lcid", "timeZoneInformation"]); - break; - case "RemoveMeeting": - addToPayload(opt, ["recurrenceId", "uid", "sequence", "utcDateStamp", "cancelMeeting"]); - break; - case "SetWorkspaceTitle": - addToPayload(opt, ["title"]); - break; - - // PEOPLE OPERATIONS - case "ResolvePrincipals": - addToPayload(opt, ["principalKeys", "principalType", "addToUserInfoList"]); - break; - case "SearchPrincipals": - addToPayload(opt, ["searchText", "maxResults", "principalType"]); - break; - - // PERMISSION OPERATIONS - case "AddPermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - case "AddPermissionCollection": - addToPayload(opt, ["objectName", "objectType", "permissionsInfoXml"]); - break; - case "GetPermissionCollection": - addToPayload(opt, ["objectName", "objectType"]); - break; - case "RemovePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType"]); - break; - case "RemovePermissionCollection": - addToPayload(opt, ["objectName", "objectType", "memberIdsXml"]); - break; - case "UpdatePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - - // PUBLISHEDLINKSSERVICE OPERATIONS - case "GetLinks": - break; - - // SEARCH OPERATIONS - case "GetPortalSearchInfo": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "GetQuerySuggestions": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", escapeHTML(opt.queryXml)); - break; - case "GetSearchMetadata": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "Query": - SOAPEnvelope.payload += wrapNode("queryXml", escapeHTML(opt.queryXml)); - break; - case "QueryEx": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", escapeHTML(opt.queryXml)); - break; - case "Registration": - SOAPEnvelope.payload += wrapNode("registrationXml", escapeHTML(opt.registrationXml)); - break; - case "Status": - break; - - // SHAREPOINTDIAGNOSTICS OPERATIONS - case "SendClientScriptErrorReport": - addToPayload(opt, ["message", "file", "line", "client", "stack", "team", "originalFile"]); - break; - - // SITEDATA OPERATIONS - case "EnumerateFolder": - addToPayload(opt, ["strFolderUrl"]); - break; - case "GetAttachments": - addToPayload(opt, ["strListName", "strItemId"]); - break; - case "SiteDataGetList": - addToPayload(opt, ["strListName"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetListCollection": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSite": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSiteUrl": - addToPayload(opt, ["Url"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetWeb": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - - // SITES OPERATIONS - case "CreateWeb": - addToPayload(opt, ["url", "title", "description", "templateName", "language", "languageSpecified", - "locale", "localeSpecified", "collationLocale", "collationLocaleSpecified", "uniquePermissions", - "uniquePermissionsSpecified", "anonymous", "anonymousSpecified", "presence", "presenceSpecified"]); - break; - case "DeleteWeb": - addToPayload(opt, ["url"]); - break; - case "GetSite": - addToPayload(opt, ["SiteUrl"]); - break; - case "GetSiteTemplates": - addToPayload(opt, ["LCID", "TemplateList"]); - break; - - // SOCIALDATASERVICE OPERATIONS - case "AddComment": - addToPayload(opt, ["url", "comment", "isHighPriority", "title"]); - break; - case "AddTag": - addToPayload(opt, ["url", "termID", "title", "isPrivate"]); - break; - case "AddTagByKeyword": - addToPayload(opt, ["url", "keyword", "title", "isPrivate"]); - break; - case "CountCommentsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "CountCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "CountCommentsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountTagsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "DeleteComment": - addToPayload(opt, ["url", "lastModifiedTime"]); - break; - case "DeleteRating": - addToPayload(opt, ["url"]); - break; - case "DeleteTag": - addToPayload(opt, ["url", "termID"]); - break; - case "DeleteTagByKeyword": - addToPayload(opt, ["url", "keyword"]); - break; - case "DeleteTags": - addToPayload(opt, ["url"]); - break; - case "GetAllTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetAllTagTermsForUrlFolder": - addToPayload(opt, ["urlFolder", "maximumItemsToReturn"]); - break; - case "GetAllTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetAllTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetCommentsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetCommentsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn", "startIndex"]); - if(opt.excludeItemsTime !== undefined && opt.excludeItemsTime.length > 0) { - SOAPEnvelope.payload += wrapNode("excludeItemsTime", opt.excludeItemsTime); - } - break; - case "GetRatingAverageOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetRatingOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "GetRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetSocialDataForFullReplication": - addToPayload(opt, ["userAccountName"]); - break; - case "GetTags": - addToPayload(opt, ["url"]); - break; - case "GetTagsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetTagTermsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn"]); - break; - case "GetTagTermsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn"]); - break; - case "GetTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetTagUrlsOfUser": - addToPayload(opt, ["termID", "userAccountName"]); - break; - case "GetTagUrlsOfUserByKeyword": - addToPayload(opt, ["keyword", "userAccountName"]); - break; - case "SetRating": - addToPayload(opt, ["url", "rating", "title", "analysisDataEntry"]); - break; - case "UpdateComment": - addToPayload(opt, ["url", "lastModifiedTime", "comment", "isHighPriority"]); - break; - - // SPELLCHECK OPERATIONS - case "SpellCheck": - addToPayload(opt, ["chunksToSpell", "declaredLanguage", "useLad"]); - break; - - // TAXONOMY OPERATIONS - case "AddTerms": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "newTerms"]); - break; - case "GetChildTermsInTerm": - addToPayload(opt, ["sspId", "lcid", "termId", "termSetId"]); - break; - case "GetChildTermsInTermSet": - addToPayload(opt, ["sspId", "lcid", "termSetId"]); - break; - case "GetKeywordTermsByGuids": - addToPayload(opt, ["termIds", "lcid"]); - break; - case "GetTermsByLabel": - addToPayload(opt, ["label", "lcid", "matchOption", "resultCollectionSize", "termIds", "addIfNotFound"]); - break; - case "GetTermSets": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "clientTimeStamps", "clientVersions"]); - break; - - // USERS AND GROUPS OPERATIONS - case "AddGroup": - addToPayload(opt, ["groupName", "ownerIdentifier", "ownerType", "defaultUserLoginName", "description"]); - break; - case "AddGroupToRole": - addToPayload(opt, ["groupName", "roleName"]); - break; - case "AddRole": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddRoleDef": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddUserCollectionToGroup": - addToPayload(opt, ["groupName", "usersInfoXml"]); - break; - case "AddUserCollectionToRole": - addToPayload(opt, ["roleName", "usersInfoXml"]); - break; - case "AddUserToGroup": - addToPayload(opt, ["groupName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "AddUserToRole": - addToPayload(opt, ["roleName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "GetAllUserCollectionFromWeb": - break; - case "GetGroupCollection": - addToPayload(opt, ["groupNamesXml"]); - break; - case "GetGroupCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetGroupCollectionFromSite": - break; - case "GetGroupCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetGroupCollectionFromWeb": - break; - case "GetGroupInfo": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollection": - addToPayload(opt, ["roleNamesXml"]); - break; - case "GetRoleCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetRoleCollectionFromWeb": - break; - case "GetRoleInfo": - addToPayload(opt, ["roleName"]); - break; - case "GetRolesAndPermissionsForCurrentUser": - break; - case "GetRolesAndPermissionsForSite": - break; - case "GetUserCollection": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "GetUserCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetUserCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetUserCollectionFromSite": - break; - case "GetUserCollectionFromWeb": - break; - case "GetUserInfo": - addToPayload(opt, ["userLoginName"]); - break; - case "GetUserLoginFromEmail": - addToPayload(opt, ["emailXml"]); - break; - case "RemoveGroup": - addToPayload(opt, ["groupName"]); - break; - case "RemoveGroupFromRole": - addToPayload(opt, ["roleName", "groupName"]); - break; - case "RemoveRole": - addToPayload(opt, ["roleName"]); - break; - case "RemoveUserCollectionFromGroup": - addToPayload(opt, ["groupName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromRole": - addToPayload(opt, ["roleName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromSite": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "RemoveUserFromGroup": - addToPayload(opt, ["groupName", "userLoginName"]); - break; - case "RemoveUserFromRole": - addToPayload(opt, ["roleName", "userLoginName"]); - break; - case "RemoveUserFromSite": - addToPayload(opt, ["userLoginName"]); - break; - case "RemoveUserFromWeb": - addToPayload(opt, ["userLoginName"]); - break; - case "UpdateGroupInfo": - addToPayload(opt, ["oldGroupName", "groupName", "ownerIdentifier", "ownerType", "description"]); - break; - case "UpdateRoleDefInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateRoleInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateUserInfo": - addToPayload(opt, ["userLoginName", "userName", "userEmail", "userNotes"]); - break; - - // USERPROFILESERVICE OPERATIONS - case "AddColleague": - addToPayload(opt, ["accountName", "colleagueAccountName", "group", "privacy", "isInWorkGroup"]); - break; - case "AddLink": - addToPayload(opt, ["accountName", "name", "url", "group", "privacy"]); - break; - case "AddMembership": - addToPayload(opt, ["accountName", "membershipInfo", "group", "privacy"]); - break; - case "AddPinnedLink": - addToPayload(opt, ["accountName", "name", "url"]); - break; - case "CreateMemberGroup": - addToPayload(opt, ["membershipInfo"]); - break; - case "CreateUserProfileByAccountName": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonManager": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetInCommon": - addToPayload(opt, ["accountName"]); - break; - case "GetPropertyChoiceList": - addToPayload(opt, ["propertyName"]); - break; - case "GetUserColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetUserLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetUserPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserProfileByGuid": - addToPayload(opt, ["guid"]); - break; - case "GetUserProfileByIndex": - addToPayload(opt, ["index"]); - break; - case "GetUserProfileByName": - // Note that this operation is inconsistent with the others, using AccountName rather than accountName - if(opt.accountName !== undefined && opt.accountName.length > 0) { - addToPayload(opt, [["AccountName", "accountName"]]); - } else { - addToPayload(opt, ["AccountName"]); - } - break; - case "GetUserProfileCount": - break; - case "GetUserProfileSchema": - break; - case "ModifyUserPropertyByAccountName": - addToPayload(opt, ["accountName", "newData"]); - break; - case "RemoveAllColleagues": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllMemberships": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveColleague": - addToPayload(opt, ["accountName", "colleagueAccountName"]); - break; - case "RemoveLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "RemoveMembership": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference"]); - break; - case "RemovePinnedLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "UpdateColleaguePrivacy": - addToPayload(opt, ["accountName", "colleagueAccountName", "newPrivacy"]); - break; - case "UpdateLink": - addToPayload(opt, ["accountName", "data"]); - break; - case "UpdateMembershipPrivacy": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference", "newPrivacy"]); - break; - case "UpdatePinnedLink ": - addToPayload(opt, ["accountName", "data"]); - break; - - // VERSIONS OPERATIONS - case "DeleteAllVersions": - addToPayload(opt, ["fileName"]); - break; - case "DeleteVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - case "GetVersions": - addToPayload(opt, ["fileName"]); - break; - case "RestoreVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - - // VIEW OPERATIONS - case "AddView": - addToPayload(opt, ["listName", "viewName", "viewFields", "query", "rowLimit", "rowLimit", "type", "makeViewDefault"]); - break; - case "DeleteView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetViewCollection": - addToPayload(opt, ["listName"]); - break; - case "GetViewHtml": - addToPayload(opt, ["listName", "viewName"]); - break; - case "UpdateView": - addToPayload(opt, ["listName", "viewName", "viewProperties", "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - case "UpdateViewHtml": - addToPayload(opt, ["listName", "viewName", "viewProperties", "toolbar", "viewHeader", "viewBody", "viewFooter", "viewEmpty", "rowLimitExceeded", - "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - - // WEBPARTPAGES OPERATIONS - case "AddWebPart": - addToPayload(opt, ["pageUrl", "webPartXml", "storage"]); - break; - case "AddWebPartToZone": - addToPayload(opt, ["pageUrl", "webPartXml", "storage", "zoneId", "zoneIndex"]); - break; - case "GetWebPart2": - addToPayload(opt, ["pageUrl", "storageKey", "storage", "behavior"]); - break; - case "GetWebPartPage": - addToPayload(opt, ["documentName", "behavior"]); - break; - case "GetWebPartProperties": - addToPayload(opt, ["pageUrl", "storage"]); - break; - case "GetWebPartProperties2": - addToPayload(opt, ["pageUrl", "storage", "behavior"]); - break; - - // WEBS OPERATIONS - case "Webs.CreateContentType": - addToPayload(opt, ["displayName", "parentType", "newFields", "contentTypeProperties"]); - break; - case "GetColumns": - addToPayload(opt, ["webUrl"]); - break; - case "GetContentType": - addToPayload(opt, ["contentTypeId"]); - break; - case "GetContentTypes": - break; - case "GetCustomizedPageStatus": - addToPayload(opt, ["fileUrl"]); - break; - case "GetListTemplates": - break; - case "GetObjectIdFromUrl": - addToPayload(opt, ["objectUrl"]); - break; - case "GetWeb": - addToPayload(opt, [["webUrl", "webURL"]]); - break; - case "GetWebCollection": - break; - case "GetAllSubWebCollection": - break; - case "UpdateColumns": - addToPayload(opt, ["newFields", "updateFields", "deleteFields"]); - break; - case "Webs.UpdateContentType": - addToPayload(opt, ["contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields"]); - break; - case "WebUrlFromPageUrl": - addToPayload(opt, [["pageUrl", "pageURL"]]); - break; - - // WORKFLOW OPERATIONS - case "AlterToDo": - addToPayload(opt, ["item", "todoId", "todoListId", "taskData"]); - break; - case "GetTemplatesForItem": - addToPayload(opt, ["item"]); - break; - case "GetToDosForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowDataForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowTaskData": - addToPayload(opt, ["item", "listId", "taskId"]); - break; - case "StartWorkflow": - addToPayload(opt, ["item", "templateId", "workflowParameters"]); - break; - - default: - break; - } - - // Glue together the pieces of the SOAP message - var msg = SOAPEnvelope.header + - SOAPEnvelope.opheader + - SOAPEnvelope.payload + - SOAPEnvelope.opfooter + - SOAPEnvelope.footer; - - var cachedXML; - var status = null; - - if(opt.cacheXML) { - cachedXML = $("body").data(msg); - } - - if(cachedXML === undefined) { - // Make the Ajax call - $.ajax({ - url: ajaxURL, // The relative URL for the AJAX call - async: opt.async, // By default, the AJAX calls are asynchronous. You can specify false to require a synchronous call. - beforeSend: function (xhr) { // Before sending the msg, need to send the request header - // If we need to pass the SOAPAction, do so - if(WSops[opt.operation][1]) { - xhr.setRequestHeader("SOAPAction", SOAPAction); - } - }, - type: "POST", // This is a POST - data: msg, // Here is the SOAP request we've built above - dataType: "xml", // We're getting XML; tell jQuery so that it doesn't need to do a best guess - contentType: "text/xml;charset='utf-8'", // and this is its content type - complete: function(xData, Status) { - if(opt.cacheXML) { - $("body").data(msg, xData); // Cache the results - } - cachedXML = xData; - status = Status; - opt.completefunc(cachedXML, status); // When the call is complete, do this - } - }); - - } else { - opt.completefunc(cachedXML, status); // Call the completefunc - } - - }; // End $.fn.SPServices - - // Defaults added as a function in our library means that the caller can override the defaults - // for their session by calling this function. Each operation requires a different set of options; - // we allow for all in a standardized way. - $.fn.SPServices.defaults = { - - cacheXML: false, // If true, we'll cache the XML results with jQuery's .data() function - operation: "", // The Web Service operation - webURL: "", // URL of the target Web - makeViewDefault: false, // true to make the view the default view for the list - - // For operations requiring CAML, these options will override any abstractions - CAMLViewName: "", // View name in CAML format. - CAMLQuery: "", // Query in CAML format - CAMLViewFields: "", // View fields in CAML format - CAMLRowLimit: 0, // Row limit as a string representation of an integer - CAMLQueryOptions: "", // Query options in CAML format - - // Abstractions for CAML syntax - batchCmd: "Update", // Method Cmd for UpdateListItems - valuepairs: [], // Fieldname / Fieldvalue pairs for UpdateListItems - - // As of v0.7.1, removed all options which were assigned an empty string ("") - DestinationUrls: [], // Array of destination URLs for copy operations - behavior: "Version3", // An SPWebServiceBehavior indicating whether the client supports Windows SharePoint Services 2.0 or Windows SharePoint Services 3.0: {Version2 | Version3 } - storage: "Shared", // A Storage value indicating how the Web Part is stored: {None | Personal | Shared} - objectType: "List", // objectType for operations which require it - cancelMeeting: true, // true to delete a meeting;false to remove its association with a Meeting Workspace site - nonGregorian: false, // true if the calendar is set to a format other than Gregorian;otherwise, false. - fClaim: false, // Specifies if the action is a claim or a release. Specifies true for a claim and false for a release. - recurrenceId: 0, // The recurrence ID for the meeting that needs its association removed. This parameter can be set to 0 for single-instance meetings. - sequence: 0, // An integer that is used to determine the ordering of updates in case they arrive out of sequence. Updates with a lower-than-current sequence are discarded. If the sequence is equal to the current sequence, the latest update are applied. - maximumItemsToReturn: 0, // SocialDataService maximumItemsToReturn - startIndex: 0, // SocialDataService startIndex - isHighPriority: false, // SocialDataService isHighPriority - isPrivate: false, // SocialDataService isPrivate - rating: 1, // SocialDataService rating - maxResults: 10, // Unless otherwise specified, the maximum number of principals that can be returned from a provider is 10. - principalType: "User", // Specifies user scope and other information: [None | User | DistributionList | SecurityGroup | SharePointGroup | All] - - async: true, // Allow the user to force async - completefunc: null // Function to call on completion - - }; // End $.fn.SPServices.defaults - - // Function to determine the current Web's URL. We need this for successful Ajax calls. - // The function is also available as a public function. - $.fn.SPServices.SPGetCurrentSite = function() { - - // Do we already know the current site? - if(thisSite.length > 0) { - return thisSite; - } - - // SharePoint 2010 provides the current context, so if available, let's use it -// thisSite = (typeof SP !== "undefined") ? SP.ClientContext.get_current().get_url() : undefined; -// if(thisSite !== undefined) return thisSite = location.protocol + "//" + location.hostname + thisSite; - - var msg = SOAPEnvelope.header + - "" + - ((location.href.indexOf("?") > 0) ? location.href.substr(0, location.href.indexOf("?")) : location.href) + - "" + - SOAPEnvelope.footer; - $.ajax({ - async: false, // Need this to be synchronous so we're assured of a valid value - url: "/_vti_bin/Webs.asmx", - type: "POST", - data: msg, - dataType: "xml", - contentType: "text/xml;charset=\"utf-8\"", - complete: function (xData, Status) { - thisSite = $(xData.responseXML).find("WebUrlFromPageUrlResult").text(); - } - }); - return thisSite; // Return the URL - }; // End $.fn.SPServices.SPGetCurrentSite - - // Function to set up cascading dropdowns on a SharePoint form - // (Newform.aspx, EditForm.aspx, or any other customized form.) - $.fn.SPServices.SPCascadeDropdowns = function(options) { - - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationships list - relationshipList: "", // The name of the list which contains the parent/child relationships - relationshipListParentColumn: "", // The internal name of the parent column in the relationship list - relationshipListChildColumn: "", // The internal name of the child column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListChildColumn - parentColumn: "", // The display name of the parent column in the form - childColumn: "", // The display name of the child column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relationshipList - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of childColumn. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - simpleChild: false, // [Optional] If set to true and childColumn is a complex dropdown, convert it to a simple dropdown - selectSingleOption: false, // [Optional] If set to true and there is only a single child option, select it - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - - var thisParentSetUp = false; - var thisFunction = "SPServices.SPCascadeDropdowns"; - - // Find the parent column's select (dropdown) - var parentSelect = new DropdownCtl(opt.parentColumn); - if(parentSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "parentColumn: " + opt.parentColumn , TXTColumnNotFound);return;} - - // Find the child column's select (dropdown) - var childSelect = new DropdownCtl(opt.childColumn); - if(childSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "childColumn: " + opt.childColumn, TXTColumnNotFound);return;} - - // If requested and the childColumn is a complex dropdown, convert to a simple dropdown - if(opt.simpleChild === true && childSelect.Type === "C") { - $().SPServices.SPComplexToSimpleDropdown({ - columnName: opt.childColumn - }); - // Set the childSelect to reference the new simple dropdown - childSelect = new DropdownCtl(opt.childColumn); - } - - // Get information about the childColumn from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData, Status) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.childColumn + "']").each(function() { - // Determine whether childColumn is Required - childColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - childColumnStatic = $(this).attr("StaticName"); - // Stop looking; we're done - return false; - }); - }); - } - }); - - // Save data about each child column on the parent - var childColumn = {opt: opt, childSelect: childSelect, childColumnStatic: childColumnStatic, childColumnRequired: childColumnRequired}; - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - - // If this is the first child for this parent, then create the data object to hold the settings - if(childColumns === undefined) { - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", [childColumn]); - // If we already have a data object for this parent, then add the setting for this child to it - } else { - childColumns.push(childColumn); - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", childColumns); - thisParentSetUp = true; - } - - // We only need to bind to the event(s) if we haven't already done so - if(!thisParentSetUp) { - switch(parentSelect.Type) { - // Plain old select - case "S": - parentSelect.Obj.bind("change", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='"+ parentSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Multi-select hybrid - case "M": - // Handle the dblclick on the candidate select - parentSelect.Obj.bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle the dblclick on the selected values - parentSelections = parentSelect.Obj.closest("span").find("select[id$='SelectResult']"); - parentSelections.bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle a button click - parentSelect.Obj.closest("span").find("button").each(function() { - $(this).bind("click", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - }); - break; - default: - break; - } - } - // Fire the change to set the initially allowable values - cascadeDropdown(opt.parentColumn, parentSelect); - - }; // End $.fn.SPServices.SPCascadeDropdowns - - function cascadeDropdown(parentColumn, parentSelect) { - var choices = ""; - var parentSelectSelected; - var childSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var numChildOptions; - var firstChildOptionId; - var firstChildOptionValue; - - // Filter each child column - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - $(childColumns).each(function() { - - // Break out the data objects for this child column - var opt = this.opt; - var childSelect = this.childSelect; - var childColumnStatic = this.childColumnStatic; - var childColumnRequired = this.childColumnRequired; - - // Get the parent column selection(s) - parentSelectSelected = getDropdownSelected(parentSelect, opt.matchOnId); - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C" or "M", as there are multiple propertychanges - // which don't require any action. The attribute will be unique per child column in case there are - // multiple children for a given parent. - var allParentSelections = parentSelectSelected.join(";#"); - if(parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic) === allParentSelections) { - return; - } - parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic, allParentSelections); - - // Get the current child column selection(s) - childSelectSelected = getDropdownSelected(childSelect, true); - - // Find the important bits of the multi-select - if(childSelect.Type === "M") { - MultiLookupPickerdata = childSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[childSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - currentSelection = childSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - } - - // When the parent column's selected option changes, get the matching items from the relationship list - // Get the list items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListChildColumn; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - // Build up the criteria for inclusion - if(parentSelectSelected.length === 0) { - // Handle the case where no values are selected in multi-selects - camlQuery += ""; - } else if(parentSelectSelected.length === 1) { - // Only one value is selected - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[0]) + ""; - } else { - var compound = (parentSelectSelected.length > 2) ? true : false; - for(i=0; i < (parentSelectSelected.length - 1); i++) { - camlQuery += ""; - } - for(i=0; i < parentSelectSelected.length; i++) { - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[i]) + ""; - if(i>0 && (i < (parentSelectSelected.length - 1)) && compound) { - camlQuery += ""; - } - } - camlQuery += ""; - } - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - - // Make sure we don't get any items which don't have the child value - camlQuery += ""; - - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the child column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the currently selected parent column's value - CAMLQuery: camlQuery, - // Only get the parent and child columns - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: "FALSE", - completefunc: function(xData, Status) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var thisFunction = "SPServices.SPCascadeDropdowns"; - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListParentColumn: " + opt.relationshipListParentColumn + " or " + - "relationshipListChildColumn: " + opt.relationshipListChildColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(childSelect.Type) { - case "S": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!childColumnRequired && (opt.promptText.length > 0)) { - childSelect.Obj.append(""); - } else if(!childColumnRequired){ - childSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = childColumnRequired ? "" : opt.noneText + "|0"; - childSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - // Get the count of items returned and save it so that we can select if it's a single option - // The item count is stored thus: - numChildOptions = parseFloat($(xData.responseXML).SPFilterNode("rs:data").attr("ItemCount")); - - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOptionId, thisOptionValue; - - // If relationshipListChildColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListChildColumn); - - if(thisValue !== undefined && thisValue.indexOf(";#") > 0) { - var splitValue = thisValue.split(";#"); - thisOptionId = splitValue[0]; - thisOptionValue = splitValue[1]; - } else { - thisOptionId = $(this).attr("ows_ID"); - thisOptionValue = thisValue; - } - - // If the relationshipListChildColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOptionId should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOptionId)) { - thisOptionId = $(this).attr("ows_ID"); - } - - // Save the id and value for the first child option in case we need to select it (selectSingleOption option is true) - firstChildOptionId = thisOptionId; - firstChildOptionValue = thisOptionValue; - - switch(childSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === childSelectSelected[0]) ? " selected='selected'" : ""; - childSelect.Obj.append("" + thisOptionValue + ""); - break; - case "C": - if(thisOptionId === childSelectSelected[0]) { - childSelect.Obj.attr("value", thisOptionValue); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOptionValue + "|" + thisOptionId; - break; - case "M": - childSelect.Obj.append(""); - newMultiLookupPickerdata += thisOptionId + "|t" + thisOptionValue + "|t |t |t"; - break; - default: - break; - } - }); - - switch(childSelect.Type) { - case "S": - childSelect.Obj.trigger("change"); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - $(childSelect.Obj).find("option[value!='0']:first").attr("selected", "selected"); - } - break; - case "C": - // Set the allowable choices - childSelect.Obj.attr("choices", choices); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - // Set the input element value - $(childSelect.Obj).attr("value", firstChildOptionValue); - // Set the value of the optHid input element - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(firstChildOptionId); - } - // If there's no selection, then remove the value in the associated hidden input element (optHid) - if(childSelect.Obj.val() === "") { - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(""); - } - break; - case "M": - // Clear the master - master.data = ""; - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - - // Clear any prior selections that are no longer valid or aren't selected - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - var thisValue = $(this).html(); - $(this).attr("selected", "selected"); - $(childSelect.Obj).find("option").filter(function() { - return $(this).text() == thisValue.replace(/&/, "&"); - }).each(function() { - if($(this).html() === thisValue) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - - // Hide any options in the candidate list which are already selected - $(childSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - childSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }); // $(childColumns).each(function() - - } // End cascadeDropdown - - - // function to convert complex dropdowns to simple dropdowns - $.fn.SPServices.SPComplexToSimpleDropdown = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox("SPServices.SPComplexToSimpleDropdown", "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // If we don't have a complex dropdown, then there is nothing to do - if(columnSelect.Type !== "C") { return; } - - // The available options are stored in the choices attribute of the complex dropdowns's input element... - var choices = $(columnSelect.Obj).attr("choices").split("|"); - // The optHid attribute contains the id of a hidden input element which stores the selected value for the commit - var columnOptHid = $(columnSelect.Obj).attr("optHid"); - var columnOptHidInput = $("input[id='" + columnOptHid + "']"); - // We need to know which option is selected already, if any - var complexSelectSelectedId = $("input[id='" + columnOptHid + "']").val(); - - // Build up the simple dropdown, giving it an easy to select id - var simpleSelectId = genContainerId("SPComplexToSimpleDropdown", opt.columnName); - - var simpleSelect = ""; - - // Append the new simple select to the form - $(columnSelect.Obj).closest("td").prepend(simpleSelect); - - // Remove the complex dropdown functionality since we don't need it anymore... - $(columnSelect.Obj).closest("span").find("img").remove(); - // ...and hide the input element - $(columnSelect.Obj).closest("span").find("input").hide(); - - // When the simple select changes... - $("#" + simpleSelectId).change(function() { - var thisVal = $(this).val(); - // ...set the optHid input element's value to the valus of the selected option... - columnOptHidInput.val(thisVal); - // ...and save the selected value as the hidden input's value only if the value is not equal to "0" (None) - $(columnSelect.Obj).val($(this).find("option[value='" + (thisVal !== "0" ? thisVal : "") + "']").html()); - }); - // Trigger a change to ensure that the selected value registers in the complex dropdown - $("#" + simpleSelectId).trigger("change"); - - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - - }; // End $.fn.SPServices.SPConvertToSimpleDropdown - - - // Function to display related information when an option is selected on a form. - $.fn.SPServices.SPDisplayRelatedInfo = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - relatedWebURL: "", // [Optional] The name of the Web (site) which contains the related list - relatedList: "", // The name of the list which contains the additional information - relatedListColumn: "", // The internal name of the related column in the related list - relatedColumns: [], // An array of related columns to display - displayFormat: "table", // The format to use in displaying the related information. Possible values are: [table, list] - headerCSSClass: "ms-vh2", // CSS class for the table headers - rowCSSClass: "ms-vb", // CSS class for the table rows - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be ed with the default query on the relatedList - numChars: 0, // If used on an input column (not a dropdown), no matching will occur until at least this number of characters has been entered - matchType: "Eq", // If used on an input column (not a dropdown), type of match. Can be any valid CAML comparison operator, most often "Eq" or "BeginsWith" - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var divId; - var relatedColumnsXML = []; - var relatedListXML; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // Generate a unique id for the container - divId = genContainerId("SPDisplayRelatedInfo", opt.columnName); - - // Get information about the related list and its columns - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - completefunc: function(xData, Status) { - // If debug is on, notify about an error - $(xData.responseXML).find("faultcode").each(function() { - if(opt.debug) {errBox(thisFunction, "relatedList: " + opt.relatedList, "List not found"); return; } - }); - // Get info about the related list - relatedListXML = $(xData.responseXML).find("List"); - // Save the information about each column requested - for (i=0; i < opt.relatedColumns.length; i++) { - relatedColumnsXML[i] = $(xData.responseXML).find("Fields > Field[Name='" + opt.relatedColumns[i] + "']"); - } - } - }); - - switch(columnSelect.Type) { - // Plain old select - case "S": - columnSelect.Obj.bind("change", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='" + columnSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Multi-select hybrid - case "M": - if(opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, "Multi-select columns not supported by this function"); } - break; - default: - break; - } - // Fire the change to set the initially allowable values - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - - }; // End $.fn.SPServices.SPDisplayRelatedInfo - - function showRelated(opt, divId, relatedListXML, relatedColumnsXML) { - - var columnSelectSelected = null; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, opt.matchOnId); - if(columnSelect.Type === "C" && opt.numChars > 0 && columnSelectSelected[0].length < opt.numChars) { - return; - } - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C", as there are multiple propertychanges - // which don't require any action. - if(columnSelect.Obj.attr("showRelatedSelected") === columnSelectSelected[0]) { - return; - } - columnSelect.Obj.attr("showRelatedSelected", columnSelectSelected[0]); - - // Remove the old container... - $("#" + divId).remove(); - // ...and append a new, empty one - columnSelect.Obj.parent().append("
"); - - // Get the list items which match the current selection - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - camlQuery += "" : "'/>") + - escapeColumnValue(columnSelectSelected[0]) + ""; - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - var viewFields = " "; - for (i=0; i < opt.relatedColumns.length; i++) { - viewFields += ""; - } - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - // Filter based on the column's currently selected value - CAMLQuery: camlQuery, - CAMLViewFields: "" + viewFields + "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData, Status) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relatedListColumn: " + opt.relatedListColumn, - "Column not found in relatedList " + opt.relatedList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relatedList: " + opt.relatedList, - "List not found"); - } - return; - }); - - var outString; - // Output each row - switch(opt.displayFormat) { - // Only implementing the table format in the first iteration (v0.2.9) - case "table": - outString = ""; - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === 'undefined' && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - } - outString += ""; - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - outString += ""; - } - outString += ""; - }); - outString += "
" + relatedColumnsXML[i].attr("DisplayName") + "
" + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
"; - break; - // list format implemented in v0.5.0. Still table-based, but vertical orientation. - case "list": - outString = ""; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === 'undefined' && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - outString += ""; - outString += ""; - outString += ""; - } - }); - outString += "
" + relatedColumnsXML[i].attr("DisplayName") + "" + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
"; - break; - default: - break; - } - // Write out the results - $("#" + divId).html(outString); - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - } // End showRelated - - // Function to filter a lookup based dropdown - $.fn.SPServices.SPFilterDropdown = function(options) { - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationshipList - relationshipList: "", // The name of the list which contains the lookup values - relationshipListColumn: "", // The internal name of the column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListColumn - relationshipListSortAscending: true, // [Optional] By default, the sort is ascending. If false, descending - columnName: "", // The display name of the column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of columnName. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - CAMLQuery: "", // This CAML fragment will be applied to the relationshipList - CAMLQueryOptions: "FALSE", // Need this to mirror SharePoint's behavior, but it can be overridden - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages; if false, run silent - }, options); - - var choices = ""; - var columnSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var columnColumnRequired; - var thisFunction = "SPServices.SPFilterDropdown"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return;} - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, true); - - // Get the relationshipList items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListColumn; - var sortOrder = (opt.relationshipListSortAscending == true) ? "" : "Ascending='FALSE'"; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery; - } - camlQuery += ""; - - // Get information about columnName from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData, Status) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName is Required - columnColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - // Stop looking; we're done - return false; - }); - }); - } - }); - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the specified CAML - CAMLQuery: camlQuery, - // Only get the columnName's data (plus columns we can't prevent) - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: opt.CAMLQueryOptions, - completefunc: function(xData, Status) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListColumn: " + opt.relationshipListColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(columnSelect.Type) { - case "S": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!columnColumnRequired && (opt.promptText.length > 0)) { - columnSelect.Obj.append(""); - } else if(!columnColumnRequired){ - columnSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = columnColumnRequired ? "" : opt.noneText + "|0"; - columnSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - - // Add an option for each item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOptionId, thisOptionValue; - - // If relationshipListColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListColumn); - - if(thisValue !== undefined && thisValue.indexOf(";#") > 0) { - var splitValue = thisValue.split(";#"); - thisOptionId = splitValue[0]; - thisOptionValue = splitValue[1]; - } else { - thisOptionId = $(this).attr("ows_ID"); - thisOptionValue = thisValue; - } - - // If the relationshipListColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOptionId should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOptionId)) { - thisOptionId = $(this).attr("ows_ID"); - } - - switch(columnSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === columnSelectSelected[0]) ? " selected='selected'" : ""; - columnSelect.Obj.append("" + thisOptionValue + ""); - break; - case "C": - if(thisOptionId === columnSelectSelected[0]) { - columnSelect.Obj.attr("value", thisOptionValue); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOptionValue + "|" + thisOptionId; - break; - case "M": - columnSelect.Obj.append(""); - newMultiLookupPickerdata += thisOptionId + "|t" + thisOptionValue + "|t |t |t"; - break; - default: - break; - } - }); - - switch(columnSelect.Type) { - case "S": - columnSelect.Obj.trigger("change"); - break; - case "C": - columnSelect.Obj.attr("choices", choices); - columnSelect.Obj.trigger("propertychange"); - break; - case "M": - // Find the important bits of the multi-select - MultiLookupPickerdata = columnSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[columnSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - currentSelection = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - // Clear the master - master.data = ""; - - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - // Clear any prior selections that are no longer valid - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - $(this).attr("selected", "selected"); - $(columnSelect.Obj).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - // Hide any options in the candidate list which are already selected - $(columnSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - columnSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPFilterDropdown - - - // Utility function to show the results of a Web Service call formatted well in the browser. - $.fn.SPServices.SPDebugXMLHttpResult = function(options) { - - var opt = $.extend({}, { - node: null, // An XMLHttpResult object from an ajax call - indent: 0 // Number of indents - }, options); - - var i; - var NODE_TEXT = 3; - var NODE_CDATA_SECTION = 4; - - var outString = ""; - // For each new subnode, begin rendering a new TABLE - outString += ""; - // DisplayPatterns are a bit unique, so let's handle them differently - if(opt.node.nodeName === "DisplayPattern") { - outString += ""; - // A node which has no children - } else if (!opt.node.hasChildNodes()) { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // A CDATA_SECTION node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_CDATA_SECTION) { - outString += ""; - // A TEXT node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_TEXT) { - outString += ""; - // Handle child nodes - } else { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // Since the node has child nodes, recurse - outString += ""; - } - outString += "
" + opt.node.nodeName + - "
" + opt.node.nodeName + - "" + ((opt.node.nodeValue !== null) ? checkLink(opt.node.nodeValue) : " ") + "
" + showAttrs(opt.node, opt) + "
" + opt.node.nodeName + - "
" + opt.node.nodeName + - "" + checkLink(opt.node.firstChild.nodeValue) + "
" + opt.node.nodeName + "
" + showAttrs(opt.node, opt) + "
"; - for (i = 0;i < opt.node.childNodes.length; i++) { - outString += $().SPServices.SPDebugXMLHttpResult({ - node: opt.node.childNodes.item(i), - indent: opt.indent + 1 - }); - } - outString += "
"; - // Return the HTML which we have built up - return outString; - }; // End $.fn.SPServices.SPDebugXMLHttpResult - - // Function which returns the account name for the current user in DOMAIN\username format - $.fn.SPServices.SPGetCurrentUser = function(options) { - - var opt = $.extend({}, { - fieldName: "Name", // Specifies which field to return from the userdisp.aspx page - fieldNames: {}, // Specifies which fields to return from the userdisp.aspx page - added in v0.7.2 to allow multiple columns - debug: false // If true, show error messages; if false, run silent - }, options); - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldName === "ID" && _spUserId != undefined) { - return _spUserId; - } - - var thisField = ""; - var theseFields = {}; - var fieldCount = opt.fieldNames.length > 0 ? opt.fieldNames.length : 1; - var thisUserDisp; - - // Get the UserDisp.aspx page using AJAX - $.ajax({ - // Need this to be synchronous so we're assured of a valid value - async: false, - // Force parameter forces redirection to a page that displays the information as stored in the UserInfo table rather than My Site. - // Adding the extra Query String parameter with the current date/time forces the server to view this as a new request. - url: $().SPServices.SPGetCurrentSite() + "/_layouts/userdisp.aspx?Force=True&" + new Date().getTime(), - complete: function (xData, Status) { - thisUserDisp = xData; - } - }); - - for(i=0; i < fieldCount; i++) { - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldNames[i] === "ID") { - thisField = _spUserId; - } else { - var thisTextValue; - if(fieldCount > 1) { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldNames[i] + "\"", "gi"); - } else { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldName + "\"", "gi"); - } - $(thisUserDisp.responseText).find("table.ms-formtable td[id^='SPField']").each(function() { - if(thisTextValue.test($(this).html())) { - // Each fieldtype contains a different data type, as indicated by the id - switch($(this).attr("id")) { - case "SPFieldText": - thisField = $(this).text(); - break; - case "SPFieldNote": - thisField = $(this).find("div").html(); - break; - case "SPFieldURL": - thisField = $(this).find("img").attr("src"); - break; - // Just in case - default: - thisField = $(this).text(); - break; - } - // Stop looking; we're done - return false; - } - }); - } - if(opt.fieldNames[i] !== "ID") { - thisField = (thisField !== undefined) ? thisField.replace(/(^[\s\xA0]+|[\s\xA0]+$)/g, '') : null; - } - if(fieldCount > 1) { - theseFields[opt.fieldNames[i]] = thisField; - } - } - - return (fieldCount > 1) ? theseFields : thisField; - - }; // End $.fn.SPServices.SPGetCurrentUser - - - // Function which provides a link on a Lookup column for the user to follow - // which allows them to add a new value to the Lookup list. - // Based on http://blog.mastykarz.nl/extending-lookup-fields-add-new-item-option/ - // by Waldek Mastykarz - $.fn.SPServices.SPLookupAddNew = function(options) { - - var opt = $.extend({}, { - lookupColumn: "", // The display name of the Lookup column - promptText: "Add new {0}", // Text to use as prompt + column name - newWindow: false, // If true, the link will open in a new window *without* passing the Source. - ContentTypeID: "", // [Optional] Pass the ContentTypeID if you'd like to specify it - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var thisFunction = "SPServices.SPLookupAddNew"; - - // Find the lookup column's select (dropdown) - var lookupSelect = new DropdownCtl(opt.lookupColumn); - if(lookupSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, TXTColumnNotFound);return;} - - var newUrl = ""; - var lookupListUrl = ""; - var lookupColumnStaticName = ""; - // Use GetList for the current list to determine the details for the Lookup column - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $().SPServices.SPListNameFromUrl(), - completefunc: function (xData, Status) { - $(xData.responseXML).find("Field[DisplayName='" + opt.lookupColumn + "']").each(function() { - lookupColumnStaticName = $(this).attr("StaticName"); - // Use GetList for the Lookup column's list to determine the list's URL - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $(this).attr("List"), - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - lookupListUrl = $(this).attr("WebFullUrl"); - // Need to handle when list is in the root site - lookupListUrl = lookupListUrl !== SLASH ? lookupListUrl + SLASH : lookupListUrl; - }); - } - }); - // Get the NewItem form for the Lookup column's list - newUrl = getListFormUrl($(this).attr("List"), "NewForm"); - // Stop looking;we're done - return false; - }); - } - }); - - if(lookupListUrl.length === 0 && opt.debug) { - errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, "This column does not appear to be a lookup column"); - return; - } - if(newUrl.length > 0) { - // Build the link to the Lookup column's list enclosed in a div with the id="SPLookupAddNew_" + lookupColumnStaticName - var newHref = lookupListUrl + newUrl; - // If requested, open the link in a new window and if requested, pass the ContentTypeID - newHref += opt.newWindow ? - ((opt.ContentTypeID.length > 0) ? "?ContentTypeID=" + opt.ContentTypeID : "") + "' target='_blank'" : - "?" + ((opt.ContentTypeID.length > 0) ? "ContentTypeID=" + opt.ContentTypeID + "&" : "") + "Source=" + escapeUrl(location.href) + "'"; - newLink = "
" + " 0) { - camlQuery += ""; - } - camlQuery += "" + userId + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: camlQuery, - CAMLViewFields: "", - CAMLRowLimit: 1, - CAMLQueryOptions: "", - completefunc: function(xData, Status) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - lastId = $(this).attr("ows_ID"); - }); - } - }); - return lastId; - }; // End $.fn.SPServices.SPGetLastItemId - - // Function which checks to see if the value for a column on the form is unique in the list. - $.fn.SPServices.SPRequireUnique = function (options) { - - var opt = $.extend({}, { - columnStaticName: "Title", // Name of the column - duplicateAction: 0, // 0 = warn, 1 = prevent - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - initMsg: "This value must be unique.", // Initial message to display after setup - initMsgCSSClass: "ms-vb", // CSS class for initial message - errMsg: "This value is not unique.", // Error message to display if not unique - errMsgCSSClass: "ms-formvalidation", // CSS class for error message - showDupes: false, // If true, show links to the duplicate item(s) after the error message - completefunc: null // Function to call on completion of rendering the change. - }, options); - - // Get the current item's ID from the Query String - var queryStringVals = $().SPServices.SPGetQueryString(); - var thisID = queryStringVals.ID; - var thisList = $().SPServices.SPListNameFromUrl(); - - // Set the messages based on the options provided - var msg = "{1}
"; - var firstMsg = msg.replace(/\{0\}/g, opt.initMsgCSSClass).replace(/\{1\}/g, opt.initMsg); - - // We need the DisplayName - var columnDisplayName = $().SPServices.SPGetDisplayFromStatic({ - listName: thisList, - columnStaticName: opt.columnStaticName - }); - var columnObj = $("input[Title='" + columnDisplayName + "']"); - $(columnObj).parent().append(firstMsg); - - $(columnObj).blur(function () { - var columnValueIDs = []; - // Get the columnDisplayName's value - var columnValue = $(this).attr("value"); - if(columnValue.length === 0) { return false; } - - // Call the Lists Web Service (GetListItems) to see if the value already exists - $().SPServices({ - operation: "GetListItems", - async: false, - listName: thisList, - // Make sure we get all the items, ignoring any filters on the default view. - CAMLQuery: "", - // Filter based on columnStaticName's value - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData, Status) { - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = opt.ignoreCase ? $(this).attr("ows_" + opt.columnStaticName).toUpperCase() : $(this).attr("ows_" + opt.columnStaticName); - // If this value already exists in columnStaticName and it's not the current item, then save the ID in the array - if((testValue === thisValue) && ($(this).attr("ows_ID") !== thisID)) { - columnValueIDs.push([$(this).attr("ows_ID"), $(this).attr("ows_" + opt.columnStaticName)]); - } - }); - } - }); - var newMsg = opt.initMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.initMsgCSSClass); - - $("input[value='OK']:disabled, input[value='Save']:disabled").removeAttr("disabled"); - if(columnValueIDs.length > 0) { - newMsg = opt.errMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.errMsgCSSClass); - if(opt.duplicateAction === 1) { - $("input[Title='" + opt.columnDisplayName + "']").focus(); - $("input[value='OK'], input[value='Save']").attr("disabled", "disabled"); - } - if(opt.showDupes) { - var out = " " + columnValueIDs.length + " duplicate item" + (columnValueIDs.length > 1 ? "s" : "") + ": "; - for (i=0;i < columnValueIDs.length; i++) { - out += "
" + columnValueIDs[i][1] + " "; - } - $("span#SPRequireUnique" + opt.columnStaticName).append(out); - } - } - - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPRequireUnique - - // This function returns the DisplayName for a column based on the StaticName. - $.fn.SPServices.SPGetDisplayFromStatic = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnStaticName: "", // StaticName of the column - columnStaticNames: {} // StaticName of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var displayName = ""; - var displayNames = {}; - var nameCount = opt.columnStaticNames.length > 0 ? opt.columnStaticNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData, Status) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - displayNames[opt.columnStaticNames[i]] = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticNames[i] + "']").attr("DisplayName"); - } - } else { - displayName = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticName + "']").attr("DisplayName"); - } - } - }); - - return (nameCount > 1) ? displayNames : displayName; - - }; // End $.fn.SPServices.SPGetDisplayFromStatic - - // This function returns the StaticName for a column based on the DisplayName. - $.fn.SPServices.SPGetStaticFromDisplay = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnDisplayName: "", // DisplayName of the column - columnDisplayNames: {} // DisplayNames of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var staticName = ""; - var staticNames = {}; - var nameCount = opt.columnDisplayNames.length > 0 ? opt.columnDisplayNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData, Status) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - staticNames[opt.columnDisplayNames[i]] = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayNames[i] + "']").attr("StaticName"); - } - } else { - staticName = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayName + "']").attr("StaticName"); - } - } - }); - - return (nameCount > 1) ? staticNames : staticName; - - }; // End $.fn.SPServices.SPGetStaticFromDisplay - - // This function allows you to redirect to a another page from a new item form with the new - // item's ID. This allows chaining of forms from item creation onward. - $.fn.SPServices.SPRedirectWithID = function (options) { - - var opt = $.extend({}, { - redirectUrl: "", // Page for the redirect - qsParamName: "ID" // In some cases, you may want to pass the newly created item's ID with a different - // parameter name than ID. Specify that name here, if needed. - }, options); - - var thisList = $().SPServices.SPListNameFromUrl(); - var queryStringVals = $().SPServices.SPGetQueryString(); - var lastID = queryStringVals.ID; - var QSList = queryStringVals.List; - var QSRootFolder = queryStringVals.RootFolder; - var QSContentTypeId = queryStringVals.ContentTypeId; - - // On first load, change the form actions to redirect back to this page with the current lastID for this user and the - // original Source. - if(typeof queryStringVals.ID === 'undefined') { - lastID = $().SPServices.SPGetLastItemId({ - listName: thisList - }); - $("form[name='aspnetForm']").each(function() { - // This page... - var thisUrl = (location.href.indexOf("?") > 0) ? location.href.substring(0, location.href.indexOf("?")) : location.href; - // ... plus the Source if it exists - var thisSource = (typeof queryStringVals.Source === "string") ? - "Source=" + queryStringVals.Source.replace(/\//g, "%2f").replace(/:/g, "%3a") : ""; - - var newQS = []; - if(typeof QSList !== 'undefined') { - newQS.push("List=" + QSList); - } - if(typeof QSRootFolder !== 'undefined') { - newQS.push("RootFolder=" + QSRootFolder); - } - if(typeof QSContentTypeId !== 'undefined') { - newQS.push("ContentTypeId=" + QSContentTypeId); - } - - var newAction = thisUrl + - ((newQS.length > 0) ? ("?" + newQS.join("&") + "&") : "?") + - // Set the Source to point back to this page with the lastID this user has added - "Source=" + thisUrl + - "?ID=" + lastID + - // Pass the original source as RealSource, if present - ((thisSource.length > 0) ? ("%26RealSource=" + queryStringVals.Source) : "") + - // Pass the override RedirectURL, if present - ((typeof queryStringVals.RedirectURL === "string") ? ("%26RedirectURL=" + queryStringVals.RedirectURL) : ""); - $(this).attr("action", newAction); - }); - // If this is the load after the item is saved, wait until the new item has been saved (commits are asynchronous), - // then do the redirect to redirectUrl with the new lastID, passing along the original Source. - } else { - while(queryStringVals.ID === lastID) { - lastID = $().SPServices.SPGetLastItemId({ - listName: thisList - }); - } - // If there is a RedirectURL parameter on the Query String, then redirect there instead of the value - // specified in the options (opt.redirectUrl) - var thisRedirectUrl = (typeof queryStringVals.RedirectURL === "string") ? queryStringVals.RedirectURL : opt.redirectUrl; - location.href = thisRedirectUrl + "?" + opt.qsParamName + "=" + lastID + - ((typeof queryStringVals.RealSource === "string") ? ("&Source=" + queryStringVals.RealSource) : ""); - } - }; // End $.fn.SPServices.SPRedirectWithID - - // The SPSetMultiSelectSizes function sets the sizes of the multi-select boxes for a column on a form automagically - // based on the values they contain. The function takes into account the fontSize, fontFamily, fontWeight, etc., in its algorithm. - $.fn.SPServices.SPSetMultiSelectSizes = function (options) { - - var opt = $.extend({}, { - multiSelectColumn: "", - minWidth: 0, - maxWidth: 0, - debug: false - }, options); - - var thisFunction = "SPServices.SPSetMultiSelectSizes"; - - // Find the multi-select column - var thisMultiSelect = new DropdownCtl(opt.multiSelectColumn); - if(thisMultiSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, TXTColumnNotFound);return;} - if(thisMultiSelect.Type !== "M" && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, "Column is not multi-select.");return;} - - var possibleValues = thisMultiSelect.Obj; - var selectedValues = possibleValues.closest("span").find("select[ID$='SelectResult']"); - - // Create a temporary clone of the select to use to determine the appropriate width settings. - // We'll append it to the end of the enclosing span. - var cloneId = genContainerId("SPSetMultiSelectSizes", opt.multiSelectColumn); - possibleValues.clone().appendTo(possibleValues.closest("span")).css({ - "width": "auto", // We want the clone to resize its width based on the contents - "height": 0, // Just to keep the page clean while we are using the clone - "visibility": "hidden" // And let's keep it hidden - }).attr({ - id: cloneId, // We don't want the clone to have the same id as its source - length: 0 // And let's start with no options - }); - var cloneObj = $("#" + cloneId); - - // Add all the values to the cloned select. First the left (possible values) select... - possibleValues.find("option").each(function() { - cloneObj.append(""); - }); - // ...then the right (selected values) select (in case some values have already been selected) - selectedValues.find("option").each(function() { - cloneObj.append(""); - }); - - // We'll add 5px for a little padding on the right. - var divWidth = $("#" + cloneId).width() + 5; - var newDivWidth = divWidth; - if(opt.minWidth > 0 || opt.maxWidth > 0) { - if(divWidth < opt.minWidth) { - divWidth = opt.minWidth; - } - if(newDivWidth < opt.minWidth) { - newDivWidth = opt.minWidth; - } - if(newDivWidth > opt.maxWidth) { - newDivWidth = opt.maxWidth; - } - } - var selectWidth = divWidth; - - // Set the new widths - possibleValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - selectedValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - - // Remove the select's clone, since we're done with it - $("#" + cloneId).remove(); - }; // End $.fn.SPServices.SPSetMultiSelectSizes - - // Does an audit of a site's list forms to show where script is in use. - $.fn.SPServices.SPScriptAudit = function (options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] The name of the Web (site) to audit - listName: "", // [Optional] The name of a specific list to audit. If not present, all lists in the site are audited. - outputId: "", // The id of the DOM object for output - auditForms: true, // Audit the form pages - auditViews: true, // Audit the view pages - auditPages: true, // Audit the Pages Document Library - auditPagesListName: "Pages", // The Pages Document Library(ies), if desired. Either a single string or an array of strings. - showHiddenLists: false, // Show output for hidden lists - showNoScript: false, // Show output for lists with no scripts (effectively "verbose") - showSrc: true // Show the source location for included scripts - }, options); - - var formTypes = [["New", "NewForm.aspx", false], ["Display", "DispForm.aspx", false], ["Edit", "EditForm.aspx", false]]; - var listXml; - - // Build the table to contain the results - $("#" + opt.outputId) - .append("" + - "" + - "" + - "" + - "" + - "" + - "" + - (opt.showSrc ? "" : "") + - "" + - "
ListPage ClassPage TypePageScript References
"); - // Apply the CSS class to the headers - $("#SPScriptAudit th").attr("class", "ms-vh2-nofilter"); - - // Don't bother with the lists if the options don't require them - if(opt.auditForms || opt.auditViews) { - // First, get all of the lists within the site - $().SPServices({ - operation: "GetListCollection", - webURL: opt.webURL, - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - - // If listName has been specified, then only return results for that list - if((opt.listName.length === 0) || (listXml.attr("Title") === opt.listName)) { - // Don't work with hidden lists unless we're asked to - if((opt.showHiddenLists && listXml.attr("Hidden") === "False") || !opt.showHiddenLists) { - - // Audit the list's forms - if(opt.auditForms) { - // Get the list's Content Types, therefore the form pages - $().SPServices({ - operation: "GetListContentTypes", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("ContentType").each(function() { - // Don't deal with folders - if($(this).attr("ID").substring(0,6) !== "0x0120") { - var formUrls = $(this).find("FormUrls"); - for(i=0; i < formTypes.length; i++) { - // Look for a customized form... - $(formUrls).find(formTypes[i][0]).each(function() { - SPScriptAuditPage(opt, listXml, "Form", this.nodeName, - ((opt.webURL.length > 0) ? opt.webURL : $().SPServices.SPGetCurrentSite()) + SLASH + $(this).text()); - formTypes[i][2] = true; - }); - // ...else the uncustomized form - if(!formTypes[i][2]) { - var defaultViewUrl = listXml.attr("DefaultViewUrl"); - SPScriptAuditPage(opt, listXml, "Form", formTypes[i][0], - defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH)+1) + formTypes[i][1]); - } - } - // Reset the form types - for(i=0; i < formTypes.length; i++) { - formTypes[i][2] = false; - } - } - }); - } - }); - } - - // Audit the list's views - if(opt.auditViews) { - // Get the list's Views - $().SPServices({ - operation: "GetViewCollection", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("View").each(function() { - SPScriptAuditPage(opt, listXml, "View", $(this).attr("DisplayName"), $(this).attr("Url")); - }); - } - }); - } - - } - } - }); - } - }); - } - - // Don't bother with auditing pages if the options don't require it - var numLists = 0; - var listsArray = []; - if(typeof opt.auditPagesListName === "string") { - numLists = 1; - listsArray.push(opt.auditPagesListName); - } else { - numLists = opt.auditPagesListName.length; - listsArray = opt.auditPagesListName; - } - - if(opt.auditPages) { - for(i=0; i < numLists; i++) { - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: listsArray[i], - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - }); - } - }); - // Get all of the items from the Document Library - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: listsArray[i], - CAMLQuery: "Folder", - CAMLViewFields: "", - CAMLRowLimit: 0, - completefunc: function(xData, Status) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisPageUrl = $(this).attr("ows_FileRef").split(";#")[1]; - var thisPageType = (typeof $(this).attr("ows_Title") !== 'undefined') ? $(this).attr("ows_Title") : ""; - if(thisPageUrl.indexOf(".aspx") > 0) { - SPScriptAuditPage(opt, listXml, "Page", thisPageType, SLASH + thisPageUrl); - } - }); - } - }); - } - } - // Remove progress indicator and make the output pretty by cleaning up the ms-alternating CSS class - $("#SPScriptAudit tr[class='ms-alternating']:even").removeAttr("class"); - }; // End $.fn.SPServices.SPScriptAudit - - // Displays the usage of scripts in a site - function SPScriptAuditPage(opt, listXml, pageClass, pageType, pageUrl) { - - var i = 0; - var jQueryPage = 0; - var pageScriptSrc = {}; - pageScriptSrc.type = []; - pageScriptSrc.src = []; - pageScriptSrc.script = []; - var scriptRegex = RegExp("", "gi"); - - // Fetch the page - $.ajax({ - type: "GET", - url: pageUrl, - dataType: "text", - async: false, - success: function(xData) { - - while (scriptMatch = scriptRegex.exec(xData)) { - var scriptLanguage = getScriptAttribute(scriptMatch, "language"); - var scriptType = getScriptAttribute(scriptMatch, "type"); - var scriptSrc = getScriptAttribute(scriptMatch, "src"); - if(scriptSrc !== null && scriptSrc.length > 0 && !coreScript(scriptSrc)) { - pageScriptSrc.type.push((scriptLanguage !== null && scriptLanguage.length > 0) ? scriptLanguage : scriptType); - pageScriptSrc.src.push(scriptSrc); - jQueryPage++; - } - } - - // Only show pages without script if we've been asked to do so. - if((!opt.showNoScript && (pageScriptSrc.type.length > 0)) || opt.showNoScript) { - var pagePath = pageUrl.substring(0, pageUrl.lastIndexOf(SLASH)+1); - var out = "" + - "" + - "" + listXml.attr("Title") + ((listXml.attr("Hidden") === "True") ? '(Hidden)' : '')+ "" + - "" + pageClass + "" + - "" + pageType + "" + - "" + fileName(pageUrl) + ""; - if(opt.showSrc) { - var thisSrcPath; - out += ""; - for(i=0; i < pageScriptSrc.type.length; i++) { - thisSrcPath = (pageScriptSrc.src[i].substr(0,1) !== SLASH) ? pagePath + pageScriptSrc.src[i] : pageScriptSrc.src[i]; - out += ""; - out += ""; - } - out += "
" + pageScriptSrc.type[i] + "" + fileName(pageScriptSrc.src[i]) + "
"; - } - $("#SPScriptAudit").append(out); - } - } - }); - } // End of function SPScriptAuditPage - - function getScriptAttribute(source, attribute) { - var regex = RegExp(attribute + "=(\"([^\"]*)\")|('([^']*)')", "gi"); - if(matches = regex.exec(source)) { - return matches[2]; - } - return null; - } // End of function getScriptAttribute - - // Check to see if the script reference is part of SharePoint core so that we can ignore it - function coreScript(src) { - var i; - var coreScriptLocations = ["WebResource.axd", "_layouts"]; - for(i=0; i < coreScriptLocations.length; i++) { - if(src.indexOf(coreScriptLocations[i]) > -1) { - return true; - } - } - return false; - } // End of function coreScript - - // Rearrange radio buttons or checkboxes in a form from vertical to horizontal display to save page real estate - $.fn.SPServices.SPArrangeChoices = function (options) { - - var opt = $.extend({}, { - listName: "", // The list name for the current form - columnName: "", // The display name of the column in the form - perRow: 99, // Maximum number of choices desired per row. - randomize: false // If true, randomize the order of the options - }, options); - - var columnFillInChoice = false; - var columnOptions = []; - var out; - - // Get information about columnName from the list to determine if we're allowing fill-in choices - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: (opt.listName.length > 0) ? opt.listName : $().SPServices.SPListNameFromUrl(), - completefunc: function(xData, Status) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName allows a fill-in choice - columnFillInChoice = ($(this).attr("FillInChoice") === "TRUE") ? true : false; - // Stop looking;we're done - return false; - }); - }); - } - }); - - var thisFormField = findFormField(opt.columnName); - - var totalChoices = $(thisFormField).find("tr").length; - var choiceNumber = 0; - var fillinPrompt; - var fillinInput; - // Collect all of the choices - $(thisFormField).find("tr").each(function() { - choiceNumber++; - // If this is the fill-in prompt, save it... - if(columnFillInChoice && choiceNumber === (totalChoices - 1)) { - fillinPrompt = $(this).find("td").html(); - // ...or if it is the fill-in input box, save it... - } else if(columnFillInChoice && choiceNumber === totalChoices) { - fillinInput = $(this).find("td").html(); - // ...else push into the columnOptions array. - } else { - columnOptions.push($(this).html()); - } - }); - out = ""; - - // If randomize is true, randomly sort the options - if(opt.randomize) { - columnOptions.sort(randOrd); - } - - // Add all of the options to the out string - for(i=0; i < columnOptions.length; i++) { - out += columnOptions[i]; - // If we've already got perRow columnOptions in the row, close off the row - if((i+1) % opt.perRow === 0) { - out += ""; - } - } - out += ""; - - // If we are allowing a fill-in choice, add that option in a separate row at the bottom - if(columnFillInChoice) { - out += "" + fillinPrompt + fillinInput + ""; - } - - // Remove the existing rows... - $(thisFormField).find("tr").remove(); - // ...and append the out string - $(thisFormField).find("table").append(out); - - }; // End $.fn.SPServices.SPArrangeChoices - - // Provide suggested values from a list for in input column based on characters typed - $.fn.SPServices.SPAutocomplete = function (options) { - - var opt = $.extend({}, { - WebURL: "", // [Optional] The name of the Web (site) which contains the sourceList - sourceList: "", // The name of the list which contains the values - sourceColumn: "", // The static name of the column which contains the values - columnName: "", // The display name of the column in the form - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relatedList - CAMLQueryOptions: "", // [Optional] For power users, allows specifying the CAMLQueryOptions for the GetListItems call - CAMLRowLimit: 0, // [Optional] Override the default view rowlimit and get all appropriate rows - filterType: "BeginsWith", // Type of filtering: [BeginsWith, Contains] - numChars: 0, // Wait until this number of characters has been typed before attempting any actions - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - highlightClass: "", // If a class is supplied, highlight the matched characters in the values by applying that class to a wrapping span - uniqueVals: false, // If set to true, the function only adds unique values to the list (no duplicates) - maxHeight: 99999, // Sets the maximum number of values to display before scrolling occurs - slideDownSpeed: "fast", // Speed at which the div should slide down when values match (milliseconds or ["fast" | "slow"]) - processingIndicator: "_layouts/images/REFRESH.GIF", // If present, show this while processing - debug: false // If true, show error messages;if false, run silent - }, options); - - var matchNum; - - // Find the input control for the column and save some of its attributes - var columnObj = $("input[Title='" + opt.columnName + "']"); - $("input[Title='" + opt.columnName + "']").css("position", ""); - var columnObjId = columnObj.attr("ID"); - var columnObjColor = columnObj.css("color"); - var columnObjWidth = columnObj.css("width"); - - if(columnObj.html() === null && opt.debug) { - errBox("SPServices.SPAutocomplete", - "columnName: " + opt.columnName, - "Column is not an input control or is not found on page"); - return; - } - - // Remove the
which isn't needed and messes up the formatting - columnObj.closest("span").find("br").remove(); - columnObj.wrap("
"); - - // Create a div to contain the matching values and add it to the DOM - var containerId = genContainerId("SPAutocomplete", opt.columnName); - columnObj.after("
"); - - // Set the width to match the width of the input control - $("#" + containerId).css("width", columnObjWidth); - - // Handle keypresses - $(columnObj).keyup(function () { - - // Get the column's value - var columnValue = $(this).val(); - - // Hide the container while we're working on it - $("#" + containerId).hide(); - - // Have enough characters been typed yet? - if(columnValue.length < opt.numChars) { - return false; - } - - // Show the the processingIndicator as a background image in the input element - columnObj.css({ - "background-image": "url(" + opt.processingIndicator + ")", - "background-position": "right", - "background-repeat": "no-repeat" - }); - - // Array to hold the matched values - var matchArray = []; - - // Build the appropriate CAMLQuery - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - camlQuery += "<" + opt.filterType + ">" + columnValue + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - // Call GetListItems to find all of the potential values - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.WebURL, - listName: opt.sourceList, - CAMLQuery: camlQuery, - CAMLQueryOptions: opt.CAMLQueryOptions, - CAMLViewFields: "", - CAMLRowLimit: opt.CAMLRowLimit, - completefunc: function(xData, Status) { - // Handle upper/lower case if ignoreCase = true - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - // See which values match and add the ones that do to matchArray - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = $(this).attr("ows_" + opt.sourceColumn); - var thisValueTest = opt.ignoreCase ? $(this).attr("ows_" + opt.sourceColumn).toUpperCase() : $(this).attr("ows_" + opt.sourceColumn); - // Make sure we have a match... - if(opt.filterType === "Contains") { - var firstMatch = thisValueTest.indexOf(testValue); - if((firstMatch >= 0) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } else { - // Handles normal case, which is BeginsWith and and other unknown values - if(testValue === thisValueTest.substr(0,testValue.length) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } - }); - } - }); - - // Build out the set of list elements to contain the available values - var out = ""; - for (i=0; i < matchArray.length; i++) { - // If a highlightClass has been supplied, wrap a span around each match - if(opt.highlightClass.length > 0) { - // Set up Regex based on whether we want to ignore case - var thisRegex = RegExp(columnValue, opt.ignoreCase ? "gi" : "g"); - // Look for all occurrences - var matches = matchArray[i].match(thisRegex); - var startLoc = 0; - // Loop for each occurrence, wrapping each in a span with the highlightClass CSS class - for (matchNum=0; matchNum < matches.length; matchNum++) { - var thisPos = matchArray[i].indexOf(matches[matchNum], startLoc); - var endPos = thisPos + matches[matchNum].length; - var thisSpan = "" + matches[matchNum] + ""; - matchArray[i] = matchArray[i].substr(0, thisPos) + thisSpan + matchArray[i].substr(endPos); - startLoc = thisPos + thisSpan.length; - } - } - // Add the value to the markup for the container - out += "
  • " + matchArray[i] + "
  • "; - } - - // Add all the list elements to the containerId container - $("#" + containerId).html(out); - // Set up hehavior for the available values in the list element - $("#" + containerId + " li").click(function () { - $("#" + containerId).fadeOut(opt.slideUpSpeed); - $("#" + columnObjId).val($(this).text()); - }).mouseover(function () { - var mouseoverCss = { - "cursor": "hand", - "color": "#ffffff", - "background": "#3399ff" - }; - $(this).css(mouseoverCss); - }).mouseout(function () { - var mouseoutCss = { - "cursor": "inherit", - "color": columnObjColor, - "background": "transparent" - }; - $(this).css(mouseoutCss); - }); - - // If we've got some values to show, then show 'em! - if(matchArray.length > 0) { - $("#" + containerId).slideDown(opt.slideDownSpeed); - } - // Remove the processing indicator - columnObj.css("background-image", ""); - }); - - }; // End $.fn.SPServices.SPAutocomplete - - // Get the Query String parameters and their values and return in an array - $.fn.SPServices.SPGetQueryString = function () { - - var i; - var queryStringVals = {}; - - var qs = location.search.substring(1, location.search.length); - var args = qs.split("&"); - var rxQS = /^([^=]+)=(.*)/i; - - for (i=0; i < args.length; i++) { - matches = rxQS.exec(args[i]); - if (rxQS.test(location.href)) { - if (matches !== null && matches.length > 2) { - queryStringVals[matches[1]] = unescape(matches[2]).replace(/\+/g,' '); - } - } - } - return queryStringVals; - - }; // End $.fn.SPServices.SPGetQueryString - - // Get the current list's GUID (ID) from the current URL. Use of this function only makes sense if we're in a list's context, - // and we assume that we are calling it from an aspx page which is a form or view for the list. - $.fn.SPServices.SPListNameFromUrl = function (options) { - - var opt = $.extend({}, { - listName: "" // [Optional] Pass in the name or GUID of a list if you are not in its context. e.g., on a Web Part pages in the Pages library - }, options); - - // Has the name or GUID been passed in? - if(opt.listName.length > 0) { - thisList = opt.listName; - return thisList; - // Do we already know the current list? - } else if(thisList.length > 0) { - return thisList; - } - - // Parse out the list's root URL from the current location or the passed url - var thisPage = location.href; - var thisPageBaseName = thisPage.substring(0, thisPage.indexOf(".aspx")); - var listPath = decodeURIComponent(thisPageBaseName.substring(0, thisPageBaseName.lastIndexOf(SLASH) + 1)).toUpperCase(); - - // Call GetListCollection and loop through the results to find a match with the list's URL to get the list's GUID - $().SPServices({ - operation: "GetListCollection", - async: false, - completefunc: function(xData, Status) { - $(xData.responseXML).find("List").each(function() { - var defaultViewUrl = $(this).attr("DefaultViewUrl"); - var listCollList = defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH) + 1).toUpperCase(); - if(listPath.indexOf(listCollList) > 0) { - thisList = $(this).attr("ID"); - return false; - } - }); - } - }); - - // Return the GUID (ID) - return thisList; - }; // End $.fn.SPServices.SPListNameFromUrl - - // SPUpdateMultipleListItems allows you to update multiple items in a list based upon some common characteristic or metadata criteria. - $.fn.SPServices.SPUpdateMultipleListItems = function(options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] URL of the target Web. If not specified, the current Web is used. - listName: "", // The list to operate on. - CAMLQuery: "", // A CAML fragment specifying which items in the list will be selected and updated - batchCmd: "Update", // The operation to perform. By default, Update. - valuepairs: [], // Valuepairs for the update in the form [[fieldname1, fieldvalue1], [fieldname2, fieldvalue2]...] - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var i; - var itemsToUpdate = []; - var documentsToUpdate = []; - - // Call GetListItems to find all of the items matching the CAMLQuery - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: opt.CAMLQuery, - CAMLQueryOptions: "", - completefunc: function(xData, Status) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - itemsToUpdate.push($(this).attr("ows_ID")); - var fileRef = $(this).attr("ows_FileRef"); - fileRef = "/" + fileRef.substring(fileRef.indexOf(";#")+2); - documentsToUpdate.push(fileRef); - }); - } - }); - - var fieldNum; - var batch = ""; - for(i=0; i < itemsToUpdate.length; i++) { - batch += ""; - for (fieldNum=0; fieldNum < opt.valuepairs.length; fieldNum++) { - batch += "" + escapeColumnValue(opt.valuepairs[fieldNum][1]) + ""; - } - batch += "" + itemsToUpdate[i] + ""; - if(documentsToUpdate[i].length > 0) { - batch += "" + documentsToUpdate[i] + ""; - } - batch += ""; - } - batch += ""; - - // Call UpdateListItems to update all of the items matching the CAMLQuery - $().SPServices({ - operation: "UpdateListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - updates: batch, - completefunc: function(xData, Status) { - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(xData, Status); - } - } - }); - - }; // End $.fn.SPServices.SPUpdateMultipleListItems - - // This method for finding specific nodes in the returned XML was developed by Steve Workman. See his blog post - // http://www.steveworkman.com/html5-2/javascript/2011/improving-javascript-xml-node-finding-performance-by-2000/ - // for performance details. - $.fn.SPFilterNode = function(name) { - return this.find('*').filter(function() { - return this.nodeName === name; - }); - }; // End $.fn.SPFilterNode - - - // This function converts an XML node set to JSON - // Initial implementation focuses only on GetListItems - $.fn.SPXmlToJson = function(options) { - - var opt = $.extend({}, { - mapping: {}, // columnName: mappedName: "mappedName", objectType: "objectType" - includeAllAttrs: false, // If true, return all attributes, regardless whether they are in the mapping - removeOws: true // Specifically for GetListItems, if true, the leading ows_ will be stripped off the field name - }, options); - - var colNum; - var jsonObject = []; - - this.each(function() { - var row = {}; - var colValue; - var rowAttrs = this.attributes; - - // Bring back all mapped columns, even those with no value - $.each(opt.mapping, function() { - row[this.mappedName] = ""; - }); - - // Parse through the element's attributes - for(attrNum = 0; attrNum < rowAttrs.length; attrNum++) { - var thisAttrName = rowAttrs[attrNum].name; - var thisMapping = opt.mapping[thisAttrName]; - var thisObjectName = thisMapping !== undefined ? thisMapping.mappedName : opt.removeOws ? thisAttrName.split("ows_")[1] : thisAttrName; - var thisObjectType = thisMapping !== undefined ? thisMapping.objectType : undefined; - if(opt.includeAllAttrs || thisMapping !== undefined) { - row[thisObjectName] = attrToJson(rowAttrs[attrNum].value, thisObjectType); - } - } - // Push this item into the JSON Object - jsonObject.push(row); - - }); - - // Return the JSON object - return jsonObject; - - }; // End $.fn.SPServices.SPXmlToJson - - - function attrToJson(v, objectType) { - - switch (objectType) { - case "DateTime": - case "datetime": // For calculated columns, stored as datetime;#value - // Dates have dashes instead of slashes: ows_Created="2009-08-25 14:24:48" - colValue = dateToJsonObject(v); - break; - case "User": - colValue = userToJsonObject(v); - break; - case "UserMulti": - colValue = userMultiToJsonObject(v); - break; - case "Lookup": - colValue = lookupToJsonObject(v); - break; - case "LookupMulti": - colValue = lookupMultiToJsonObject(v); - break; - case "Boolean": - colValue = booleanToJsonObject(v); - break; - case "Integer": - colValue = intToJsonObject(v); - break; - case "Counter": - colValue = intToJsonObject(v); - break; - case "MultiChoice": - colValue = choiceMultiToJsonObject(v); - break; - case "Currency": - case "float": // For calculated columns, stored as float;#value - colValue = floatToJsonObject(v); - break; - case "Calc": - colValue = calcToJsonObject(v); - break; - default: - // All other objectTypes will be simple strings - colValue = stringToJsonObject(v); - break; - } - return colValue; - } - - function stringToJsonObject(s) { - return s; - } - function intToJsonObject(s) { - return parseInt(s, 10); - } - function floatToJsonObject(s) { - return parseFloat(s); - } - function booleanToJsonObject(s) { - var out = s === "0" ? false : true; - return out; - } - function dateToJsonObject(s) { - return new Date(s.replace(/-/g, "/")); - } - function userToJsonObject(s) { - if (s.length === 0) { - return null; - } else { - var thisUser = s.split(";#"); - var thisUserExpanded = thisUser[1].split(",#"); - if(thisUserExpanded.length == 1) { - return {userId: thisUser[0], userName: thisUser[1]}; - } else { - return { - userId: thisUser[0], - userName: thisUserExpanded[0].replace( /(,,)/g, ","), - loginName: thisUserExpanded[1].replace( /(,,)/g, ","), - email: thisUserExpanded[2].replace( /(,,)/g, ","), - sipAddress: thisUserExpanded[3].replace( /(,,)/g, ","), - title: thisUserExpanded[4].replace( /(,,)/g, ",") - }; - } - } - } - function userMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisUserMultiObject = []; - var thisUserMulti = s.split(";#"); - for(i=0; i < thisUserMulti.length; i=i+2) { - var thisUser = userToJsonObject(thisUserMulti[i] + ";#" + thisUserMulti[i+1]); - thisUserMultiObject.push(thisUser); - } - return thisUserMultiObject; - } - } - function lookupToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookup = s.split(";#"); - return {lookupId: thisLookup[0], lookupValue: thisLookup[1]}; - } - } - function lookupMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookupMultiObject = []; - var thisLookupMulti = s.split(";#"); - for(i=0; i < thisLookupMulti.length; i=i+2) { - var thisLookup = lookupToJsonObject(thisLookupMulti[i] + ";#" + thisLookupMulti[i+1]); - thisLookupMultiObject.push(thisLookup); - } - return thisLookupMultiObject; - } - } - function choiceMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisChoiceMultiObject = []; - var thisChoiceMulti = s.split(";#"); - for(i=0; i < thisChoiceMulti.length; i++) { - if(thisChoiceMulti[i].length !== 0) { - thisChoiceMultiObject.push(thisChoiceMulti[i]); - } - } - return thisChoiceMultiObject; - } - } - function calcToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisCalc = s.split(";#"); - // The first value will be the calculated column value type, the second will be the value - return attrToJson(thisCalc[1], thisCalc[0]); - } - } - - // Find a People Picker in the page - // Returns references to: - // row - The TR which contains the People Picker (useful if you'd like to hide it at some point) - // contents - The element which contains the current value - // currentValue - The current value if it is set - // checkNames - The Check Names image (in case you'd like to click it at some point) - $.fn.SPFindPeoplePicker = function(options) { - - var opt = $.extend({}, { - peoplePickerDisplayName: "", // The displayName of the People Picker on the form - valueToSet: "", // The value to set the People Picker to. Should be a string containing each username or groupname separated by semi-colons. - checkNames: true // If set to true, the Check Names image will be clicked to resolve the names - }, options); - - var thisRow = $("nobr").filter(function() { - // Ensures we get a match whether or not the People Picker is required (if required, the nobr contains a span also) - return $(this).contents().eq(0).text() === opt.peoplePickerDisplayName; - }).closest("tr"); - - var thisContents = thisRow.find("div[name='upLevelDiv']"); - var thisCheckNames = thisRow.find("img[Title='Check Names']:first"); - - // If a value was provided, set the value - if(opt.valueToSet.length > 0) { - thisContents.html(opt.valueToSet); - } - - // If checkName is true, click the check names icon - if(opt.checkNames) { - thisCheckNames.click(); - } - var thisCurrentValue = $.trim(thisContents.text()); - - // Parse the entity data - var dictionaryEntries = []; - - // IE - thisContents.children("span").each(function() { - - // Grab the entity data - var thisData = $(this).find("div[data]").attr("data"); - - var dictionaryEntry = {}; - - // Entity data is only available in IE - if(thisData != undefined) { - var arrayOfDictionaryEntry = $.parseXML(thisData); - $xml = $(arrayOfDictionaryEntry); - - $xml.find("DictionaryEntry").each(function() { - var key = $(this).find("Key").text(); - var value = $(this).find("Value").text(); - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - // For other browsers, we'll call GetUserInfo to get the data - } else { - $().SPServices({ - operation: "GetUserInfo", - async: false, - cacheXML: true, - userLoginName: $(this).attr("title"), - completefunc: function(xData, Status) { - - $(xData.responseXML).find("User").each(function() { - - $.each(this.attributes, function(i, attrib){ - var key = attrib.name; - var value = attrib.value; - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - }); - } - }); - } - }); - - return {row: thisRow, contents: thisContents, currentValue: thisCurrentValue, checkNames: thisCheckNames, dictionaryEntries: dictionaryEntries}; - }; - - // Return the current version of SPServices as a string - $.fn.SPServices.Version = function () { - - return VERSION; - - }; // End $.fn.SPServices.Version - - - -////// PRIVATE FUNCTIONS //////// - - // Display a column (field) formatted correctly based on its definition in the list. - // NOTE: Currently not dealing with locale differences. - // columnXML The XML node for the column from a GetList operation - // columnValue The text representation of the column's value - // opt The current set of options - function showColumn(listXML, columnXML, columnValue, opt) { - - if(typeof columnValue === 'undefined') { - return ""; - } - - var i; - var outString = ""; - var dispUrl; - var numDecimals; - var outArray =[]; - var webUrl = opt.relatedWebURL.length > 0 ? opt.relatedWebURL : $().SPServices.SPGetCurrentSite(); - - switch(columnXML.attr("Type")) { - case "Text": - outString = columnValue; - break; - case "URL": - switch(columnXML.attr("Format")) { - // URL as hyperlink - case "Hyperlink": - outString = "
    " + - columnValue.substring(columnValue.search(",") + 1) + ""; - break; - // URL as image - case "Image": - outString = "" + columnValue.substring(columnValue.search(",") + 1) +
-							""; - break; - // Just in case - default: - outString = columnValue; - break; - } - break; - case "User": - case "UserMulti": - var userMultiValues = columnValue.split(";#"); - for(i=0; i < userMultiValues.length; i = i+2) { - outArray.push("" + - userMultiValues[i+1] + ""); - } - outString = outArray.join(", "); - break; - case "Calculated": - var calcColumn = columnValue.split(";#"); - outString = calcColumn[1]; - break; - case "Number": - numDecimals = columnXML.attr("Decimals"); - outString = numDecimals === undefined ? - parseFloat(columnValue).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Currency": - numDecimals = columnXML.attr("Decimals"); - outString = numDecimals === undefined ? - parseFloat(columnValue).toFixed(2).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Lookup": - switch(columnXML.attr("Name")) { - case "FileRef": - // Get the display form URL for the lookup source list - dispUrl = listXML.attr("BaseType") === "1" ? listXML.attr("RootFolder") + SLASH + "Forms/DispForm.aspx" : - listXML.attr("RootFolder") + SLASH + "DispForm.aspx"; - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - case "FileDirRef": - // Get the display form URL for the lookup source list - dispUrl = SLASH + columnValue.substring(columnValue.search(";#") + 2); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - // Any other lookup column - default: - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - } - break; - case "LookupMulti": - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - // Show all the values as links to the items, separated by commas - outString = ""; - if(columnValue.length > 0) { - var lookupMultiValues = columnValue.split(";#"); - for(i=0; i < lookupMultiValues.length / 2; i++) { - outArray.push("" + - lookupMultiValues[(i * 2) + 1] + ""); - } - } - outString = outArray.join(", "); - break; - case "File": - fileName = columnValue.substring(columnValue.search(";#") + 2); - outString = "" + fileName + ""; - break; - case "Counter": - outString = columnValue; - break; - case "DateTime": - outString = columnValue; - break; - default: - outString = columnValue; - break; - } - return outString; - } // End of function showColumn - - // Show a single attribute of a node, enclosed in a table - // node The XML node - // opt The current set of options - function showAttrs(node, opt) { - var i; - var out = ""; - for (i=0; i < node.attributes.length; i++) { - out += ""; - } - out += "
    " + i + "" + - node.attributes.item(i).nodeName + "" + checkLink(node.attributes.item(i).nodeValue) + "
    "; - return out; - } // End of function showAttrs - - // Find a dropdown (or multi-select) in the DOM. Returns the dropdown onject and its type: - // S = Simple (select);C = Compound (input + select hybrid);M = Multi-select (select hybrid) - function DropdownCtl(colName) { - // Simple - if((this.Obj = $("select[Title='" + colName + "']")).length === 1) { - this.Type = "S"; - // Compound - } else if((this.Obj = $("input[Title='" + colName + "']")).length === 1) { - this.Type = "C"; - // Multi-select: This will find the multi-select column control in English and most other languages sites where the Title looks like 'Column Name possible values' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title^='" + colName + " ']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Russian site (and perhaps others) where the Title looks like 'Выбранных значений: Column Name' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=': " + colName + "']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a German site (and perhaps others) where the Title looks like 'Mögliche Werte für "Column name".' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$='\"" + colName + "\".']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Italian site (and perhaps others) where the Title looks like "Valori possibili Column name" - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=' " + colName + "']")).length === 1) { - this.Type = "M"; - } else { - this.Type = null; - } - } // End of function DropdownCtl - - // Returns the selected value(s) for a dropdown in an array. Expects a dropdown object as returned by the DropdownCtl function. - // If matchOnId is true, returns the ids rather than the text values for the selection options(s). - function getDropdownSelected(columnSelect, matchOnId) { - - var columnSelectSelected = []; - - switch(columnSelect.Type) { - case "S": - if(matchOnId) { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").text() || []); - } - break; - case "C": - if(matchOnId) { - columnSelectSelected.push($("input[id='"+ columnSelect.Obj.attr("optHid") + "']").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.attr("value") || []); - } - break; - case "M": - var columnSelections = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - $(columnSelections).find("option").each(function() { - columnSelectSelected.push($(this).html()); - }); - break; - default: - break; - } - return columnSelectSelected; - - } // End of function getDropdownSelected - - // Build an error message based on passed parameters - function errBox(func, param, msg) { - var errMsg = "Error in function
    " + func + "
    " + - "Parameter
    " + param + "
    " + - "Message
    " + msg + "

    " + - "Click to continue
    "; - modalBox(errMsg); - } // End of function errBox - - // Call this function to pop up a branded modal msgBox - function modalBox(msg) { - var boxCSS = "position:absolute;width:300px;height:150px;padding:10px;background-color:#000000;color:#ffffff;z-index:30;font-family:'Arial';font-size:12px;display:none;"; - $("#aspnetForm").parent().append("
    " + msg); - var height = $("#SPServices_msgBox").height(); - var width = $("#SPServices_msgBox").width(); - var leftVal = ($(window).width() / 2) - (width / 2) + "px"; - var topVal = ($(window).height() / 2) - (height / 2) - 100 + "px"; - $("#SPServices_msgBox").css({border:'5px #C02000 solid', left:leftVal, top:topVal}).show().fadeTo("slow", 0.75).click(function () { - $(this).fadeOut("3000", function () { - $(this).remove(); - }); - }); - } // End of function modalBox - - // Generate a unique id for a containing div using the function name and the column display name - function genContainerId(funcname, columnName) { - return funcname + "_" + $().SPServices.SPGetStaticFromDisplay({ - listName: $().SPServices.SPListNameFromUrl(), - columnDisplayName: columnName - }); - } // End of function genContainerId - - // Get the URL for a specified form for a list - function getListFormUrl(l, f) { - - var thisForm, u; - - $().SPServices({ - operation: "GetFormCollection", - async: false, - listName: l, - completefunc: function (xData, Status) { - u = $(xData.responseXML).find("Form[Type='" + f + "']").attr("Url");; - } - }); - return u; - - } // End of function getListFormUrl - - // Add the option values to the SOAPEnvelope.payload for the operation - // opt = options for the call - // paramArray = an array of option names to add to the payload - // "paramName" if the parameter name and the option name match - // ["paramName", "optionName"] if the parameter name and the option name are different (this handles early "wrappings" with inconsistent naming) - function addToPayload(opt, paramArray) { - - var i; - - for (i=0; i < paramArray.length; i++) { - // the parameter name and the option name match - if(typeof paramArray[i] === "string") { - SOAPEnvelope.payload += wrapNode(paramArray[i], opt[paramArray[i]]); - // the parameter name and the option name are different - } else if(paramArray[i].length === 2) { - SOAPEnvelope.payload += wrapNode(paramArray[i][0], opt[paramArray[i][1]]); - // something isn't right, so report it - } else { - errBox(opt.operation, "paramArray[" + i + "]: " + paramArray[i], "Invalid paramArray element passed to addToPayload()"); - } - } - } // End of function addToPayload - - // Finds the td which contains a form field in default forms using the comment which contains: - // - // as the "anchor" to find it. Necessary because SharePoint doesn't give all field types ids or specific classes. - function findFormField(columnName) { - var thisFormBody; - // There's no easy way to find one of these columns; we'll look for the comment with the columnName - var searchText = RegExp("FieldName=\"" + columnName.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&") + "\"", "gi"); - // Loop through all of the ms-formbody table cells - $("td.ms-formbody, td.ms-formbodysurvey").each(function() { - // Check for the right comment - if(searchText.test($(this).html())) { - thisFormBody = $(this); - // Found it, so we're done - return false; - } - }); - return thisFormBody; - } // End of function findFormField - - // The SiteData operations have the same names as other Web Service operations. To make them easy to call and unique, I'm using - // the SiteData prefix on their names. This function replaces that name with the right name in the SOAPEnvelope. - function siteDataFixSOAPEnvelope(SOAPEnvelope, siteDataOperation) { - var siteDataOp = siteDataOperation.substring(8); - SOAPEnvelope.opheader = SOAPEnvelope.opheader.replace(siteDataOperation, siteDataOp); - SOAPEnvelope.opfooter = SOAPEnvelope.opfooter.replace(siteDataOperation, siteDataOp); - return SOAPEnvelope; - } // End of function siteDataFixSOAPEnvelope - - // Wrap an XML node (n) around a value (v) - function wrapNode(n, v) { - var thisValue = v !== undefined ? v : ""; - return "<" + n + ">" + thisValue + ""; - } - - // Generate a random number for sorting arrays randomly - function randOrd() { - return (Math.round(Math.random())-0.5); - } - - // If a string is a URL, format it as a link, else return the string as-is - function checkLink(s) { - return ((s.indexOf("http") === 0) || (s.indexOf(SLASH) === 0)) ? "" + s + "" : s; - } - - // Get the filename from the full URL - function fileName(s) { - return s.substring(s.lastIndexOf(SLASH)+1,s.length); - } - - // Escape string characters - function escapeHTML(s) { - return s.replace(/&/g,'&').replace(/"/g,'"').replace(//g,'>'); - } - - // Escape column values - function escapeColumnValue(s) { - if(typeof s === "string") { - return s.replace(/&(?![a-zA-Z]{1,8};)/g, "&"); - } else { - return s; - } - } - - // Escape Url - function escapeUrl(u) { - return u.replace(/&/g,'%26'); - } - - // Split values like 1;#value into id and value - function SplitIndex(s) { - var spl = s.split(";#"); - this.id = spl[0]; - this.value = spl[1]; - } - - -})(jQuery); \ No newline at end of file diff --git a/jquery.SPServices-2013.01ALPHA2.js b/jquery.SPServices-2013.01ALPHA2.js deleted file mode 100644 index 22dcc31..0000000 --- a/jquery.SPServices-2013.01ALPHA2.js +++ /dev/null @@ -1,4040 +0,0 @@ -/* - * SPServices - Work with SharePoint's Web Services using jQuery - * Version 0.7.3 -> Note to Marc: Also change var VERSION below. - * @requires jQuery v1.4.2 or greater - jQuery 1.7+ recommended - * - * Copyright (c) 2009-2012 Sympraxis Consulting LLC - * Examples and docs at: - * http://spservices.codeplex.com - * Licensed under the MIT license: - * http://www.opensource.org/licenses/mit-license.php - */ -/** - * @description Work with SharePoint's Web Services using jQuery - * @type jQuery - * @name SPServices - * @category Plugins/SPServices - * @author Sympraxis Consulting LLC/marc.anderson@sympraxisconsulting.com - */ - - - -(function ($) { - - "use strict"; - - // Version info - var VERSION = "0.7.3"; - - // String constants - // General - var SLASH = "/"; - var TXTColumnNotFound = "Column not found on page"; - var SCHEMASharePoint = "http://schemas.microsoft.com/sharepoint"; - - // Web Service names - var ALERTS = "Alerts"; - var AUTHENTICATION = "Authentication"; - var COPY = "Copy"; - var FORMS = "Forms"; - var LISTS = "Lists"; - var MEETINGS = "Meetings"; - var PEOPLE = "People"; - var PERMISSIONS = "Permissions"; - var PUBLISHEDLINKSSERVICE = "PublishedLinksService"; - var SEARCH = "Search"; - var SHAREPOINTDIAGNOSTICS = "SharePointDiagnostics"; - var SITEDATA = "SiteData"; - var SITES = "Sites"; - var SOCIALDATASERVICE = "SocialDataService"; - var SPELLCHECK = "SpellCheck"; - var TAXONOMYSERVICE = "TaxonomyClientService"; - var USERGROUP = "usergroup"; - var USERPROFILESERVICE = "UserProfileService"; - var VERSIONS = "Versions"; - var VIEWS = "Views"; - var WEBPARTPAGES = "WebPartPages"; - var WEBS = "Webs"; - var WORKFLOW = "Workflow"; - - // Global variables - var currentContext = new SPServicesContext(); // Variable to hold the current context as we figure it out - var i = 0; // Generic loop counter - var t = ""; // Temporary string variable - var encodeOptionList = ["listName", "description"]; // Used to encode options which may contain special characters - - - // Array to store Web Service information - // WSops.OpName = [WebService, needs_SOAPAction]; - // OpName The name of the Web Service operation -> These names are unique - // WebService The name of the WebService this operation belongs to - // needs_SOAPAction Boolean indicating whether the operatio needs to have the SOAPAction passed in the setRequestHeaderfunction. - // true if the operation does a write, else false - - var WSops = []; - - WSops.GetAlerts = [ALERTS, false]; - WSops.DeleteAlerts = [ALERTS, true]; - - WSops.Mode = [AUTHENTICATION, false]; - WSops.Login = [AUTHENTICATION, false]; - - WSops.CopyIntoItems = [COPY, true]; - WSops.CopyIntoItemsLocal = [COPY, true]; - WSops.GetItem = [COPY, false]; - - WSops.GetForm = [FORMS, false]; - WSops.GetFormCollection = [FORMS, false]; - - WSops.AddAttachment = [LISTS, true]; - WSops.AddDiscussionBoardItem = [LISTS, true]; - WSops.AddList = [LISTS, true]; - WSops.AddListFromFeature = [LISTS, true]; - WSops.ApplyContentTypeToList = [LISTS, true]; - WSops.CheckInFile = [LISTS, true]; - WSops.CheckOutFile = [LISTS, true]; - WSops.CreateContentType = [LISTS, true]; - WSops.DeleteAttachment = [LISTS, true]; - WSops.DeleteContentType = [LISTS, true]; - WSops.DeleteContentTypeXmlDocument = [LISTS, true]; - WSops.DeleteList = [LISTS, true]; - WSops.GetAttachmentCollection = [LISTS, false]; - WSops.GetList = [LISTS, false]; - WSops.GetListAndView = [LISTS, false]; - WSops.GetListCollection = [LISTS, false]; - WSops.GetListContentType = [LISTS, false]; - WSops.GetListContentTypes = [LISTS, false]; - WSops.GetListItemChanges = [LISTS, false]; - WSops.GetListItemChangesSinceToken = [LISTS, false]; - WSops.GetListItems = [LISTS, false]; - WSops.GetVersionCollection = [LISTS, false]; - WSops.UndoCheckOut = [LISTS, true]; - WSops.UpdateContentType = [LISTS, true]; - WSops.UpdateContentTypesXmlDocument = [LISTS, true]; - WSops.UpdateContentTypeXmlDocument = [LISTS, true]; - WSops.UpdateList = [LISTS, true]; - WSops.UpdateListItems = [LISTS, true]; - - WSops.AddMeeting = [MEETINGS, true]; - WSops.CreateWorkspace = [MEETINGS, true]; - WSops.RemoveMeeting = [MEETINGS, true]; - WSops.SetWorkSpaceTitle = [MEETINGS, true]; - - WSops.ResolvePrincipals = [PEOPLE, false]; - WSops.SearchPrincipals = [PEOPLE, false]; - - WSops.AddPermission = [PERMISSIONS, true]; - WSops.AddPermissionCollection = [PERMISSIONS, true]; - WSops.GetPermissionCollection = [PERMISSIONS, true]; - WSops.RemovePermission = [PERMISSIONS, true]; - WSops.RemovePermissionCollection = [PERMISSIONS, true]; - WSops.UpdatePermission = [PERMISSIONS, true]; - - WSops.GetLinks = [PUBLISHEDLINKSSERVICE, true]; - - WSops.GetPortalSearchInfo = [SEARCH, false]; - WSops.GetQuerySuggestions = [SEARCH, false]; - WSops.GetSearchMetadata = [SEARCH, false]; - WSops.Query = [SEARCH, false]; - WSops.QueryEx = [SEARCH, false]; - WSops.Registration = [SEARCH, false]; - WSops.Status = [SEARCH, false]; - - WSops.SendClientScriptErrorReport = [SHAREPOINTDIAGNOSTICS,true]; - - WSops.GetAttachments = [SITEDATA, false]; - WSops.EnumerateFolder = [SITEDATA, false]; - WSops.SiteDataGetList = [SITEDATA, false]; - WSops.SiteDataGetListCollection = [SITEDATA, false]; - WSops.SiteDataGetSite = [SITEDATA, false]; - WSops.SiteDataGetSiteUrl = [SITEDATA, false]; - WSops.SiteDataGetWeb = [SITEDATA, false]; - - WSops.CreateWeb = [SITES, true]; - WSops.DeleteWeb = [SITES, false]; - WSops.GetSite = [SITES, false]; - WSops.GetSiteTemplates = [SITES, false]; - - WSops.AddComment = [SOCIALDATASERVICE, true]; - WSops.AddTag = [SOCIALDATASERVICE, true]; - WSops.AddTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.CountCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountTagsOfUser = [SOCIALDATASERVICE, false]; - WSops.DeleteComment = [SOCIALDATASERVICE, true]; - WSops.DeleteRating = [SOCIALDATASERVICE, true]; - WSops.DeleteTag = [SOCIALDATASERVICE, true]; - WSops.DeleteTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.DeleteTags = [SOCIALDATASERVICE, true]; - WSops.GetAllTagTerms = [SOCIALDATASERVICE, false]; - WSops.GetAllTagTermsForUrlFolder = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrls = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrlsByKeyword = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingAverageOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetSocialDataForFullReplication = [SOCIALDATASERVICE, false]; - WSops.GetTags = [SOCIALDATASERVICE, true]; - WSops.GetTagsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTerms = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOnUrl = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUserByKeyword = [SOCIALDATASERVICE, true]; - WSops.GetTagUrls = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsByKeyword = [SOCIALDATASERVICE, true]; - WSops.SetRating = [SOCIALDATASERVICE, true]; - WSops.UpdateComment = [SOCIALDATASERVICE, true]; - - WSops.SpellCheck = [SPELLCHECK, false]; - - // Taxonomy Service Calls - // Updated 2011.01.27 by Thomas McMillan - WSops.AddTerms = [TAXONOMYSERVICE, true]; - WSops.GetChildTermsInTerm = [TAXONOMYSERVICE, false]; - WSops.GetChildTermsInTermSet = [TAXONOMYSERVICE, false]; - WSops.GetKeywordTermsByGuids = [TAXONOMYSERVICE, false]; - WSops.GetTermsByLabel = [TAXONOMYSERVICE, false]; - WSops.GetTermSets = [TAXONOMYSERVICE, false]; - - WSops.AddGroup = [USERGROUP, true]; - WSops.AddGroupToRole = [USERGROUP, true]; - WSops.AddRole = [USERGROUP, true]; - WSops.AddRoleDef = [USERGROUP, true]; - WSops.AddUserCollectionToGroup = [USERGROUP, true]; - WSops.AddUserCollectionToRole = [USERGROUP, true]; - WSops.AddUserToGroup = [USERGROUP, true]; - WSops.AddUserToRole = [USERGROUP, true]; - WSops.GetAllUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupCollection = [USERGROUP, false]; - WSops.GetGroupCollectionFromRole = [USERGROUP, false]; - WSops.GetGroupCollectionFromSite = [USERGROUP, false]; - WSops.GetGroupCollectionFromUser = [USERGROUP, false]; - WSops.GetGroupCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupInfo = [USERGROUP, false]; - WSops.GetRoleCollection = [USERGROUP, false]; - WSops.GetRoleCollectionFromGroup = [USERGROUP, false]; - WSops.GetRoleCollectionFromUser = [USERGROUP, false]; - WSops.GetRoleCollectionFromWeb = [USERGROUP, false]; - WSops.GetRoleInfo = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForCurrentUser = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForSite = [USERGROUP, false]; - WSops.GetUserCollection = [USERGROUP, false]; - WSops.GetUserCollectionFromGroup = [USERGROUP, false]; - WSops.GetUserCollectionFromRole = [USERGROUP, false]; - WSops.GetUserCollectionFromSite = [USERGROUP, false]; - WSops.GetUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetUserInfo = [USERGROUP, false]; - WSops.GetUserLoginFromEmail = [USERGROUP, false]; - WSops.RemoveGroup = [USERGROUP, true]; - WSops.RemoveGroupFromRole = [USERGROUP, true]; - WSops.RemoveRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromGroup = [USERGROUP, true]; - WSops.RemoveUserCollectionFromRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromSite = [USERGROUP, true]; - WSops.RemoveUserFromGroup = [USERGROUP, true]; - WSops.RemoveUserFromRole = [USERGROUP, true]; - WSops.RemoveUserFromSite = [USERGROUP, true]; - WSops.RemoveUserFromWeb = [USERGROUP, true]; - WSops.UpdateGroupInfo = [USERGROUP, true]; - WSops.UpdateRoleDefInfo = [USERGROUP, true]; - WSops.UpdateRoleInfo = [USERGROUP, true]; - WSops.UpdateUserInfo = [USERGROUP, true]; - - WSops.AddColleague = [USERPROFILESERVICE, true]; - WSops.AddLink = [USERPROFILESERVICE, true]; - WSops.AddMembership = [USERPROFILESERVICE, true]; - WSops.AddPinnedLink = [USERPROFILESERVICE, true]; - WSops.CreateMemberGroup = [USERPROFILESERVICE, true]; - WSops.CreateUserProfileByAccountName = [USERPROFILESERVICE, true]; - WSops.GetCommonColleagues = [USERPROFILESERVICE, false]; - WSops.GetCommonManager = [USERPROFILESERVICE, false]; - WSops.GetCommonMemberships = [USERPROFILESERVICE, false]; - WSops.GetInCommon = [USERPROFILESERVICE, false]; - WSops.GetPropertyChoiceList = [USERPROFILESERVICE, false]; - WSops.GetUserColleagues = [USERPROFILESERVICE, false]; - WSops.GetUserLinks = [USERPROFILESERVICE, false]; - WSops.GetUserMemberships = [USERPROFILESERVICE, false]; - WSops.GetUserPinnedLinks = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByGuid = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByIndex = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByName = [USERPROFILESERVICE, false]; - WSops.GetUserProfileCount = [USERPROFILESERVICE, false]; - WSops.GetUserProfileSchema = [USERPROFILESERVICE, false]; - WSops.ModifyUserPropertyByAccountName = [USERPROFILESERVICE, true]; - WSops.RemoveAllColleagues = [USERPROFILESERVICE, true]; - WSops.RemoveAllLinks = [USERPROFILESERVICE, true]; - WSops.RemoveAllMemberships = [USERPROFILESERVICE, true]; - WSops.RemoveAllPinnedLinks = [USERPROFILESERVICE, true]; - WSops.RemoveColleague = [USERPROFILESERVICE, true]; - WSops.RemoveLink = [USERPROFILESERVICE, true]; - WSops.RemoveMembership = [USERPROFILESERVICE, true]; - WSops.RemovePinnedLink = [USERPROFILESERVICE, true]; - WSops.UpdateColleaguePrivacy = [USERPROFILESERVICE, true]; - WSops.UpdateLink = [USERPROFILESERVICE, true]; - WSops.UpdateMembershipPrivacy = [USERPROFILESERVICE, true]; - WSops.UpdatePinnedLink = [USERPROFILESERVICE, true]; - - WSops.DeleteAllVersions = [VERSIONS, true]; - WSops.DeleteVersion = [VERSIONS, true]; - WSops.GetVersions = [VERSIONS, false]; - WSops.RestoreVersion = [VERSIONS, true]; - - WSops.AddView = [VIEWS, true]; - WSops.DeleteView = [VIEWS, true]; - WSops.GetView = [VIEWS, false]; - WSops.GetViewHtml = [VIEWS, false]; - WSops.GetViewCollection = [VIEWS, false]; - WSops.UpdateView = [VIEWS, true]; - WSops.UpdateViewHtml = [VIEWS, true]; - - WSops.AddWebPart = [WEBPARTPAGES, true]; - WSops.AddWebPartToZone = [WEBPARTPAGES, true]; - WSops.GetWebPart2 = [WEBPARTPAGES, false]; - WSops.GetWebPartPage = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties2 = [WEBPARTPAGES, false]; - - WSops.CreateContentType = [WEBS, true]; - WSops.GetColumns = [WEBS, false]; - WSops.GetContentType = [WEBS, false]; - WSops.GetContentTypes = [WEBS, false]; - WSops.GetCustomizedPageStatus = [WEBS, false]; - WSops.GetListTemplates = [WEBS, false]; - WSops.GetObjectIdFromUrl = [WEBS, false]; // 2010 - WSops.GetWeb = [WEBS, false]; - WSops.GetWebCollection = [WEBS, false]; - WSops.GetAllSubWebCollection = [WEBS, false]; - WSops.UpdateColumns = [WEBS, true]; - WSops.UpdateContentType = [WEBS, true]; - WSops.WebUrlFromPageUrl = [WEBS, false]; - - WSops.AlterToDo = [WORKFLOW, true]; - WSops.GetTemplatesForItem = [WORKFLOW, false]; - WSops.GetToDosForItem = [WORKFLOW, false]; - WSops.GetWorkflowDataForItem = [WORKFLOW, false]; - WSops.GetWorkflowTaskData = [WORKFLOW, false]; - WSops.StartWorkflow = [WORKFLOW, true]; - - // Set up SOAP envelope - var SOAPEnvelope = {}; - SOAPEnvelope.header = ""; - SOAPEnvelope.footer = ""; - SOAPEnvelope.payload = ""; - var SOAPAction; - - - // Main function, which calls SharePoint's Web Services directly. - $.fn.SPServices = function(options) { - - // If there are no options passed in, use the defaults. Extend replaces each default with the passed option. - var opt = $.extend({}, $.fn.SPServices.defaults, options); - - // Encode options which may contain special character, esp. ampersand - for(var i=0; i < encodeOptionList.length; i++) { - if(typeof opt[encodeOptionList[i]] === "string") { - opt[encodeOptionList[i]] = encodeXml(opt[encodeOptionList[i]]); - } - } - - // Put together operation header and SOAPAction for the SOAP call based on which Web Service we're calling - SOAPEnvelope.opheader = "<" + opt.operation + " "; - switch(WSops[opt.operation][0]) { - case ALERTS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/2002/1/alerts/' >"; - SOAPAction = SCHEMASharePoint + "/soap/2002/1/alerts/"; - break; - case MEETINGS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/meetings/' >"; - SOAPAction = SCHEMASharePoint + "/soap/meetings/"; - break; - case PERMISSIONS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case PUBLISHEDLINKSSERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/"; - break; - case SEARCH: - SOAPEnvelope.opheader += "xmlns='urn:Microsoft.Search' >"; - SOAPAction = "urn:Microsoft.Search/"; - break; - case SHAREPOINTDIAGNOSTICS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/diagnostics/' >"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/diagnostics/"; - break; - case SOCIALDATASERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/SocialDataService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/SocialDataService/"; - break; - case SPELLCHECK: - SOAPEnvelope.opheader += "xmlns='http://schemas.microsoft.com/sharepoint/publishing/spelling/'"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/publishing/spelling/SpellCheck"; - break; - case TAXONOMYSERVICE: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/taxonomy/soap/' >"; - SOAPAction = SCHEMASharePoint + "/taxonomy/soap/"; - break; - case USERGROUP: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case USERPROFILESERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/UserProfileService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/UserProfileService/"; - break; - case WEBPARTPAGES: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/sharepoint/webpartpages' >"; - SOAPAction = "http://microsoft.com/sharepoint/webpartpages/"; - break; - case WORKFLOW: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/workflow/' >"; - SOAPAction = SCHEMASharePoint + "/soap/workflow/"; - break; - default: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/'>"; - SOAPAction = SCHEMASharePoint + "/soap/"; - break; - } - - // Add the operation to the SOAPAction and opfooter - SOAPAction += opt.operation; - SOAPEnvelope.opfooter = ""; - - // Build the URL for the Ajax call based on which operation we're calling - // If the webURL has been provided, then use it, else use the current site - var ajaxURL = "_vti_bin/" + WSops[opt.operation][0] + ".asmx"; - if(opt.webURL.charAt(opt.webURL.length - 1) === SLASH) { - ajaxURL = opt.webURL + ajaxURL; - } else if(opt.webURL.length > 0) { - ajaxURL = opt.webURL + SLASH + ajaxURL; - } else { - ajaxURL = $().SPServices.SPGetCurrentSite() + SLASH + ajaxURL; - } - - SOAPEnvelope.payload = ""; - // Each operation requires a different set of values. This switch statement sets them up in the SOAPEnvelope.payload. - switch(opt.operation) { - // ALERT OPERATIONS - case "GetAlerts": - break; - case "DeleteAlerts": - SOAPEnvelope.payload += ""; - for (i=0; i < opt.IDs.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.IDs[i]); - } - SOAPEnvelope.payload += ""; - break; - - // AUTHENTICATION OPERATIONS - case "Mode": - break; - case "Login": - addToPayload(opt, ["username", "password"]); - break; - - // COPY OPERATIONS - case "CopyIntoItems": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - addToPayload(opt, ["Fields", "Stream", "Results"]); - break; - case "CopyIntoItemsLocal": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - break; - case "GetItem": - addToPayload(opt, ["Url", "Fields", "Stream"]); - break; - - // FORM OPERATIONS - case "GetForm": - addToPayload(opt, ["listName", "formUrl"]); - break; - case "GetFormCollection": - addToPayload(opt, ["listName"]); - break; - - // LIST OPERATIONS - case "AddAttachment": - addToPayload(opt, ["listName", "listItemID", "fileName", "attachment"]); - break; - case "AddDiscussionBoardItem": - addToPayload(opt, ["listName", "message"]); - break; - case "AddList": - addToPayload(opt, ["listName", "description", "templateID"]); - break; - case "AddListFromFeature": - addToPayload(opt, ["listName", "description", "featureID", "templateID"]); - break; - case "ApplyContentTypeToList": - addToPayload(opt, ["webUrl", "contentTypeId", "listName"]); - break; - case "CheckInFile": - addToPayload(opt, ["pageUrl", "comment", "CheckinType"]); - break; - case "CheckOutFile": - addToPayload(opt, ["pageUrl", "checkoutToLocal", "lastmodified"]); - break; - case "CreateContentType": - addToPayload(opt, ["listName", "displayName", "parentType", "fields", "contentTypeProperties", "addToView"]); - break; - case "DeleteAttachment": - addToPayload(opt, ["listName", "listItemID", "url"]); - break; - case "DeleteContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "DeleteContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "documentUri"]); - break; - case "DeleteList": - addToPayload(opt, ["listName"]); - break; - case "GetAttachmentCollection": - addToPayload(opt, ["listName", ["listItemID", "ID"]]); - break; - case "GetList": - addToPayload(opt, ["listName"]); - break; - case "GetListAndView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetListCollection": - break; - case "GetListContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "GetListContentTypes": - addToPayload(opt, ["listName"]); - break; - case "GetListItems": - addToPayload(opt, ["listName", "viewName", ["query", "CAMLQuery"], ["viewFields", "CAMLViewFields"], ["rowLimit", "CAMLRowLimit"], ["queryOptions", "CAMLQueryOptions"]]); - break; - case "GetListItemChanges": - addToPayload(opt, ["listName", "viewFields", "since", "contains"]); - break; - case "GetListItemChangesSinceToken": - addToPayload(opt, ["listName", "viewName", "query", "viewFields", "rowLimit", "queryOptions", "changeToken", "contains"]); - break; - case "GetVersionCollection": - addToPayload(opt, ["strlistID", "strlistItemID", "strFieldName"]); - break; - case "UndoCheckOut": - addToPayload(opt, ["pageUrl"]); - break; - case "UpdateContentType": - addToPayload(opt, ["listName", "contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields", "addToView"]); - break; - case "UpdateContentTypesXmlDocument": - addToPayload(opt, ["listName", "newDocument"]); - break; - case "UpdateContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "newDocument"]); - break; - case "UpdateList": - addToPayload(opt, ["listName", "listProperties", "newFields", "updateFields", "deleteFields", "listVersion"]); - break; - case "UpdateListItems": - addToPayload(opt, ["listName"]); - if(opt.updates !== undefined && opt.updates.length > 0) { - addToPayload(opt, ["updates"]); - } else { - SOAPEnvelope.payload += ""; - for (i=0; i < opt.valuepairs.length; i++) { - SOAPEnvelope.payload += "" + escapeColumnValue(opt.valuepairs[i][1]) + ""; - } - if(opt.batchCmd !== "New") { - SOAPEnvelope.payload += "" + opt.ID + ""; - } - SOAPEnvelope.payload += ""; - } - break; - - // MEETINGS OPERATIONS - case "AddMeeting": - addToPayload(opt, ["organizerEmail", "uid", "sequence", "utcDateStamp", "title", "location", "utcDateStart", "utcDateEnd", "nonGregorian"]); - break; - case "CreateWorkspace": - addToPayload(opt, ["title", "templateName", "lcid", "timeZoneInformation"]); - break; - case "RemoveMeeting": - addToPayload(opt, ["recurrenceId", "uid", "sequence", "utcDateStamp", "cancelMeeting"]); - break; - case "SetWorkspaceTitle": - addToPayload(opt, ["title"]); - break; - - // PEOPLE OPERATIONS - case "ResolvePrincipals": - addToPayload(opt, ["principalKeys", "principalType", "addToUserInfoList"]); - break; - case "SearchPrincipals": - addToPayload(opt, ["searchText", "maxResults", "principalType"]); - break; - - // PERMISSION OPERATIONS - case "AddPermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - case "AddPermissionCollection": - addToPayload(opt, ["objectName", "objectType", "permissionsInfoXml"]); - break; - case "GetPermissionCollection": - addToPayload(opt, ["objectName", "objectType"]); - break; - case "RemovePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType"]); - break; - case "RemovePermissionCollection": - addToPayload(opt, ["objectName", "objectType", "memberIdsXml"]); - break; - case "UpdatePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - - // PUBLISHEDLINKSSERVICE OPERATIONS - case "GetLinks": - break; - - // SEARCH OPERATIONS - case "GetPortalSearchInfo": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "GetQuerySuggestions": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "GetSearchMetadata": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "Query": - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "QueryEx": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "Registration": - SOAPEnvelope.payload += wrapNode("registrationXml", encodeXml(opt.registrationXml)); - break; - case "Status": - break; - - // SHAREPOINTDIAGNOSTICS OPERATIONS - case "SendClientScriptErrorReport": - addToPayload(opt, ["message", "file", "line", "client", "stack", "team", "originalFile"]); - break; - - // SITEDATA OPERATIONS - case "EnumerateFolder": - addToPayload(opt, ["strFolderUrl"]); - break; - case "GetAttachments": - addToPayload(opt, ["strListName", "strItemId"]); - break; - case "SiteDataGetList": - addToPayload(opt, ["strListName"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetListCollection": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSite": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSiteUrl": - addToPayload(opt, ["Url"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetWeb": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - - // SITES OPERATIONS - case "CreateWeb": - addToPayload(opt, ["url", "title", "description", "templateName", "language", "languageSpecified", - "locale", "localeSpecified", "collationLocale", "collationLocaleSpecified", "uniquePermissions", - "uniquePermissionsSpecified", "anonymous", "anonymousSpecified", "presence", "presenceSpecified"]); - break; - case "DeleteWeb": - addToPayload(opt, ["url"]); - break; - case "GetSite": - addToPayload(opt, ["SiteUrl"]); - break; - case "GetSiteTemplates": - addToPayload(opt, ["LCID", "TemplateList"]); - break; - - // SOCIALDATASERVICE OPERATIONS - case "AddComment": - addToPayload(opt, ["url", "comment", "isHighPriority", "title"]); - break; - case "AddTag": - addToPayload(opt, ["url", "termID", "title", "isPrivate"]); - break; - case "AddTagByKeyword": - addToPayload(opt, ["url", "keyword", "title", "isPrivate"]); - break; - case "CountCommentsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "CountCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "CountCommentsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountTagsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "DeleteComment": - addToPayload(opt, ["url", "lastModifiedTime"]); - break; - case "DeleteRating": - addToPayload(opt, ["url"]); - break; - case "DeleteTag": - addToPayload(opt, ["url", "termID"]); - break; - case "DeleteTagByKeyword": - addToPayload(opt, ["url", "keyword"]); - break; - case "DeleteTags": - addToPayload(opt, ["url"]); - break; - case "GetAllTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetAllTagTermsForUrlFolder": - addToPayload(opt, ["urlFolder", "maximumItemsToReturn"]); - break; - case "GetAllTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetAllTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetCommentsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetCommentsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn", "startIndex"]); - if(opt.excludeItemsTime !== undefined && opt.excludeItemsTime.length > 0) { - SOAPEnvelope.payload += wrapNode("excludeItemsTime", opt.excludeItemsTime); - } - break; - case "GetRatingAverageOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetRatingOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "GetRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetSocialDataForFullReplication": - addToPayload(opt, ["userAccountName"]); - break; - case "GetTags": - addToPayload(opt, ["url"]); - break; - case "GetTagsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetTagTermsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn"]); - break; - case "GetTagTermsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn"]); - break; - case "GetTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetTagUrlsOfUser": - addToPayload(opt, ["termID", "userAccountName"]); - break; - case "GetTagUrlsOfUserByKeyword": - addToPayload(opt, ["keyword", "userAccountName"]); - break; - case "SetRating": - addToPayload(opt, ["url", "rating", "title", "analysisDataEntry"]); - break; - case "UpdateComment": - addToPayload(opt, ["url", "lastModifiedTime", "comment", "isHighPriority"]); - break; - - // SPELLCHECK OPERATIONS - case "SpellCheck": - addToPayload(opt, ["chunksToSpell", "declaredLanguage", "useLad"]); - break; - - // TAXONOMY OPERATIONS - case "AddTerms": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "newTerms"]); - break; - case "GetChildTermsInTerm": - addToPayload(opt, ["sspId", "lcid", "termId", "termSetId"]); - break; - case "GetChildTermsInTermSet": - addToPayload(opt, ["sspId", "lcid", "termSetId"]); - break; - case "GetKeywordTermsByGuids": - addToPayload(opt, ["termIds", "lcid"]); - break; - case "GetTermsByLabel": - addToPayload(opt, ["label", "lcid", "matchOption", "resultCollectionSize", "termIds", "addIfNotFound"]); - break; - case "GetTermSets": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "clientTimeStamps", "clientVersions"]); - break; - - // USERS AND GROUPS OPERATIONS - case "AddGroup": - addToPayload(opt, ["groupName", "ownerIdentifier", "ownerType", "defaultUserLoginName", "description"]); - break; - case "AddGroupToRole": - addToPayload(opt, ["groupName", "roleName"]); - break; - case "AddRole": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddRoleDef": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddUserCollectionToGroup": - addToPayload(opt, ["groupName", "usersInfoXml"]); - break; - case "AddUserCollectionToRole": - addToPayload(opt, ["roleName", "usersInfoXml"]); - break; - case "AddUserToGroup": - addToPayload(opt, ["groupName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "AddUserToRole": - addToPayload(opt, ["roleName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "GetAllUserCollectionFromWeb": - break; - case "GetGroupCollection": - addToPayload(opt, ["groupNamesXml"]); - break; - case "GetGroupCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetGroupCollectionFromSite": - break; - case "GetGroupCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetGroupCollectionFromWeb": - break; - case "GetGroupInfo": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollection": - addToPayload(opt, ["roleNamesXml"]); - break; - case "GetRoleCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetRoleCollectionFromWeb": - break; - case "GetRoleInfo": - addToPayload(opt, ["roleName"]); - break; - case "GetRolesAndPermissionsForCurrentUser": - break; - case "GetRolesAndPermissionsForSite": - break; - case "GetUserCollection": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "GetUserCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetUserCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetUserCollectionFromSite": - break; - case "GetUserCollectionFromWeb": - break; - case "GetUserInfo": - addToPayload(opt, ["userLoginName"]); - break; - case "GetUserLoginFromEmail": - addToPayload(opt, ["emailXml"]); - break; - case "RemoveGroup": - addToPayload(opt, ["groupName"]); - break; - case "RemoveGroupFromRole": - addToPayload(opt, ["roleName", "groupName"]); - break; - case "RemoveRole": - addToPayload(opt, ["roleName"]); - break; - case "RemoveUserCollectionFromGroup": - addToPayload(opt, ["groupName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromRole": - addToPayload(opt, ["roleName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromSite": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "RemoveUserFromGroup": - addToPayload(opt, ["groupName", "userLoginName"]); - break; - case "RemoveUserFromRole": - addToPayload(opt, ["roleName", "userLoginName"]); - break; - case "RemoveUserFromSite": - addToPayload(opt, ["userLoginName"]); - break; - case "RemoveUserFromWeb": - addToPayload(opt, ["userLoginName"]); - break; - case "UpdateGroupInfo": - addToPayload(opt, ["oldGroupName", "groupName", "ownerIdentifier", "ownerType", "description"]); - break; - case "UpdateRoleDefInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateRoleInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateUserInfo": - addToPayload(opt, ["userLoginName", "userName", "userEmail", "userNotes"]); - break; - - // USERPROFILESERVICE OPERATIONS - case "AddColleague": - addToPayload(opt, ["accountName", "colleagueAccountName", "group", "privacy", "isInWorkGroup"]); - break; - case "AddLink": - addToPayload(opt, ["accountName", "name", "url", "group", "privacy"]); - break; - case "AddMembership": - addToPayload(opt, ["accountName", "membershipInfo", "group", "privacy"]); - break; - case "AddPinnedLink": - addToPayload(opt, ["accountName", "name", "url"]); - break; - case "CreateMemberGroup": - addToPayload(opt, ["membershipInfo"]); - break; - case "CreateUserProfileByAccountName": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonManager": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetInCommon": - addToPayload(opt, ["accountName"]); - break; - case "GetPropertyChoiceList": - addToPayload(opt, ["propertyName"]); - break; - case "GetUserColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetUserLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetUserPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserProfileByGuid": - addToPayload(opt, ["guid"]); - break; - case "GetUserProfileByIndex": - addToPayload(opt, ["index"]); - break; - case "GetUserProfileByName": - // Note that this operation is inconsistent with the others, using AccountName rather than accountName - if(opt.accountName !== undefined && opt.accountName.length > 0) { - addToPayload(opt, [["AccountName", "accountName"]]); - } else { - addToPayload(opt, ["AccountName"]); - } - break; - case "GetUserProfileCount": - break; - case "GetUserProfileSchema": - break; - case "ModifyUserPropertyByAccountName": - addToPayload(opt, ["accountName", "newData"]); - break; - case "RemoveAllColleagues": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllMemberships": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveColleague": - addToPayload(opt, ["accountName", "colleagueAccountName"]); - break; - case "RemoveLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "RemoveMembership": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference"]); - break; - case "RemovePinnedLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "UpdateColleaguePrivacy": - addToPayload(opt, ["accountName", "colleagueAccountName", "newPrivacy"]); - break; - case "UpdateLink": - addToPayload(opt, ["accountName", "data"]); - break; - case "UpdateMembershipPrivacy": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference", "newPrivacy"]); - break; - case "UpdatePinnedLink ": - addToPayload(opt, ["accountName", "data"]); - break; - - // VERSIONS OPERATIONS - case "DeleteAllVersions": - addToPayload(opt, ["fileName"]); - break; - case "DeleteVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - case "GetVersions": - addToPayload(opt, ["fileName"]); - break; - case "RestoreVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - - // VIEW OPERATIONS - case "AddView": - addToPayload(opt, ["listName", "viewName", "viewFields", "query", "rowLimit", "rowLimit", "type", "makeViewDefault"]); - break; - case "DeleteView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetViewCollection": - addToPayload(opt, ["listName"]); - break; - case "GetViewHtml": - addToPayload(opt, ["listName", "viewName"]); - break; - case "UpdateView": - addToPayload(opt, ["listName", "viewName", "viewProperties", "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - case "UpdateViewHtml": - addToPayload(opt, ["listName", "viewName", "viewProperties", "toolbar", "viewHeader", "viewBody", "viewFooter", "viewEmpty", "rowLimitExceeded", - "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - - // WEBPARTPAGES OPERATIONS - case "AddWebPart": - addToPayload(opt, ["pageUrl", "webPartXml", "storage"]); - break; - case "AddWebPartToZone": - addToPayload(opt, ["pageUrl", "webPartXml", "storage", "zoneId", "zoneIndex"]); - break; - case "GetWebPart2": - addToPayload(opt, ["pageUrl", "storageKey", "storage", "behavior"]); - break; - case "GetWebPartPage": - addToPayload(opt, ["documentName", "behavior"]); - break; - case "GetWebPartProperties": - addToPayload(opt, ["pageUrl", "storage"]); - break; - case "GetWebPartProperties2": - addToPayload(opt, ["pageUrl", "storage", "behavior"]); - break; - - // WEBS OPERATIONS - case "Webs.CreateContentType": - addToPayload(opt, ["displayName", "parentType", "newFields", "contentTypeProperties"]); - break; - case "GetColumns": - addToPayload(opt, ["webUrl"]); - break; - case "GetContentType": - addToPayload(opt, ["contentTypeId"]); - break; - case "GetContentTypes": - break; - case "GetCustomizedPageStatus": - addToPayload(opt, ["fileUrl"]); - break; - case "GetListTemplates": - break; - case "GetObjectIdFromUrl": - addToPayload(opt, ["objectUrl"]); - break; - case "GetWeb": - addToPayload(opt, [["webUrl", "webURL"]]); - break; - case "GetWebCollection": - break; - case "GetAllSubWebCollection": - break; - case "UpdateColumns": - addToPayload(opt, ["newFields", "updateFields", "deleteFields"]); - break; - case "Webs.UpdateContentType": - addToPayload(opt, ["contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields"]); - break; - case "WebUrlFromPageUrl": - addToPayload(opt, [["pageUrl", "pageURL"]]); - break; - - // WORKFLOW OPERATIONS - case "AlterToDo": - addToPayload(opt, ["item", "todoId", "todoListId", "taskData"]); - break; - case "GetTemplatesForItem": - addToPayload(opt, ["item"]); - break; - case "GetToDosForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowDataForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowTaskData": - addToPayload(opt, ["item", "listId", "taskId"]); - break; - case "StartWorkflow": - addToPayload(opt, ["item", "templateId", "workflowParameters"]); - break; - - default: - break; - } - - // Glue together the pieces of the SOAP message - var msg = SOAPEnvelope.header + - SOAPEnvelope.opheader + - SOAPEnvelope.payload + - SOAPEnvelope.opfooter + - SOAPEnvelope.footer; - - var cachedXML; - var status = null; - - if(opt.cacheXML) { - cachedXML = $("body").data(msg); - } - - if(cachedXML === undefined) { - // Make the Ajax call - $.ajax({ - url: ajaxURL, // The relative URL for the AJAX call - async: opt.async, // By default, the AJAX calls are asynchronous. You can specify false to require a synchronous call. - beforeSend: function (xhr) { // Before sending the msg, need to send the request header - // If we need to pass the SOAPAction, do so - if(WSops[opt.operation][1]) { - xhr.setRequestHeader("SOAPAction", SOAPAction); - } - }, - type: "POST", // This is a POST - data: msg, // Here is the SOAP request we've built above - dataType: "xml", // We're getting XML; tell jQuery so that it doesn't need to do a best guess - contentType: "text/xml;charset='utf-8'", // and this is its content type - complete: function(xData, Status) { - if(opt.cacheXML) { - $("body").data(msg, xData); // Cache the results - } - cachedXML = xData; - status = Status; - opt.completefunc(cachedXML, status); // When the call is complete, do this - } - }); - - } else { - opt.completefunc(cachedXML, status); // Call the completefunc - } - - }; // End $.fn.SPServices - - // Defaults added as a function in our library means that the caller can override the defaults - // for their session by calling this function. Each operation requires a different set of options; - // we allow for all in a standardized way. - $.fn.SPServices.defaults = { - - cacheXML: false, // If true, we'll cache the XML results with jQuery's .data() function - operation: "", // The Web Service operation - webURL: "", // URL of the target Web - makeViewDefault: false, // true to make the view the default view for the list - - // For operations requiring CAML, these options will override any abstractions - CAMLViewName: "", // View name in CAML format. - CAMLQuery: "", // Query in CAML format - CAMLViewFields: "", // View fields in CAML format - CAMLRowLimit: 0, // Row limit as a string representation of an integer - CAMLQueryOptions: "", // Query options in CAML format - - // Abstractions for CAML syntax - batchCmd: "Update", // Method Cmd for UpdateListItems - valuepairs: [], // Fieldname / Fieldvalue pairs for UpdateListItems - - // As of v0.7.1, removed all options which were assigned an empty string ("") - DestinationUrls: [], // Array of destination URLs for copy operations - behavior: "Version3", // An SPWebServiceBehavior indicating whether the client supports Windows SharePoint Services 2.0 or Windows SharePoint Services 3.0: {Version2 | Version3 } - storage: "Shared", // A Storage value indicating how the Web Part is stored: {None | Personal | Shared} - objectType: "List", // objectType for operations which require it - cancelMeeting: true, // true to delete a meeting;false to remove its association with a Meeting Workspace site - nonGregorian: false, // true if the calendar is set to a format other than Gregorian;otherwise, false. - fClaim: false, // Specifies if the action is a claim or a release. Specifies true for a claim and false for a release. - recurrenceId: 0, // The recurrence ID for the meeting that needs its association removed. This parameter can be set to 0 for single-instance meetings. - sequence: 0, // An integer that is used to determine the ordering of updates in case they arrive out of sequence. Updates with a lower-than-current sequence are discarded. If the sequence is equal to the current sequence, the latest update are applied. - maximumItemsToReturn: 0, // SocialDataService maximumItemsToReturn - startIndex: 0, // SocialDataService startIndex - isHighPriority: false, // SocialDataService isHighPriority - isPrivate: false, // SocialDataService isPrivate - rating: 1, // SocialDataService rating - maxResults: 10, // Unless otherwise specified, the maximum number of principals that can be returned from a provider is 10. - principalType: "User", // Specifies user scope and other information: [None | User | DistributionList | SecurityGroup | SharePointGroup | All] - - async: true, // Allow the user to force async - completefunc: null // Function to call on completion - - }; // End $.fn.SPServices.defaults - - // Function to determine the current Web's URL. We need this for successful Ajax calls. - // The function is also available as a public function. - $.fn.SPServices.SPGetCurrentSite = function() { - - // We've already determined the current site... - if(currentContext.thisSite.length > 0) { - return currentContext.thisSite; - } - - // If we still don't know the current site, we call WebUrlFromPageUrlResult. - var msg = SOAPEnvelope.header + - "" + - ((location.href.indexOf("?") > 0) ? location.href.substr(0, location.href.indexOf("?")) : location.href) + - "" + - SOAPEnvelope.footer; - $.ajax({ - async: false, // Need this to be synchronous so we're assured of a valid value - url: "/_vti_bin/Webs.asmx", - type: "POST", - data: msg, - dataType: "xml", - contentType: "text/xml;charset=\"utf-8\"", - complete: function (xData, Status) { - currentContext.thisSite = $(xData.responseXML).find("WebUrlFromPageUrlResult").text(); - } - }); - - return currentContext.thisSite; // Return the URL - - }; // End $.fn.SPServices.SPGetCurrentSite - - // Function to set up cascading dropdowns on a SharePoint form - // (Newform.aspx, EditForm.aspx, or any other customized form.) - $.fn.SPServices.SPCascadeDropdowns = function(options) { - - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationships list - relationshipList: "", // The name of the list which contains the parent/child relationships - relationshipListParentColumn: "", // The internal name of the parent column in the relationship list - relationshipListChildColumn: "", // The internal name of the child column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListChildColumn - parentColumn: "", // The display name of the parent column in the form - childColumn: "", // The display name of the child column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relationshipList - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of childColumn. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - simpleChild: false, // [Optional] If set to true and childColumn is a complex dropdown, convert it to a simple dropdown - selectSingleOption: false, // [Optional] If set to true and there is only a single child option, select it - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - - var thisParentSetUp = false; - var thisFunction = "SPServices.SPCascadeDropdowns"; - - // Find the parent column's select (dropdown) - var parentSelect = new DropdownCtl(opt.parentColumn); - if(parentSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "parentColumn: " + opt.parentColumn , TXTColumnNotFound);return;} - - // Find the child column's select (dropdown) - var childSelect = new DropdownCtl(opt.childColumn); - if(childSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "childColumn: " + opt.childColumn, TXTColumnNotFound);return;} - - // If requested and the childColumn is a complex dropdown, convert to a simple dropdown - if(opt.simpleChild === true && childSelect.Type === "C") { - $().SPServices.SPComplexToSimpleDropdown({ - columnName: opt.childColumn - }); - // Set the childSelect to reference the new simple dropdown - childSelect = new DropdownCtl(opt.childColumn); - } - - var childColumnRequired; - - // Get information about the childColumn from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData, Status) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.childColumn + "']").each(function() { - // Determine whether childColumn is Required - childColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - childColumnStatic = $(this).attr("StaticName"); - // Stop looking; we're done - return false; - }); - }); - } - }); - - // Save data about each child column on the parent - var childColumn = {opt: opt, childSelect: childSelect, childColumnStatic: childColumnStatic, childColumnRequired: childColumnRequired}; - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - - // If this is the first child for this parent, then create the data object to hold the settings - if(childColumns === undefined) { - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", [childColumn]); - // If we already have a data object for this parent, then add the setting for this child to it - } else { - childColumns.push(childColumn); - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", childColumns); - thisParentSetUp = true; - } - - // We only need to bind to the event(s) if we haven't already done so - if(!thisParentSetUp) { - switch(parentSelect.Type) { - // Plain old select - case "S": - parentSelect.Obj.bind("change", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='"+ parentSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Multi-select hybrid - case "M": - // Handle the dblclick on the candidate select - parentSelect.Obj.bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle the dblclick on the selected values - parentSelections = parentSelect.Obj.closest("span").find("select[id$='SelectResult']"); - parentSelections.bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle a button click - parentSelect.Obj.closest("span").find("button").each(function() { - $(this).bind("click", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - }); - break; - default: - break; - } - } - // Fire the change to set the initially allowable values - cascadeDropdown(opt.parentColumn, parentSelect); - - }; // End $.fn.SPServices.SPCascadeDropdowns - - function cascadeDropdown(parentColumn, parentSelect) { - var choices = ""; - var parentSelectSelected; - var childSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var numChildOptions; - var firstChildOptionId; - var firstChildOptionValue; - - // Filter each child column - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - $(childColumns).each(function() { - - // Break out the data objects for this child column - var opt = this.opt; - var childSelect = this.childSelect; - var childColumnStatic = this.childColumnStatic; - var childColumnRequired = this.childColumnRequired; - - // Get the parent column selection(s) - parentSelectSelected = getDropdownSelected(parentSelect, opt.matchOnId); - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C" or "M", as there are multiple propertychanges - // which don't require any action. The attribute will be unique per child column in case there are - // multiple children for a given parent. - var allParentSelections = parentSelectSelected.join(";#"); - if(parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic) === allParentSelections) { - return; - } - parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic, allParentSelections); - - // Get the current child column selection(s) - childSelectSelected = getDropdownSelected(childSelect, true); - - // Find the important bits of the multi-select - if(childSelect.Type === "M") { - MultiLookupPickerdata = childSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[childSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - currentSelection = childSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - } - - // When the parent column's selected option changes, get the matching items from the relationship list - // Get the list items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListChildColumn; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - // Build up the criteria for inclusion - if(parentSelectSelected.length === 0) { - // Handle the case where no values are selected in multi-selects - camlQuery += ""; - } else if(parentSelectSelected.length === 1) { - // Only one value is selected - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[0]) + ""; - } else { - var compound = (parentSelectSelected.length > 2) ? true : false; - for(i=0; i < (parentSelectSelected.length - 1); i++) { - camlQuery += ""; - } - for(i=0; i < parentSelectSelected.length; i++) { - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[i]) + ""; - if(i>0 && (i < (parentSelectSelected.length - 1)) && compound) { - camlQuery += ""; - } - } - camlQuery += ""; - } - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - - // Make sure we don't get any items which don't have the child value - camlQuery += ""; - - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the child column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the currently selected parent column's value - CAMLQuery: camlQuery, - // Only get the parent and child columns - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: "FALSE", - completefunc: function(xData, Status) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var thisFunction = "SPServices.SPCascadeDropdowns"; - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListParentColumn: " + opt.relationshipListParentColumn + " or " + - "relationshipListChildColumn: " + opt.relationshipListChildColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(childSelect.Type) { - case "S": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!childColumnRequired && (opt.promptText.length > 0)) { - childSelect.Obj.append(""); - } else if(!childColumnRequired){ - childSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = childColumnRequired ? "" : opt.noneText + "|0"; - childSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - // Get the count of items returned and save it so that we can select if it's a single option - // The item count is stored thus: - numChildOptions = parseFloat($(xData.responseXML).SPFilterNode("rs:data").attr("ItemCount")); - - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOption = {}; - - // If relationshipListChildColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListChildColumn); - - if(thisValue !== undefined && thisValue.indexOf(";#") > 0) { - thisOption = new SplitIndex(thisValue); - } else { - thisOption.id = $(this).attr("ows_ID"); - thisOption.value = thisValue; - } - - // If the relationshipListChildColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOption.id should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOption.id)) { - thisOption.id = $(this).attr("ows_ID"); - } - - // Save the id and value for the first child option in case we need to select it (selectSingleOption option is true) - firstChildOptionId = thisOption.id; - firstChildOptionValue = thisOption.value; - - switch(childSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === childSelectSelected[0]) ? " selected='selected'" : ""; - childSelect.Obj.append("" + thisOption.value + ""); - break; - case "C": - if(thisOption.id === childSelectSelected[0]) { - childSelect.Obj.attr("value", thisOption.value); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOption.value + "|" + thisOption.id; - break; - case "M": - childSelect.Obj.append(""); - newMultiLookupPickerdata += thisOption.id + "|t" + thisOption.value + "|t |t |t"; - break; - default: - break; - } - }); - - switch(childSelect.Type) { - case "S": - childSelect.Obj.trigger("change"); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - $(childSelect.Obj).find("option[value!='0']:first").attr("selected", "selected"); - } - break; - case "C": - // Set the allowable choices - childSelect.Obj.attr("choices", choices); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - // Set the input element value - $(childSelect.Obj).attr("value", firstChildOptionValue); - // Set the value of the optHid input element - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(firstChildOptionId); - } - // If there's no selection, then remove the value in the associated hidden input element (optHid) - if(childSelect.Obj.val() === "") { - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(""); - } - break; - case "M": - // Clear the master - master.data = ""; - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - - // Clear any prior selections that are no longer valid or aren't selected - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - var thisValue = $(this).html(); - $(this).attr("selected", "selected"); - $(childSelect.Obj).find("option").filter(function() { - return $(this).text() === thisValue.replace(/&/, "&"); - }).each(function() { - if($(this).html() === thisValue) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - - // Hide any options in the candidate list which are already selected - $(childSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - childSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }); // $(childColumns).each(function() - - } // End cascadeDropdown - - - // function to convert complex dropdowns to simple dropdowns - $.fn.SPServices.SPComplexToSimpleDropdown = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox("SPServices.SPComplexToSimpleDropdown", "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // If we don't have a complex dropdown, then there is nothing to do - if(columnSelect.Type !== "C") { return; } - - // The available options are stored in the choices attribute of the complex dropdowns's input element... - var choices = $(columnSelect.Obj).attr("choices").split("|"); - // The optHid attribute contains the id of a hidden input element which stores the selected value for the commit - var columnOptHid = $(columnSelect.Obj).attr("optHid"); - var columnOptHidInput = $("input[id='" + columnOptHid + "']"); - // We need to know which option is selected already, if any - var complexSelectSelectedId = $("input[id='" + columnOptHid + "']").val(); - - // Build up the simple dropdown, giving it an easy to select id - var simpleSelectId = genContainerId("SPComplexToSimpleDropdown", opt.columnName); - - var simpleSelect = ""; - - // Append the new simple select to the form - $(columnSelect.Obj).closest("td").prepend(simpleSelect); - - // Remove the complex dropdown functionality since we don't need it anymore... - $(columnSelect.Obj).closest("span").find("img").remove(); - // ...and hide the input element - $(columnSelect.Obj).closest("span").find("input").hide(); - - // When the simple select changes... - $("#" + simpleSelectId).change(function() { - var thisVal = $(this).val(); - // ...set the optHid input element's value to the valus of the selected option... - columnOptHidInput.val(thisVal); - // ...and save the selected value as the hidden input's value only if the value is not equal to "0" (None) - $(columnSelect.Obj).val($(this).find("option[value='" + (thisVal !== "0" ? thisVal : "") + "']").html()); - }); - // Trigger a change to ensure that the selected value registers in the complex dropdown - $("#" + simpleSelectId).trigger("change"); - - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - - }; // End $.fn.SPServices.SPConvertToSimpleDropdown - - - // Function to display related information when an option is selected on a form. - $.fn.SPServices.SPDisplayRelatedInfo = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - relatedWebURL: "", // [Optional] The name of the Web (site) which contains the related list - relatedList: "", // The name of the list which contains the additional information - relatedListColumn: "", // The internal name of the related column in the related list - relatedColumns: [], // An array of related columns to display - displayFormat: "table", // The format to use in displaying the related information. Possible values are: [table, list] - headerCSSClass: "ms-vh2", // CSS class for the table headers - rowCSSClass: "ms-vb", // CSS class for the table rows - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be ed with the default query on the relatedList - numChars: 0, // If used on an input column (not a dropdown), no matching will occur until at least this number of characters has been entered - matchType: "Eq", // If used on an input column (not a dropdown), type of match. Can be any valid CAML comparison operator, most often "Eq" or "BeginsWith" - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var divId; - var relatedColumnsXML = []; - var relatedListXML; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // Generate a unique id for the container - divId = genContainerId("SPDisplayRelatedInfo", opt.columnName); - - // Get information about the related list and its columns - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - completefunc: function(xData, Status) { - // If debug is on, notify about an error - $(xData.responseXML).find("faultcode").each(function() { - if(opt.debug) {errBox(thisFunction, "relatedList: " + opt.relatedList, "List not found"); return; } - }); - // Get info about the related list - relatedListXML = $(xData.responseXML).find("List"); - // Save the information about each column requested - for (i=0; i < opt.relatedColumns.length; i++) { - relatedColumnsXML[i] = $(xData.responseXML).find("Fields > Field[Name='" + opt.relatedColumns[i] + "']"); - } - } - }); - - switch(columnSelect.Type) { - // Plain old select - case "S": - columnSelect.Obj.bind("change", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='" + columnSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Multi-select hybrid - case "M": - if(opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, "Multi-select columns not supported by this function"); } - break; - default: - break; - } - // Fire the change to set the initially allowable values - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - - }; // End $.fn.SPServices.SPDisplayRelatedInfo - - function showRelated(opt, divId, relatedListXML, relatedColumnsXML) { - - var columnSelectSelected = null; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, opt.matchOnId); - if(columnSelect.Type === "C" && opt.numChars > 0 && columnSelectSelected[0].length < opt.numChars) { - return; - } - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C", as there are multiple propertychanges - // which don't require any action. - if(columnSelect.Obj.attr("showRelatedSelected") === columnSelectSelected[0]) { - return; - } - columnSelect.Obj.attr("showRelatedSelected", columnSelectSelected[0]); - - // Remove the old container... - $("#" + divId).remove(); - // ...and append a new, empty one - columnSelect.Obj.parent().append("
    "); - - // Get the list items which match the current selection - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - camlQuery += "" : "'/>") + - escapeColumnValue(columnSelectSelected[0]) + ""; - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - var viewFields = " "; - for (i=0; i < opt.relatedColumns.length; i++) { - viewFields += ""; - } - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - // Filter based on the column's currently selected value - CAMLQuery: camlQuery, - CAMLViewFields: "" + viewFields + "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData, Status) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relatedListColumn: " + opt.relatedListColumn, - "Column not found in relatedList " + opt.relatedList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relatedList: " + opt.relatedList, - "List not found"); - } - return; - }); - - var outString; - // Output each row - switch(opt.displayFormat) { - // Only implementing the table format in the first iteration (v0.2.9) - case "table": - outString = ""; - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === 'undefined' && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - } - outString += ""; - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - outString += ""; - } - outString += ""; - }); - outString += "
    " + relatedColumnsXML[i].attr("DisplayName") + "
    " + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
    "; - break; - // list format implemented in v0.5.0. Still table-based, but vertical orientation. - case "list": - outString = ""; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === 'undefined' && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - outString += ""; - outString += ""; - outString += ""; - } - }); - outString += "
    " + relatedColumnsXML[i].attr("DisplayName") + "" + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
    "; - break; - default: - break; - } - // Write out the results - $("#" + divId).html(outString); - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - } // End showRelated - - // Function to filter a lookup based dropdown - $.fn.SPServices.SPFilterDropdown = function(options) { - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationshipList - relationshipList: "", // The name of the list which contains the lookup values - relationshipListColumn: "", // The internal name of the column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListColumn - relationshipListSortAscending: true, // [Optional] By default, the sort is ascending. If false, descending - columnName: "", // The display name of the column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of columnName. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - CAMLQuery: "", // This CAML fragment will be applied to the relationshipList - CAMLQueryOptions: "FALSE", // Need this to mirror SharePoint's behavior, but it can be overridden - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages; if false, run silent - }, options); - - var choices = ""; - var columnSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var columnColumnRequired; - var thisFunction = "SPServices.SPFilterDropdown"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return;} - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, true); - - // Get the relationshipList items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListColumn; - var sortOrder = (opt.relationshipListSortAscending === true) ? "" : "Ascending='FALSE'"; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery; - } - camlQuery += ""; - - // Get information about columnName from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData, Status) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName is Required - columnColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - // Stop looking; we're done - return false; - }); - }); - } - }); - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the specified CAML - CAMLQuery: camlQuery, - // Only get the columnName's data (plus columns we can't prevent) - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: opt.CAMLQueryOptions, - completefunc: function(xData, Status) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListColumn: " + opt.relationshipListColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(columnSelect.Type) { - case "S": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!columnColumnRequired && (opt.promptText.length > 0)) { - columnSelect.Obj.append(""); - } else if(!columnColumnRequired){ - columnSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = columnColumnRequired ? "" : opt.noneText + "|0"; - columnSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - - // Add an option for each item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOption = {}; - - // If relationshipListColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListColumn); - - if(thisValue !== undefined && thisValue.indexOf(";#") > 0) { - thisOption = new SplitIndex(thisValue); - } else { - thisOption.id = $(this).attr("ows_ID"); - thisOption.value = thisValue; - } - - // If the relationshipListColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOption.id should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOption.id)) { - thisOption.id = $(this).attr("ows_ID"); - } - - switch(columnSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === columnSelectSelected[0]) ? " selected='selected'" : ""; - columnSelect.Obj.append("" + thisOption.value + ""); - break; - case "C": - if(thisOption.id === columnSelectSelected[0]) { - columnSelect.Obj.attr("value", thisOption.value); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOption.value + "|" + thisOption.id; - break; - case "M": - columnSelect.Obj.append(""); - newMultiLookupPickerdata += thisOption.id + "|t" + thisOption.value + "|t |t |t"; - break; - default: - break; - } - }); - - switch(columnSelect.Type) { - case "S": - columnSelect.Obj.trigger("change"); - break; - case "C": - columnSelect.Obj.attr("choices", choices); - columnSelect.Obj.trigger("propertychange"); - break; - case "M": - // Find the important bits of the multi-select - MultiLookupPickerdata = columnSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[columnSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - currentSelection = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - // Clear the master - master.data = ""; - - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - // Clear any prior selections that are no longer valid - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - $(this).attr("selected", "selected"); - $(columnSelect.Obj).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - // Hide any options in the candidate list which are already selected - $(columnSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - columnSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPFilterDropdown - - - // Utility function to show the results of a Web Service call formatted well in the browser. - $.fn.SPServices.SPDebugXMLHttpResult = function(options) { - - var opt = $.extend({}, { - node: null, // An XMLHttpResult object from an ajax call - indent: 0 // Number of indents - }, options); - - var i; - var NODE_TEXT = 3; - var NODE_CDATA_SECTION = 4; - - var outString = ""; - // For each new subnode, begin rendering a new TABLE - outString += ""; - // DisplayPatterns are a bit unique, so let's handle them differently - if(opt.node.nodeName === "DisplayPattern") { - outString += ""; - // A node which has no children - } else if (!opt.node.hasChildNodes()) { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // A CDATA_SECTION node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_CDATA_SECTION) { - outString += ""; - // A TEXT node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_TEXT) { - outString += ""; - // Handle child nodes - } else { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // Since the node has child nodes, recurse - outString += ""; - } - outString += "
    " + opt.node.nodeName + - "
    " + opt.node.nodeName + - "" + ((opt.node.nodeValue !== null) ? checkLink(opt.node.nodeValue) : " ") + "
    " + showAttrs(opt.node, opt) + "
    " + opt.node.nodeName + - "
    " + opt.node.nodeName + - "" + checkLink(opt.node.firstChild.nodeValue) + "
    " + opt.node.nodeName + "
    " + showAttrs(opt.node, opt) + "
    "; - for (i = 0;i < opt.node.childNodes.length; i++) { - outString += $().SPServices.SPDebugXMLHttpResult({ - node: opt.node.childNodes.item(i), - indent: opt.indent + 1 - }); - } - outString += "
    "; - // Return the HTML which we have built up - return outString; - }; // End $.fn.SPServices.SPDebugXMLHttpResult - - // Function which returns the account name for the current user in DOMAIN\username format - $.fn.SPServices.SPGetCurrentUser = function(options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Site Collection. If not specified, the current Web is used. - fieldName: "Name", // Specifies which field to return from the userdisp.aspx page - fieldNames: {}, // Specifies which fields to return from the userdisp.aspx page - added in v0.7.2 to allow multiple columns - debug: false // If true, show error messages; if false, run silent - }, options); - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldName === "ID" && typeof currentContext.thisUserId !== "undefined") { - return currentContext.thisUserId; - } - - var thisField = ""; - var theseFields = {}; - var fieldCount = opt.fieldNames.length > 0 ? opt.fieldNames.length : 1; - var thisUserDisp; - var thisWeb = opt.webURL.length > 0 ? opt.webURL : $().SPServices.SPGetCurrentSite(); - - // Get the UserDisp.aspx page using AJAX - $.ajax({ - // Need this to be synchronous so we're assured of a valid value - async: false, - // Force parameter forces redirection to a page that displays the information as stored in the UserInfo table rather than My Site. - // Adding the extra Query String parameter with the current date/time forces the server to view this as a new request. - url: thisWeb + "/_layouts/userdisp.aspx?Force=True&" + new Date().getTime(), - complete: function (xData, Status) { - thisUserDisp = xData; - } - }); - - for(i=0; i < fieldCount; i++) { - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldNames[i] === "ID") { - thisField = currentContext.thisUserId; - } else { - var thisTextValue; - if(fieldCount > 1) { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldNames[i] + "\"", "gi"); - } else { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldName + "\"", "gi"); - } - $(thisUserDisp.responseText).find("table.ms-formtable td[id^='SPField']").each(function() { - if(thisTextValue.test($(this).html())) { - // Each fieldtype contains a different data type, as indicated by the id - switch($(this).attr("id")) { - case "SPFieldText": - thisField = $(this).text(); - break; - case "SPFieldNote": - thisField = $(this).find("div").html(); - break; - case "SPFieldURL": - thisField = $(this).find("img").attr("src"); - break; - // Just in case - default: - thisField = $(this).text(); - break; - } - // Stop looking; we're done - return false; - } - }); - } - if(opt.fieldNames[i] !== "ID") { - thisField = (thisField !== undefined) ? thisField.replace(/(^[\s\xA0]+|[\s\xA0]+$)/g, '') : null; - } - if(fieldCount > 1) { - theseFields[opt.fieldNames[i]] = thisField; - } - } - - return (fieldCount > 1) ? theseFields : thisField; - - }; // End $.fn.SPServices.SPGetCurrentUser - - - // Function which provides a link on a Lookup column for the user to follow - // which allows them to add a new value to the Lookup list. - // Based on http://blog.mastykarz.nl/extending-lookup-fields-add-new-item-option/ - // by Waldek Mastykarz - $.fn.SPServices.SPLookupAddNew = function(options) { - - var opt = $.extend({}, { - lookupColumn: "", // The display name of the Lookup column - promptText: "Add new {0}", // Text to use as prompt + column name - newWindow: false, // If true, the link will open in a new window *without* passing the Source. - ContentTypeID: "", // [Optional] Pass the ContentTypeID if you'd like to specify it - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var thisFunction = "SPServices.SPLookupAddNew"; - - // Find the lookup column's select (dropdown) - var lookupSelect = new DropdownCtl(opt.lookupColumn); - if(lookupSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, TXTColumnNotFound);return;} - - var newUrl = ""; - var lookupListUrl = ""; - var lookupColumnStaticName = ""; - // Use GetList for the current list to determine the details for the Lookup column - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $().SPServices.SPListNameFromUrl(), - completefunc: function (xData, Status) { - $(xData.responseXML).find("Field[DisplayName='" + opt.lookupColumn + "']").each(function() { - lookupColumnStaticName = $(this).attr("StaticName"); - // Use GetList for the Lookup column's list to determine the list's URL - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $(this).attr("List"), - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - lookupListUrl = $(this).attr("WebFullUrl"); - // Need to handle when list is in the root site - lookupListUrl = lookupListUrl !== SLASH ? lookupListUrl + SLASH : lookupListUrl; - }); - } - }); - // Get the NewItem form for the Lookup column's list - newUrl = getListFormUrl($(this).attr("List"), "NewForm"); - // Stop looking;we're done - return false; - }); - } - }); - - if(lookupListUrl.length === 0 && opt.debug) { - errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, "This column does not appear to be a lookup column"); - return; - } - if(newUrl.length > 0) { - // Build the link to the Lookup column's list enclosed in a div with the id="SPLookupAddNew_" + lookupColumnStaticName - var newHref = lookupListUrl + newUrl; - // If requested, open the link in a new window and if requested, pass the ContentTypeID - newHref += opt.newWindow ? - ((opt.ContentTypeID.length > 0) ? "?ContentTypeID=" + opt.ContentTypeID : "") + "' target='_blank'" : - "?" + ((opt.ContentTypeID.length > 0) ? "ContentTypeID=" + opt.ContentTypeID + "&" : "") + "Source=" + escapeUrl(location.href) + "'"; - newLink = "
    " + " 0) { - camlQuery += ""; - } - camlQuery += "" + userId + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: camlQuery, - CAMLViewFields: "", - CAMLRowLimit: 1, - CAMLQueryOptions: "", - completefunc: function(xData, Status) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - lastId = $(this).attr("ows_ID"); - }); - } - }); - return lastId; - }; // End $.fn.SPServices.SPGetLastItemId - - // Function which checks to see if the value for a column on the form is unique in the list. - $.fn.SPServices.SPRequireUnique = function (options) { - - var opt = $.extend({}, { - columnStaticName: "Title", // Name of the column - duplicateAction: 0, // 0 = warn, 1 = prevent - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - initMsg: "This value must be unique.", // Initial message to display after setup - initMsgCSSClass: "ms-vb", // CSS class for initial message - errMsg: "This value is not unique.", // Error message to display if not unique - errMsgCSSClass: "ms-formvalidation", // CSS class for error message - showDupes: false, // If true, show links to the duplicate item(s) after the error message - completefunc: null // Function to call on completion of rendering the change. - }, options); - - // Get the current item's ID from the Query String - var queryStringVals = $().SPServices.SPGetQueryString(); - var thisID = queryStringVals.ID; - currentContext.thisList = $().SPServices.SPListNameFromUrl(); - - // Set the messages based on the options provided - var msg = "{1}
    "; - var firstMsg = msg.replace(/\{0\}/g, opt.initMsgCSSClass).replace(/\{1\}/g, opt.initMsg); - - // We need the DisplayName - var columnDisplayName = $().SPServices.SPGetDisplayFromStatic({ - listName: currentContext.thisList, - columnStaticName: opt.columnStaticName - }); - var columnObj = $("input[Title='" + columnDisplayName + "']"); - $(columnObj).parent().append(firstMsg); - - $(columnObj).blur(function () { - var columnValueIDs = []; - // Get the columnDisplayName's value - var columnValue = $(this).attr("value"); - if(columnValue.length === 0) { return false; } - - // Call the Lists Web Service (GetListItems) to see if the value already exists - $().SPServices({ - operation: "GetListItems", - async: false, - listName: currentContext.thisList, - // Make sure we get all the items, ignoring any filters on the default view. - CAMLQuery: "", - // Filter based on columnStaticName's value - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData, Status) { - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = opt.ignoreCase ? $(this).attr("ows_" + opt.columnStaticName).toUpperCase() : $(this).attr("ows_" + opt.columnStaticName); - // If this value already exists in columnStaticName and it's not the current item, then save the ID in the array - if((testValue === thisValue) && ($(this).attr("ows_ID") !== thisID)) { - columnValueIDs.push([$(this).attr("ows_ID"), $(this).attr("ows_" + opt.columnStaticName)]); - } - }); - } - }); - var newMsg = opt.initMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.initMsgCSSClass); - - $("input[value='OK']:disabled, input[value='Save']:disabled").removeAttr("disabled"); - if(columnValueIDs.length > 0) { - newMsg = opt.errMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.errMsgCSSClass); - if(opt.duplicateAction === 1) { - $("input[Title='" + opt.columnDisplayName + "']").focus(); - $("input[value='OK'], input[value='Save']").attr("disabled", "disabled"); - } - if(opt.showDupes) { - var out = " " + columnValueIDs.length + " duplicate item" + (columnValueIDs.length > 1 ? "s" : "") + ": "; - for (i=0;i < columnValueIDs.length; i++) { - out += "
    " + columnValueIDs[i][1] + " "; - } - $("span#SPRequireUnique" + opt.columnStaticName).append(out); - } - } - - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPRequireUnique - - // This function returns the DisplayName for a column based on the StaticName. - $.fn.SPServices.SPGetDisplayFromStatic = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnStaticName: "", // StaticName of the column - columnStaticNames: {} // StaticName of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var displayName = ""; - var displayNames = {}; - var nameCount = opt.columnStaticNames.length > 0 ? opt.columnStaticNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData, Status) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - displayNames[opt.columnStaticNames[i]] = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticNames[i] + "']").attr("DisplayName"); - } - } else { - displayName = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticName + "']").attr("DisplayName"); - } - } - }); - - return (nameCount > 1) ? displayNames : displayName; - - }; // End $.fn.SPServices.SPGetDisplayFromStatic - - // This function returns the StaticName for a column based on the DisplayName. - $.fn.SPServices.SPGetStaticFromDisplay = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnDisplayName: "", // DisplayName of the column - columnDisplayNames: {} // DisplayNames of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var staticName = ""; - var staticNames = {}; - var nameCount = opt.columnDisplayNames.length > 0 ? opt.columnDisplayNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData, Status) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - staticNames[opt.columnDisplayNames[i]] = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayNames[i] + "']").attr("StaticName"); - } - } else { - staticName = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayName + "']").attr("StaticName"); - } - } - }); - - return (nameCount > 1) ? staticNames : staticName; - - }; // End $.fn.SPServices.SPGetStaticFromDisplay - - // This function allows you to redirect to a another page from a new item form with the new - // item's ID. This allows chaining of forms from item creation onward. - $.fn.SPServices.SPRedirectWithID = function (options) { - - var opt = $.extend({}, { - redirectUrl: "", // Page for the redirect - qsParamName: "ID" // In some cases, you may want to pass the newly created item's ID with a different - // parameter name than ID. Specify that name here, if needed. - }, options); - - currentContext.thisList = $().SPServices.SPListNameFromUrl(); - var queryStringVals = $().SPServices.SPGetQueryString(); - var lastID = queryStringVals.ID; - var QSList = queryStringVals.List; - var QSRootFolder = queryStringVals.RootFolder; - var QSContentTypeId = queryStringVals.ContentTypeId; - - // On first load, change the form actions to redirect back to this page with the current lastID for this user and the - // original Source. - if(typeof queryStringVals.ID === 'undefined') { - lastID = $().SPServices.SPGetLastItemId({ - listName: currentContext.thisList - }); - $("form[name='aspnetForm']").each(function() { - // This page... - var thisUrl = (location.href.indexOf("?") > 0) ? location.href.substring(0, location.href.indexOf("?")) : location.href; - // ... plus the Source if it exists - var thisSource = (typeof queryStringVals.Source === "string") ? - "Source=" + queryStringVals.Source.replace(/\//g, "%2f").replace(/:/g, "%3a") : ""; - - var newQS = []; - if(typeof QSList !== 'undefined') { - newQS.push("List=" + QSList); - } - if(typeof QSRootFolder !== 'undefined') { - newQS.push("RootFolder=" + QSRootFolder); - } - if(typeof QSContentTypeId !== 'undefined') { - newQS.push("ContentTypeId=" + QSContentTypeId); - } - - var newAction = thisUrl + - ((newQS.length > 0) ? ("?" + newQS.join("&") + "&") : "?") + - // Set the Source to point back to this page with the lastID this user has added - "Source=" + thisUrl + - "?ID=" + lastID + - // Pass the original source as RealSource, if present - ((thisSource.length > 0) ? ("%26RealSource=" + queryStringVals.Source) : "") + - // Pass the override RedirectURL, if present - ((typeof queryStringVals.RedirectURL === "string") ? ("%26RedirectURL=" + queryStringVals.RedirectURL) : ""); - $(this).attr("action", newAction); - }); - // If this is the load after the item is saved, wait until the new item has been saved (commits are asynchronous), - // then do the redirect to redirectUrl with the new lastID, passing along the original Source. - } else { - while(queryStringVals.ID === lastID) { - lastID = $().SPServices.SPGetLastItemId({ - listName: currentContext.thisList - }); - } - // If there is a RedirectURL parameter on the Query String, then redirect there instead of the value - // specified in the options (opt.redirectUrl) - var thisRedirectUrl = (typeof queryStringVals.RedirectURL === "string") ? queryStringVals.RedirectURL : opt.redirectUrl; - location.href = thisRedirectUrl + "?" + opt.qsParamName + "=" + lastID + - ((typeof queryStringVals.RealSource === "string") ? ("&Source=" + queryStringVals.RealSource) : ""); - } - }; // End $.fn.SPServices.SPRedirectWithID - - // The SPSetMultiSelectSizes function sets the sizes of the multi-select boxes for a column on a form automagically - // based on the values they contain. The function takes into account the fontSize, fontFamily, fontWeight, etc., in its algorithm. - $.fn.SPServices.SPSetMultiSelectSizes = function (options) { - - var opt = $.extend({}, { - multiSelectColumn: "", - minWidth: 0, - maxWidth: 0, - debug: false - }, options); - - var thisFunction = "SPServices.SPSetMultiSelectSizes"; - - // Find the multi-select column - var thisMultiSelect = new DropdownCtl(opt.multiSelectColumn); - if(thisMultiSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, TXTColumnNotFound);return;} - if(thisMultiSelect.Type !== "M" && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, "Column is not multi-select.");return;} - - var possibleValues = thisMultiSelect.Obj; - var selectedValues = possibleValues.closest("span").find("select[ID$='SelectResult']"); - - // Create a temporary clone of the select to use to determine the appropriate width settings. - // We'll append it to the end of the enclosing span. - var cloneId = genContainerId("SPSetMultiSelectSizes", opt.multiSelectColumn); - possibleValues.clone().appendTo(possibleValues.closest("span")).css({ - "width": "auto", // We want the clone to resize its width based on the contents - "height": 0, // Just to keep the page clean while we are using the clone - "visibility": "hidden" // And let's keep it hidden - }).attr({ - id: cloneId, // We don't want the clone to have the same id as its source - length: 0 // And let's start with no options - }); - var cloneObj = $("#" + cloneId); - - // Add all the values to the cloned select. First the left (possible values) select... - possibleValues.find("option").each(function() { - cloneObj.append(""); - }); - // ...then the right (selected values) select (in case some values have already been selected) - selectedValues.find("option").each(function() { - cloneObj.append(""); - }); - - // We'll add 5px for a little padding on the right. - var divWidth = $("#" + cloneId).width() + 5; - var newDivWidth = divWidth; - if(opt.minWidth > 0 || opt.maxWidth > 0) { - if(divWidth < opt.minWidth) { - divWidth = opt.minWidth; - } - if(newDivWidth < opt.minWidth) { - newDivWidth = opt.minWidth; - } - if(newDivWidth > opt.maxWidth) { - newDivWidth = opt.maxWidth; - } - } - var selectWidth = divWidth; - - // Set the new widths - possibleValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - selectedValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - - // Remove the select's clone, since we're done with it - $("#" + cloneId).remove(); - }; // End $.fn.SPServices.SPSetMultiSelectSizes - - // Does an audit of a site's list forms to show where script is in use. - $.fn.SPServices.SPScriptAudit = function (options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] The name of the Web (site) to audit - listName: "", // [Optional] The name of a specific list to audit. If not present, all lists in the site are audited. - outputId: "", // The id of the DOM object for output - auditForms: true, // Audit the form pages - auditViews: true, // Audit the view pages - auditPages: true, // Audit the Pages Document Library - auditPagesListName: "Pages", // The Pages Document Library(ies), if desired. Either a single string or an array of strings. - showHiddenLists: false, // Show output for hidden lists - showNoScript: false, // Show output for lists with no scripts (effectively "verbose") - showSrc: true // Show the source location for included scripts - }, options); - - var formTypes = [["New", "NewForm.aspx", false], ["Display", "DispForm.aspx", false], ["Edit", "EditForm.aspx", false]]; - var listXml; - - // Build the table to contain the results - $("#" + opt.outputId) - .append("" + - "" + - "" + - "" + - "" + - "" + - "" + - (opt.showSrc ? "" : "") + - "" + - "
    ListPage ClassPage TypePageScript References
    "); - // Apply the CSS class to the headers - $("#SPScriptAudit th").attr("class", "ms-vh2-nofilter"); - - // Don't bother with the lists if the options don't require them - if(opt.auditForms || opt.auditViews) { - // First, get all of the lists within the site - $().SPServices({ - operation: "GetListCollection", - webURL: opt.webURL, - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - - // If listName has been specified, then only return results for that list - if((opt.listName.length === 0) || (listXml.attr("Title") === opt.listName)) { - // Don't work with hidden lists unless we're asked to - if((opt.showHiddenLists && listXml.attr("Hidden") === "False") || !opt.showHiddenLists) { - - // Audit the list's forms - if(opt.auditForms) { - // Get the list's Content Types, therefore the form pages - $().SPServices({ - operation: "GetListContentTypes", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("ContentType").each(function() { - // Don't deal with folders - if($(this).attr("ID").substring(0,6) !== "0x0120") { - var formUrls = $(this).find("FormUrls"); - for(i=0; i < formTypes.length; i++) { - // Look for a customized form... - $(formUrls).find(formTypes[i][0]).each(function() { - SPScriptAuditPage(opt, listXml, "Form", this.nodeName, - ((opt.webURL.length > 0) ? opt.webURL : $().SPServices.SPGetCurrentSite()) + SLASH + $(this).text()); - formTypes[i][2] = true; - }); - // ...else the uncustomized form - if(!formTypes[i][2]) { - var defaultViewUrl = listXml.attr("DefaultViewUrl"); - SPScriptAuditPage(opt, listXml, "Form", formTypes[i][0], - defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH)+1) + formTypes[i][1]); - } - } - // Reset the form types - for(i=0; i < formTypes.length; i++) { - formTypes[i][2] = false; - } - } - }); - } - }); - } - - // Audit the list's views - if(opt.auditViews) { - // Get the list's Views - $().SPServices({ - operation: "GetViewCollection", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("View").each(function() { - SPScriptAuditPage(opt, listXml, "View", $(this).attr("DisplayName"), $(this).attr("Url")); - }); - } - }); - } - - } - } - }); - } - }); - } - - // Don't bother with auditing pages if the options don't require it - var numLists = 0; - var listsArray = []; - if(typeof opt.auditPagesListName === "string") { - numLists = 1; - listsArray.push(opt.auditPagesListName); - } else { - numLists = opt.auditPagesListName.length; - listsArray = opt.auditPagesListName; - } - - if(opt.auditPages) { - for(i=0; i < numLists; i++) { - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: listsArray[i], - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - }); - } - }); - // Get all of the items from the Document Library - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: listsArray[i], - CAMLQuery: "Folder", - CAMLViewFields: "", - CAMLRowLimit: 0, - completefunc: function(xData, Status) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisPageUrl = $(this).attr("ows_FileRef").split(";#")[1]; - var thisPageType = (typeof $(this).attr("ows_Title") !== 'undefined') ? $(this).attr("ows_Title") : ""; - if(thisPageUrl.indexOf(".aspx") > 0) { - SPScriptAuditPage(opt, listXml, "Page", thisPageType, SLASH + thisPageUrl); - } - }); - } - }); - } - } - // Remove progress indicator and make the output pretty by cleaning up the ms-alternating CSS class - $("#SPScriptAudit tr[class='ms-alternating']:even").removeAttr("class"); - }; // End $.fn.SPServices.SPScriptAudit - - // Displays the usage of scripts in a site - function SPScriptAuditPage(opt, listXml, pageClass, pageType, pageUrl) { - - var i = 0; - var jQueryPage = 0; - var pageScriptSrc = {}; - pageScriptSrc.type = []; - pageScriptSrc.src = []; - pageScriptSrc.script = []; - var scriptRegex = RegExp("", "gi"); - - // Fetch the page - $.ajax({ - type: "GET", - url: pageUrl, - dataType: "text", - async: false, - success: function(xData) { - - while (scriptMatch = scriptRegex.exec(xData)) { - var scriptLanguage = getScriptAttribute(scriptMatch, "language"); - var scriptType = getScriptAttribute(scriptMatch, "type"); - var scriptSrc = getScriptAttribute(scriptMatch, "src"); - if(scriptSrc !== null && scriptSrc.length > 0 && !coreScript(scriptSrc)) { - pageScriptSrc.type.push((scriptLanguage !== null && scriptLanguage.length > 0) ? scriptLanguage : scriptType); - pageScriptSrc.src.push(scriptSrc); - jQueryPage++; - } - } - - // Only show pages without script if we've been asked to do so. - if((!opt.showNoScript && (pageScriptSrc.type.length > 0)) || opt.showNoScript) { - var pagePath = pageUrl.substring(0, pageUrl.lastIndexOf(SLASH)+1); - var out = "" + - "" + - "" + listXml.attr("Title") + ((listXml.attr("Hidden") === "True") ? '(Hidden)' : '')+ "" + - "" + pageClass + "" + - "" + pageType + "" + - "" + fileName(pageUrl) + ""; - if(opt.showSrc) { - var thisSrcPath; - out += ""; - for(i=0; i < pageScriptSrc.type.length; i++) { - thisSrcPath = (pageScriptSrc.src[i].substr(0,1) !== SLASH) ? pagePath + pageScriptSrc.src[i] : pageScriptSrc.src[i]; - out += ""; - out += ""; - } - out += "
    " + pageScriptSrc.type[i] + "" + fileName(pageScriptSrc.src[i]) + "
    "; - } - $("#SPScriptAudit").append(out); - } - } - }); - } // End of function SPScriptAuditPage - - function getScriptAttribute(source, attribute) { - var regex = RegExp(attribute + "=(\"([^\"]*)\")|('([^']*)')", "gi"); - if(matches = regex.exec(source)) { - return matches[2]; - } - return null; - } // End of function getScriptAttribute - - // Check to see if the script reference is part of SharePoint core so that we can ignore it - function coreScript(src) { - var i; - var coreScriptLocations = ["WebResource.axd", "_layouts"]; - for(i=0; i < coreScriptLocations.length; i++) { - if(src.indexOf(coreScriptLocations[i]) > -1) { - return true; - } - } - return false; - } // End of function coreScript - - // Rearrange radio buttons or checkboxes in a form from vertical to horizontal display to save page real estate - $.fn.SPServices.SPArrangeChoices = function (options) { - - var opt = $.extend({}, { - listName: "", // The list name for the current form - columnName: "", // The display name of the column in the form - perRow: 99, // Maximum number of choices desired per row. - randomize: false // If true, randomize the order of the options - }, options); - - var columnFillInChoice = false; - var columnOptions = []; - var out; - - // Get information about columnName from the list to determine if we're allowing fill-in choices - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: (opt.listName.length > 0) ? opt.listName : $().SPServices.SPListNameFromUrl(), - completefunc: function(xData, Status) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName allows a fill-in choice - columnFillInChoice = ($(this).attr("FillInChoice") === "TRUE") ? true : false; - // Stop looking;we're done - return false; - }); - }); - } - }); - - var thisFormField = findFormField(opt.columnName); - - var totalChoices = $(thisFormField).find("tr").length; - var choiceNumber = 0; - var fillinPrompt; - var fillinInput; - // Collect all of the choices - $(thisFormField).find("tr").each(function() { - choiceNumber++; - // If this is the fill-in prompt, save it... - if(columnFillInChoice && choiceNumber === (totalChoices - 1)) { - fillinPrompt = $(this).find("td").html(); - // ...or if it is the fill-in input box, save it... - } else if(columnFillInChoice && choiceNumber === totalChoices) { - fillinInput = $(this).find("td").html(); - // ...else push into the columnOptions array. - } else { - columnOptions.push($(this).html()); - } - }); - out = ""; - - // If randomize is true, randomly sort the options - if(opt.randomize) { - columnOptions.sort(randOrd); - } - - // Add all of the options to the out string - for(i=0; i < columnOptions.length; i++) { - out += columnOptions[i]; - // If we've already got perRow columnOptions in the row, close off the row - if((i+1) % opt.perRow === 0) { - out += ""; - } - } - out += ""; - - // If we are allowing a fill-in choice, add that option in a separate row at the bottom - if(columnFillInChoice) { - out += "" + fillinPrompt + fillinInput + ""; - } - - // Remove the existing rows... - $(thisFormField).find("tr").remove(); - // ...and append the out string - $(thisFormField).find("table").append(out); - - }; // End $.fn.SPServices.SPArrangeChoices - - // Provide suggested values from a list for in input column based on characters typed - $.fn.SPServices.SPAutocomplete = function (options) { - - var opt = $.extend({}, { - WebURL: "", // [Optional] The name of the Web (site) which contains the sourceList - sourceList: "", // The name of the list which contains the values - sourceColumn: "", // The static name of the column which contains the values - columnName: "", // The display name of the column in the form - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relatedList - CAMLQueryOptions: "", // [Optional] For power users, allows specifying the CAMLQueryOptions for the GetListItems call - CAMLRowLimit: 0, // [Optional] Override the default view rowlimit and get all appropriate rows - filterType: "BeginsWith", // Type of filtering: [BeginsWith, Contains] - numChars: 0, // Wait until this number of characters has been typed before attempting any actions - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - highlightClass: "", // If a class is supplied, highlight the matched characters in the values by applying that class to a wrapping span - uniqueVals: false, // If set to true, the function only adds unique values to the list (no duplicates) - maxHeight: 99999, // Sets the maximum number of values to display before scrolling occurs - slideDownSpeed: "fast", // Speed at which the div should slide down when values match (milliseconds or ["fast" | "slow"]) - processingIndicator: "_layouts/images/REFRESH.GIF", // If present, show this while processing - debug: false // If true, show error messages;if false, run silent - }, options); - - var matchNum; - - // Find the input control for the column and save some of its attributes - var columnObj = $("input[Title='" + opt.columnName + "']"); - $("input[Title='" + opt.columnName + "']").css("position", ""); - var columnObjId = columnObj.attr("ID"); - var columnObjColor = columnObj.css("color"); - var columnObjWidth = columnObj.css("width"); - - if(columnObj.html() === null && opt.debug) { - errBox("SPServices.SPAutocomplete", - "columnName: " + opt.columnName, - "Column is not an input control or is not found on page"); - return; - } - - // Remove the
    which isn't needed and messes up the formatting - columnObj.closest("span").find("br").remove(); - columnObj.wrap("
    "); - - // Create a div to contain the matching values and add it to the DOM - var containerId = genContainerId("SPAutocomplete", opt.columnName); - columnObj.after("
    "); - - // Set the width to match the width of the input control - $("#" + containerId).css("width", columnObjWidth); - - // Handle keypresses - $(columnObj).keyup(function () { - - // Get the column's value - var columnValue = $(this).val(); - - // Hide the container while we're working on it - $("#" + containerId).hide(); - - // Have enough characters been typed yet? - if(columnValue.length < opt.numChars) { - return false; - } - - // Show the the processingIndicator as a background image in the input element - columnObj.css({ - "background-image": "url(" + opt.processingIndicator + ")", - "background-position": "right", - "background-repeat": "no-repeat" - }); - - // Array to hold the matched values - var matchArray = []; - - // Build the appropriate CAMLQuery - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - camlQuery += "<" + opt.filterType + ">" + columnValue + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - // Call GetListItems to find all of the potential values - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.WebURL, - listName: opt.sourceList, - CAMLQuery: camlQuery, - CAMLQueryOptions: opt.CAMLQueryOptions, - CAMLViewFields: "", - CAMLRowLimit: opt.CAMLRowLimit, - completefunc: function(xData, Status) { - // Handle upper/lower case if ignoreCase = true - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - // See which values match and add the ones that do to matchArray - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = $(this).attr("ows_" + opt.sourceColumn); - var thisValueTest = opt.ignoreCase ? $(this).attr("ows_" + opt.sourceColumn).toUpperCase() : $(this).attr("ows_" + opt.sourceColumn); - // Make sure we have a match... - if(opt.filterType === "Contains") { - var firstMatch = thisValueTest.indexOf(testValue); - if((firstMatch >= 0) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } else { - // Handles normal case, which is BeginsWith and and other unknown values - if(testValue === thisValueTest.substr(0,testValue.length) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } - }); - } - }); - - // Build out the set of list elements to contain the available values - var out = ""; - for (i=0; i < matchArray.length; i++) { - // If a highlightClass has been supplied, wrap a span around each match - if(opt.highlightClass.length > 0) { - // Set up Regex based on whether we want to ignore case - var thisRegex = RegExp(columnValue, opt.ignoreCase ? "gi" : "g"); - // Look for all occurrences - var matches = matchArray[i].match(thisRegex); - var startLoc = 0; - // Loop for each occurrence, wrapping each in a span with the highlightClass CSS class - for (matchNum=0; matchNum < matches.length; matchNum++) { - var thisPos = matchArray[i].indexOf(matches[matchNum], startLoc); - var endPos = thisPos + matches[matchNum].length; - var thisSpan = "" + matches[matchNum] + ""; - matchArray[i] = matchArray[i].substr(0, thisPos) + thisSpan + matchArray[i].substr(endPos); - startLoc = thisPos + thisSpan.length; - } - } - // Add the value to the markup for the container - out += "
  • " + matchArray[i] + "
  • "; - } - - // Add all the list elements to the containerId container - $("#" + containerId).html(out); - // Set up hehavior for the available values in the list element - $("#" + containerId + " li").click(function () { - $("#" + containerId).fadeOut(opt.slideUpSpeed); - $("#" + columnObjId).val($(this).text()); - }).mouseover(function () { - var mouseoverCss = { - "cursor": "hand", - "color": "#ffffff", - "background": "#3399ff" - }; - $(this).css(mouseoverCss); - }).mouseout(function () { - var mouseoutCss = { - "cursor": "inherit", - "color": columnObjColor, - "background": "transparent" - }; - $(this).css(mouseoutCss); - }); - - // If we've got some values to show, then show 'em! - if(matchArray.length > 0) { - $("#" + containerId).slideDown(opt.slideDownSpeed); - } - // Remove the processing indicator - columnObj.css("background-image", ""); - }); - - }; // End $.fn.SPServices.SPAutocomplete - - // Get the Query String parameters and their values and return in an array - $.fn.SPServices.SPGetQueryString = function () { - - var i; - var queryStringVals = {}; - - var qs = location.search.substring(1, location.search.length); - var args = qs.split("&"); - var rxQS = /^([^=]+)=(.*)/i; - - for (i=0; i < args.length; i++) { - matches = rxQS.exec(args[i]); - if (rxQS.test(location.href)) { - if (matches !== null && matches.length > 2) { - queryStringVals[matches[1]] = unescape(matches[2]).replace(/\+/g,' '); - } - } - } - return queryStringVals; - - }; // End $.fn.SPServices.SPGetQueryString - - // Get the current list's GUID (ID) from the current URL. Use of this function only makes sense if we're in a list's context, - // and we assume that we are calling it from an aspx page which is a form or view for the list. - $.fn.SPServices.SPListNameFromUrl = function (options) { - - var opt = $.extend({}, { - listName: "" // [Optional] Pass in the name or GUID of a list if you are not in its context. e.g., on a Web Part pages in the Pages library - }, options); - - // Has the list name or GUID been passed in? - if(opt.listName.length > 0) { - currentContext.thisList = opt.listName; - return currentContext.thisList; - // Do we already know the current list? - } else if(currentContext.thisList.length > 0) { - return currentContext.thisList; - } - - // Parse out the list's root URL from the current location or the passed url - var thisPage = location.href; - var thisPageBaseName = thisPage.substring(0, thisPage.indexOf(".aspx")); - var listPath = decodeURIComponent(thisPageBaseName.substring(0, thisPageBaseName.lastIndexOf(SLASH) + 1)).toUpperCase(); - - // Call GetListCollection and loop through the results to find a match with the list's URL to get the list's GUID - $().SPServices({ - operation: "GetListCollection", - async: false, - completefunc: function(xData, Status) { - $(xData.responseXML).find("List").each(function() { - var defaultViewUrl = $(this).attr("DefaultViewUrl"); - var listCollList = defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH) + 1).toUpperCase(); - if(listPath.indexOf(listCollList) > 0) { - currentContext.thisList = $(this).attr("ID"); - return false; - } - }); - } - }); - - // Return the list GUID (ID) - return currentContext.thisList; - - }; // End $.fn.SPServices.SPListNameFromUrl - - // SPUpdateMultipleListItems allows you to update multiple items in a list based upon some common characteristic or metadata criteria. - $.fn.SPServices.SPUpdateMultipleListItems = function(options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] URL of the target Web. If not specified, the current Web is used. - listName: "", // The list to operate on. - CAMLQuery: "", // A CAML fragment specifying which items in the list will be selected and updated - batchCmd: "Update", // The operation to perform. By default, Update. - valuepairs: [], // Valuepairs for the update in the form [[fieldname1, fieldvalue1], [fieldname2, fieldvalue2]...] - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var i; - var itemsToUpdate = []; - var documentsToUpdate = []; - - // Call GetListItems to find all of the items matching the CAMLQuery - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: opt.CAMLQuery, - CAMLQueryOptions: "", - completefunc: function(xData, Status) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - itemsToUpdate.push($(this).attr("ows_ID")); - var fileRef = $(this).attr("ows_FileRef"); - fileRef = "/" + fileRef.substring(fileRef.indexOf(";#")+2); - documentsToUpdate.push(fileRef); - }); - } - }); - - var fieldNum; - var batch = ""; - for(i=0; i < itemsToUpdate.length; i++) { - batch += ""; - for (fieldNum=0; fieldNum < opt.valuepairs.length; fieldNum++) { - batch += "" + escapeColumnValue(opt.valuepairs[fieldNum][1]) + ""; - } - batch += "" + itemsToUpdate[i] + ""; - if(documentsToUpdate[i].length > 0) { - batch += "" + documentsToUpdate[i] + ""; - } - batch += ""; - } - batch += ""; - - // Call UpdateListItems to update all of the items matching the CAMLQuery - $().SPServices({ - operation: "UpdateListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - updates: batch, - completefunc: function(xData, Status) { - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(xData, Status); - } - } - }); - - }; // End $.fn.SPServices.SPUpdateMultipleListItems - - // This method for finding specific nodes in the returned XML was developed by Steve Workman. See his blog post - // http://www.steveworkman.com/html5-2/javascript/2011/improving-javascript-xml-node-finding-performance-by-2000/ - // for performance details. - $.fn.SPFilterNode = function(name) { - return this.find('*').filter(function() { - return this.nodeName === name; - }); - }; // End $.fn.SPFilterNode - - - // This function converts an XML node set to JSON - // Initial implementation focuses only on GetListItems - $.fn.SPXmlToJson = function(options) { - - var opt = $.extend({}, { - mapping: {}, // columnName: mappedName: "mappedName", objectType: "objectType" - includeAllAttrs: false, // If true, return all attributes, regardless whether they are in the mapping - removeOws: true // Specifically for GetListItems, if true, the leading ows_ will be stripped off the field name - }, options); - - var colNum; - var jsonObject = []; - - this.each(function() { - var row = {}; - var colValue; - var rowAttrs = this.attributes; - - // Bring back all mapped columns, even those with no value - $.each(opt.mapping, function() { - row[this.mappedName] = ""; - }); - - // Parse through the element's attributes - for(attrNum = 0; attrNum < rowAttrs.length; attrNum++) { - var thisAttrName = rowAttrs[attrNum].name; - var thisMapping = opt.mapping[thisAttrName]; - var thisObjectName = thisMapping !== undefined ? thisMapping.mappedName : opt.removeOws ? thisAttrName.split("ows_")[1] : thisAttrName; - var thisObjectType = thisMapping !== undefined ? thisMapping.objectType : undefined; - if(opt.includeAllAttrs || thisMapping !== undefined) { - row[thisObjectName] = attrToJson(rowAttrs[attrNum].value, thisObjectType); - } - } - // Push this item into the JSON Object - jsonObject.push(row); - - }); - - // Return the JSON object - return jsonObject; - - }; // End $.fn.SPServices.SPXmlToJson - - - function attrToJson(v, objectType) { - - switch (objectType) { - case "DateTime": - case "datetime": // For calculated columns, stored as datetime;#value - // Dates have dashes instead of slashes: ows_Created="2009-08-25 14:24:48" - colValue = dateToJsonObject(v); - break; - case "User": - colValue = userToJsonObject(v); - break; - case "UserMulti": - colValue = userMultiToJsonObject(v); - break; - case "Lookup": - colValue = lookupToJsonObject(v); - break; - case "LookupMulti": - colValue = lookupMultiToJsonObject(v); - break; - case "Boolean": - colValue = booleanToJsonObject(v); - break; - case "Integer": - colValue = intToJsonObject(v); - break; - case "Counter": - colValue = intToJsonObject(v); - break; - case "MultiChoice": - colValue = choiceMultiToJsonObject(v); - break; - case "Currency": - case "float": // For calculated columns, stored as float;#value - colValue = floatToJsonObject(v); - break; - case "Calc": - colValue = calcToJsonObject(v); - break; - default: - // All other objectTypes will be simple strings - colValue = stringToJsonObject(v); - break; - } - return colValue; - } - - function stringToJsonObject(s) { - return s; - } - function intToJsonObject(s) { - return parseInt(s, 10); - } - function floatToJsonObject(s) { - return parseFloat(s); - } - function booleanToJsonObject(s) { - var out = s === "0" ? false : true; - return out; - } - function dateToJsonObject(s) { - return new Date(s.replace(/-/g, "/")); - } - function userToJsonObject(s) { - if (s.length === 0) { - return null; - } else { - var thisUser = new SplitIndex(s); - var thisUserExpanded = thisUser.value.split(",#"); - if(thisUserExpanded.length == 1) { - return {userId: thisUser.Id, userName: thisUser.value}; - } else { - return { - userId: thisUser.Id, - userName: thisUserExpanded[0].replace( /(,,)/g, ","), - loginName: thisUserExpanded[1].replace( /(,,)/g, ","), - email: thisUserExpanded[2].replace( /(,,)/g, ","), - sipAddress: thisUserExpanded[3].replace( /(,,)/g, ","), - title: thisUserExpanded[4].replace( /(,,)/g, ",") - }; - } - } - } - function userMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisUserMultiObject = []; - var thisUserMulti = s.split(";#"); - for(i=0; i < thisUserMulti.length; i=i+2) { - var thisUser = userToJsonObject(thisUserMulti[i] + ";#" + thisUserMulti[i+1]); - thisUserMultiObject.push(thisUser); - } - return thisUserMultiObject; - } - } - function lookupToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookup = new SplitIndex(s); - return {lookupId: thisLookup.id, lookupValue: thisLookup.value}; - } - } - function lookupMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookupMultiObject = []; - var thisLookupMulti = s.split(";#"); - for(i=0; i < thisLookupMulti.length; i=i+2) { - var thisLookup = lookupToJsonObject(thisLookupMulti[i] + ";#" + thisLookupMulti[i+1]); - thisLookupMultiObject.push(thisLookup); - } - return thisLookupMultiObject; - } - } - function choiceMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisChoiceMultiObject = []; - var thisChoiceMulti = s.split(";#"); - for(i=0; i < thisChoiceMulti.length; i++) { - if(thisChoiceMulti[i].length !== 0) { - thisChoiceMultiObject.push(thisChoiceMulti[i]); - } - } - return thisChoiceMultiObject; - } - } - function calcToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisCalc = s.split(";#"); - // The first value will be the calculated column value type, the second will be the value - return attrToJson(thisCalc[1], thisCalc[0]); - } - } - - // Find a People Picker in the page - // Returns references to: - // row - The TR which contains the People Picker (useful if you'd like to hide it at some point) - // contents - The element which contains the current value - // currentValue - The current value if it is set - // checkNames - The Check Names image (in case you'd like to click it at some point) - $.fn.SPFindPeoplePicker = function(options) { - - var opt = $.extend({}, { - peoplePickerDisplayName: "", // The displayName of the People Picker on the form - valueToSet: "", // The value to set the People Picker to. Should be a string containing each username or groupname separated by semi-colons. - checkNames: true // If set to true, the Check Names image will be clicked to resolve the names - }, options); - - var thisRow = $("nobr").filter(function() { - // Ensures we get a match whether or not the People Picker is required (if required, the nobr contains a span also) - return $(this).contents().eq(0).text() === opt.peoplePickerDisplayName; - }).closest("tr"); - - var thisContents = thisRow.find("div[name='upLevelDiv']"); - var thisCheckNames = thisRow.find("img[Title='Check Names']:first"); - - // If a value was provided, set the value - if(opt.valueToSet.length > 0) { - thisContents.html(opt.valueToSet); - } - - // If checkName is true, click the check names icon - if(opt.checkNames) { - thisCheckNames.click(); - } - var thisCurrentValue = $.trim(thisContents.text()); - - // Parse the entity data - var dictionaryEntries = []; - - // IE - thisContents.children("span").each(function() { - - // Grab the entity data - var thisData = $(this).find("div[data]").attr("data"); - - var dictionaryEntry = {}; - - // Entity data is only available in IE - if(thisData != undefined) { - var arrayOfDictionaryEntry = $.parseXML(thisData); - $xml = $(arrayOfDictionaryEntry); - - $xml.find("DictionaryEntry").each(function() { - var key = $(this).find("Key").text(); - var value = $(this).find("Value").text(); - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - // For other browsers, we'll call GetUserInfo to get the data - } else { - $().SPServices({ - operation: "GetUserInfo", - async: false, - cacheXML: true, - userLoginName: $(this).attr("title"), - completefunc: function(xData, Status) { - - $(xData.responseXML).find("User").each(function() { - - $.each(this.attributes, function(i, attrib){ - var key = attrib.name; - var value = attrib.value; - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - }); - } - }); - } - }); - - return {row: thisRow, contents: thisContents, currentValue: thisCurrentValue, checkNames: thisCheckNames, dictionaryEntries: dictionaryEntries}; - }; - - // Return the current version of SPServices as a string - $.fn.SPServices.Version = function () { - - return VERSION; - - }; // End $.fn.SPServices.Version - - -////// PRIVATE FUNCTIONS //////// - - // Get the current context (as much as we can) on startup - // See: http://johnliu.net/blog/2012/2/3/sharepoint-javascript-current-page-context-info.html - function SPServicesContext() { - - // SharePoint 2010 gives us a context variable - if(typeof _spPageContextInfo !== "undefined") { - this.thisSite = _spPageContextInfo.webServerRelativeUrl; - this.thisList = _spPageContextInfo.pageListId; - this.thisUserId = _spPageContextInfo.userId; - // In SharePoint 2007, we know the UserID only - } else { - this.thisSite = ""; - this.thisList = ""; - this.thisUserId = _spUserId; - } - - } // End of function SPServicesContext - - - // Display a column (field) formatted correctly based on its definition in the list. - // NOTE: Currently not dealing with locale differences. - // columnXML The XML node for the column from a GetList operation - // columnValue The text representation of the column's value - // opt The current set of options - function showColumn(listXML, columnXML, columnValue, opt) { - - if(typeof columnValue === 'undefined') { - return ""; - } - - var i; - var outString = ""; - var dispUrl; - var numDecimals; - var outArray =[]; - var webUrl = opt.relatedWebURL.length > 0 ? opt.relatedWebURL : $().SPServices.SPGetCurrentSite(); - - switch(columnXML.attr("Type")) { - case "Text": - outString = columnValue; - break; - case "URL": - switch(columnXML.attr("Format")) { - // URL as hyperlink - case "Hyperlink": - outString = "
    " + - columnValue.substring(columnValue.search(",") + 1) + ""; - break; - // URL as image - case "Image": - outString = "" + columnValue.substring(columnValue.search(",") + 1) +
-							""; - break; - // Just in case - default: - outString = columnValue; - break; - } - break; - case "User": - case "UserMulti": - var userMultiValues = columnValue.split(";#"); - for(i=0; i < userMultiValues.length; i = i+2) { - outArray.push("" + - userMultiValues[i+1] + ""); - } - outString = outArray.join(", "); - break; - case "Calculated": - var calcColumn = columnValue.split(";#"); - outString = calcColumn[1]; - break; - case "Number": - numDecimals = columnXML.attr("Decimals"); - outString = numDecimals === undefined ? - parseFloat(columnValue).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Currency": - numDecimals = columnXML.attr("Decimals"); - outString = numDecimals === undefined ? - parseFloat(columnValue).toFixed(2).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Lookup": - switch(columnXML.attr("Name")) { - case "FileRef": - // Get the display form URL for the lookup source list - dispUrl = listXML.attr("BaseType") === "1" ? listXML.attr("RootFolder") + SLASH + "Forms/DispForm.aspx" : - listXML.attr("RootFolder") + SLASH + "DispForm.aspx"; - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - case "FileDirRef": - // Get the display form URL for the lookup source list - dispUrl = SLASH + columnValue.substring(columnValue.search(";#") + 2); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - // Any other lookup column - default: - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - } - break; - case "LookupMulti": - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - // Show all the values as links to the items, separated by commas - outString = ""; - if(columnValue.length > 0) { - var lookupMultiValues = columnValue.split(";#"); - for(i=0; i < lookupMultiValues.length / 2; i++) { - outArray.push("" + - lookupMultiValues[(i * 2) + 1] + ""); - } - } - outString = outArray.join(", "); - break; - case "File": - fileName = columnValue.substring(columnValue.search(";#") + 2); - outString = "" + fileName + ""; - break; - case "Counter": - outString = columnValue; - break; - case "DateTime": - outString = columnValue; - break; - default: - outString = columnValue; - break; - } - return outString; - } // End of function showColumn - - - // Show a single attribute of a node, enclosed in a table - // node The XML node - // opt The current set of options - function showAttrs(node, opt) { - var i; - var out = ""; - for (i=0; i < node.attributes.length; i++) { - out += ""; - } - out += "
    " + i + "" + - node.attributes.item(i).nodeName + "" + checkLink(node.attributes.item(i).nodeValue) + "
    "; - return out; - } // End of function showAttrs - - - // Find a dropdown (or multi-select) in the DOM. Returns the dropdown onject and its type: - // S = Simple (select);C = Compound (input + select hybrid);M = Multi-select (select hybrid) - function DropdownCtl(colName) { - // Simple - if((this.Obj = $("select[Title='" + colName + "']")).length === 1) { - this.Type = "S"; - // Compound - } else if((this.Obj = $("input[Title='" + colName + "']")).length === 1) { - this.Type = "C"; - // Multi-select: This will find the multi-select column control in English and most other languages sites where the Title looks like 'Column Name possible values' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title^='" + colName + " ']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Russian site (and perhaps others) where the Title looks like 'Выбранных значений: Column Name' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=': " + colName + "']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a German site (and perhaps others) where the Title looks like 'Mögliche Werte für "Column name".' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$='\"" + colName + "\".']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Italian site (and perhaps others) where the Title looks like "Valori possibili Column name" - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=' " + colName + "']")).length === 1) { - this.Type = "M"; - } else { - this.Type = null; - } - } // End of function DropdownCtl - - - // Returns the selected value(s) for a dropdown in an array. Expects a dropdown object as returned by the DropdownCtl function. - // If matchOnId is true, returns the ids rather than the text values for the selection options(s). - function getDropdownSelected(columnSelect, matchOnId) { - - var columnSelectSelected = []; - - switch(columnSelect.Type) { - case "S": - if(matchOnId) { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").text() || []); - } - break; - case "C": - if(matchOnId) { - columnSelectSelected.push($("input[id='"+ columnSelect.Obj.attr("optHid") + "']").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.attr("value") || []); - } - break; - case "M": - var columnSelections = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - $(columnSelections).find("option").each(function() { - columnSelectSelected.push($(this).html()); - }); - break; - default: - break; - } - return columnSelectSelected; - - } // End of function getDropdownSelected - - // Build an error message based on passed parameters - function errBox(func, param, msg) { - var errMsg = "Error in function
    " + func + "
    " + - "Parameter
    " + param + "
    " + - "Message
    " + msg + "

    " + - "Click to continue
    "; - modalBox(errMsg); - } // End of function errBox - - // Call this function to pop up a branded modal msgBox - function modalBox(msg) { - var boxCSS = "position:absolute;width:300px;height:150px;padding:10px;background-color:#000000;color:#ffffff;z-index:30;font-family:'Arial';font-size:12px;display:none;"; - $("#aspnetForm").parent().append("
    " + msg); - var height = $("#SPServices_msgBox").height(); - var width = $("#SPServices_msgBox").width(); - var leftVal = ($(window).width() / 2) - (width / 2) + "px"; - var topVal = ($(window).height() / 2) - (height / 2) - 100 + "px"; - $("#SPServices_msgBox").css({border:'5px #C02000 solid', left:leftVal, top:topVal}).show().fadeTo("slow", 0.75).click(function () { - $(this).fadeOut("3000", function () { - $(this).remove(); - }); - }); - } // End of function modalBox - - // Generate a unique id for a containing div using the function name and the column display name - function genContainerId(funcname, columnName) { - return funcname + "_" + $().SPServices.SPGetStaticFromDisplay({ - listName: $().SPServices.SPListNameFromUrl(), - columnDisplayName: columnName - }); - } // End of function genContainerId - - // Get the URL for a specified form for a list - function getListFormUrl(l, f) { - - var thisForm, u; - - $().SPServices({ - operation: "GetFormCollection", - async: false, - listName: l, - completefunc: function (xData, Status) { - u = $(xData.responseXML).find("Form[Type='" + f + "']").attr("Url"); - } - }); - return u; - - } // End of function getListFormUrl - - // Add the option values to the SOAPEnvelope.payload for the operation - // opt = options for the call - // paramArray = an array of option names to add to the payload - // "paramName" if the parameter name and the option name match - // ["paramName", "optionName"] if the parameter name and the option name are different (this handles early "wrappings" with inconsistent naming) - function addToPayload(opt, paramArray) { - - var i; - - for (i=0; i < paramArray.length; i++) { - // the parameter name and the option name match - if(typeof paramArray[i] === "string") { - SOAPEnvelope.payload += wrapNode(paramArray[i], opt[paramArray[i]]); - // the parameter name and the option name are different - } else if(paramArray[i].length === 2) { - SOAPEnvelope.payload += wrapNode(paramArray[i][0], opt[paramArray[i][1]]); - // something isn't right, so report it - } else { - errBox(opt.operation, "paramArray[" + i + "]: " + paramArray[i], "Invalid paramArray element passed to addToPayload()"); - } - } - } // End of function addToPayload - - // Finds the td which contains a form field in default forms using the comment which contains: - // - // as the "anchor" to find it. Necessary because SharePoint doesn't give all field types ids or specific classes. - function findFormField(columnName) { - var thisFormBody; - // There's no easy way to find one of these columns; we'll look for the comment with the columnName - var searchText = RegExp("FieldName=\"" + columnName.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&") + "\"", "gi"); - // Loop through all of the ms-formbody table cells - $("td.ms-formbody, td.ms-formbodysurvey").each(function() { - // Check for the right comment - if(searchText.test($(this).html())) { - thisFormBody = $(this); - // Found it, so we're done - return false; - } - }); - return thisFormBody; - } // End of function findFormField - - // The SiteData operations have the same names as other Web Service operations. To make them easy to call and unique, I'm using - // the SiteData prefix on their names. This function replaces that name with the right name in the SOAPEnvelope. - function siteDataFixSOAPEnvelope(SOAPEnvelope, siteDataOperation) { - var siteDataOp = siteDataOperation.substring(8); - SOAPEnvelope.opheader = SOAPEnvelope.opheader.replace(siteDataOperation, siteDataOp); - SOAPEnvelope.opfooter = SOAPEnvelope.opfooter.replace(siteDataOperation, siteDataOp); - return SOAPEnvelope; - } // End of function siteDataFixSOAPEnvelope - - // Wrap an XML node (n) around a value (v) - function wrapNode(n, v) { - var thisValue = v !== undefined ? v : ""; - return "<" + n + ">" + thisValue + ""; - } - - // Generate a random number for sorting arrays randomly - function randOrd() { - return (Math.round(Math.random())-0.5); - } - - // If a string is a URL, format it as a link, else return the string as-is - function checkLink(s) { - return ((s.indexOf("http") === 0) || (s.indexOf(SLASH) === 0)) ? "" + s + "" : s; - } - - // Get the filename from the full URL - function fileName(s) { - return s.substring(s.lastIndexOf(SLASH)+1,s.length); - } - -/* Taken from http://dracoblue.net/dev/encodedecode-special-xml-characters-in-javascript/155/ */ - var xml_special_to_escaped_one_map = { - '&': '&', - '"': '"', - '<': '<', - '>': '>'}; - var escaped_one_to_xml_special_map = { - '&': '&', - '"': '"', - '<': '<', - '>': '>'}; - - function encodeXml(string) { - return string.replace(/([\&"<>])/g, function(str, item) { - return xml_special_to_escaped_one_map[item]; - }); - } - function decodeXml(string) { - return string.replace(/("|<|>|&)/g, - function(str, item) { - return escaped_one_to_xml_special_map[item]; - }); - } -/* Taken from http://dracoblue.net/dev/encodedecode-special-xml-characters-in-javascript/155/ */ - - // Escape column values - function escapeColumnValue(s) { - if(typeof s === "string") { - return s.replace(/&(?![a-zA-Z]{1,8};)/g, "&"); - } else { - return s; - } - } - - // Escape Url - function escapeUrl(u) { - return u.replace(/&/g,'%26'); - } - - // Split values like 1;#value into id and value - function SplitIndex(s) { - var spl = s.split(";#"); - this.id = spl[0]; - this.value = spl[1]; - } - - -})(jQuery); \ No newline at end of file diff --git a/jquery.SPServices-2013.01ALPHA3.js b/jquery.SPServices-2013.01ALPHA3.js deleted file mode 100644 index 682f16a..0000000 --- a/jquery.SPServices-2013.01ALPHA3.js +++ /dev/null @@ -1,4068 +0,0 @@ -/* - * SPServices - Work with SharePoint's Web Services using jQuery - * Version 0.7.3 - * @requires jQuery v1.5 or greater - jQuery 1.7+ recommended - * - * Copyright (c) 2009-2013 Sympraxis Consulting LLC - * Examples and docs at: - * http://spservices.codeplex.com - * Licensed under the MIT license: - * http://www.opensource.org/licenses/mit-license.php - */ -/* - * @description Work with SharePoint's Web Services using jQuery - * @type jQuery - * @name SPServices - * @category Plugins/SPServices - * @author Sympraxis Consulting LLC/marc.anderson@sympraxisconsulting.com - */ -/* jshint undef: true */ -/* global _spUserId, _spPageContextInfo, GipAddSelectedItems, GipRemoveSelectedItems, GipGetGroupData */ - -(function ($) { - - "use strict"; - - // Version info - var VERSION = "0.7.3"; // TODO: Update version - - // String constants - // General - var SLASH = "/"; - var TXTColumnNotFound = "Column not found on page"; - var SCHEMASharePoint = "http://schemas.microsoft.com/sharepoint"; - - // Caching - var promisesCache = {}; - - // Web Service names - var ALERTS = "Alerts"; - var AUTHENTICATION = "Authentication"; - var COPY = "Copy"; - var FORMS = "Forms"; - var LISTS = "Lists"; - var MEETINGS = "Meetings"; - var PEOPLE = "People"; - var PERMISSIONS = "Permissions"; - var PUBLISHEDLINKSSERVICE = "PublishedLinksService"; - var SEARCH = "Search"; - var SHAREPOINTDIAGNOSTICS = "SharePointDiagnostics"; - var SITEDATA = "SiteData"; - var SITES = "Sites"; - var SOCIALDATASERVICE = "SocialDataService"; - var SPELLCHECK = "SpellCheck"; - var TAXONOMYSERVICE = "TaxonomyClientService"; - var USERGROUP = "usergroup"; - var USERPROFILESERVICE = "UserProfileService"; - var VERSIONS = "Versions"; - var VIEWS = "Views"; - var WEBPARTPAGES = "WebPartPages"; - var WEBS = "Webs"; - var WORKFLOW = "Workflow"; - - // Global variables - var currentContext = new SPServicesContext(); // Variable to hold the current context as we figure it out - var i = 0; // Generic loop counter - var encodeOptionList = ["listName", "description"]; // Used to encode options which may contain special characters - - - // Array to store Web Service information - // WSops.OpName = [WebService, needs_SOAPAction]; - // OpName The name of the Web Service operation -> These names are unique - // WebService The name of the WebService this operation belongs to - // needs_SOAPAction Boolean indicating whether the operatio needs to have the SOAPAction passed in the setRequestHeaderfunction. - // true if the operation does a write, else false - - var WSops = []; - - WSops.GetAlerts = [ALERTS, false]; - WSops.DeleteAlerts = [ALERTS, true]; - - WSops.Mode = [AUTHENTICATION, false]; - WSops.Login = [AUTHENTICATION, false]; - - WSops.CopyIntoItems = [COPY, true]; - WSops.CopyIntoItemsLocal = [COPY, true]; - WSops.GetItem = [COPY, false]; - - WSops.GetForm = [FORMS, false]; - WSops.GetFormCollection = [FORMS, false]; - - WSops.AddAttachment = [LISTS, true]; - WSops.AddDiscussionBoardItem = [LISTS, true]; - WSops.AddList = [LISTS, true]; - WSops.AddListFromFeature = [LISTS, true]; - WSops.ApplyContentTypeToList = [LISTS, true]; - WSops.CheckInFile = [LISTS, true]; - WSops.CheckOutFile = [LISTS, true]; - WSops.CreateContentType = [LISTS, true]; - WSops.DeleteAttachment = [LISTS, true]; - WSops.DeleteContentType = [LISTS, true]; - WSops.DeleteContentTypeXmlDocument = [LISTS, true]; - WSops.DeleteList = [LISTS, true]; - WSops.GetAttachmentCollection = [LISTS, false]; - WSops.GetList = [LISTS, false]; - WSops.GetListAndView = [LISTS, false]; - WSops.GetListCollection = [LISTS, false]; - WSops.GetListContentType = [LISTS, false]; - WSops.GetListContentTypes = [LISTS, false]; - WSops.GetListItemChanges = [LISTS, false]; - WSops.GetListItemChangesSinceToken = [LISTS, false]; - WSops.GetListItems = [LISTS, false]; - WSops.GetVersionCollection = [LISTS, false]; - WSops.UndoCheckOut = [LISTS, true]; - WSops.UpdateContentType = [LISTS, true]; - WSops.UpdateContentTypesXmlDocument = [LISTS, true]; - WSops.UpdateContentTypeXmlDocument = [LISTS, true]; - WSops.UpdateList = [LISTS, true]; - WSops.UpdateListItems = [LISTS, true]; - - WSops.AddMeeting = [MEETINGS, true]; - WSops.CreateWorkspace = [MEETINGS, true]; - WSops.RemoveMeeting = [MEETINGS, true]; - WSops.SetWorkSpaceTitle = [MEETINGS, true]; - - WSops.ResolvePrincipals = [PEOPLE, false]; - WSops.SearchPrincipals = [PEOPLE, false]; - - WSops.AddPermission = [PERMISSIONS, true]; - WSops.AddPermissionCollection = [PERMISSIONS, true]; - WSops.GetPermissionCollection = [PERMISSIONS, true]; - WSops.RemovePermission = [PERMISSIONS, true]; - WSops.RemovePermissionCollection = [PERMISSIONS, true]; - WSops.UpdatePermission = [PERMISSIONS, true]; - - WSops.GetLinks = [PUBLISHEDLINKSSERVICE, true]; - - WSops.GetPortalSearchInfo = [SEARCH, false]; - WSops.GetQuerySuggestions = [SEARCH, false]; - WSops.GetSearchMetadata = [SEARCH, false]; - WSops.Query = [SEARCH, false]; - WSops.QueryEx = [SEARCH, false]; - WSops.Registration = [SEARCH, false]; - WSops.Status = [SEARCH, false]; - - WSops.SendClientScriptErrorReport = [SHAREPOINTDIAGNOSTICS,true]; - - WSops.GetAttachments = [SITEDATA, false]; - WSops.EnumerateFolder = [SITEDATA, false]; - WSops.SiteDataGetList = [SITEDATA, false]; - WSops.SiteDataGetListCollection = [SITEDATA, false]; - WSops.SiteDataGetSite = [SITEDATA, false]; - WSops.SiteDataGetSiteUrl = [SITEDATA, false]; - WSops.SiteDataGetWeb = [SITEDATA, false]; - - WSops.CreateWeb = [SITES, true]; - WSops.DeleteWeb = [SITES, false]; - WSops.GetSite = [SITES, false]; - WSops.GetSiteTemplates = [SITES, false]; - - WSops.AddComment = [SOCIALDATASERVICE, true]; - WSops.AddTag = [SOCIALDATASERVICE, true]; - WSops.AddTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.CountCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountTagsOfUser = [SOCIALDATASERVICE, false]; - WSops.DeleteComment = [SOCIALDATASERVICE, true]; - WSops.DeleteRating = [SOCIALDATASERVICE, true]; - WSops.DeleteTag = [SOCIALDATASERVICE, true]; - WSops.DeleteTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.DeleteTags = [SOCIALDATASERVICE, true]; - WSops.GetAllTagTerms = [SOCIALDATASERVICE, false]; - WSops.GetAllTagTermsForUrlFolder = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrls = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrlsByKeyword = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingAverageOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetSocialDataForFullReplication = [SOCIALDATASERVICE, false]; - WSops.GetTags = [SOCIALDATASERVICE, true]; - WSops.GetTagsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTerms = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOnUrl = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUserByKeyword = [SOCIALDATASERVICE, true]; - WSops.GetTagUrls = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsByKeyword = [SOCIALDATASERVICE, true]; - WSops.SetRating = [SOCIALDATASERVICE, true]; - WSops.UpdateComment = [SOCIALDATASERVICE, true]; - - WSops.SpellCheck = [SPELLCHECK, false]; - - // Taxonomy Service Calls - // Updated 2011.01.27 by Thomas McMillan - WSops.AddTerms = [TAXONOMYSERVICE, true]; - WSops.GetChildTermsInTerm = [TAXONOMYSERVICE, false]; - WSops.GetChildTermsInTermSet = [TAXONOMYSERVICE, false]; - WSops.GetKeywordTermsByGuids = [TAXONOMYSERVICE, false]; - WSops.GetTermsByLabel = [TAXONOMYSERVICE, false]; - WSops.GetTermSets = [TAXONOMYSERVICE, false]; - - WSops.AddGroup = [USERGROUP, true]; - WSops.AddGroupToRole = [USERGROUP, true]; - WSops.AddRole = [USERGROUP, true]; - WSops.AddRoleDef = [USERGROUP, true]; - WSops.AddUserCollectionToGroup = [USERGROUP, true]; - WSops.AddUserCollectionToRole = [USERGROUP, true]; - WSops.AddUserToGroup = [USERGROUP, true]; - WSops.AddUserToRole = [USERGROUP, true]; - WSops.GetAllUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupCollection = [USERGROUP, false]; - WSops.GetGroupCollectionFromRole = [USERGROUP, false]; - WSops.GetGroupCollectionFromSite = [USERGROUP, false]; - WSops.GetGroupCollectionFromUser = [USERGROUP, false]; - WSops.GetGroupCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupInfo = [USERGROUP, false]; - WSops.GetRoleCollection = [USERGROUP, false]; - WSops.GetRoleCollectionFromGroup = [USERGROUP, false]; - WSops.GetRoleCollectionFromUser = [USERGROUP, false]; - WSops.GetRoleCollectionFromWeb = [USERGROUP, false]; - WSops.GetRoleInfo = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForCurrentUser = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForSite = [USERGROUP, false]; - WSops.GetUserCollection = [USERGROUP, false]; - WSops.GetUserCollectionFromGroup = [USERGROUP, false]; - WSops.GetUserCollectionFromRole = [USERGROUP, false]; - WSops.GetUserCollectionFromSite = [USERGROUP, false]; - WSops.GetUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetUserInfo = [USERGROUP, false]; - WSops.GetUserLoginFromEmail = [USERGROUP, false]; - WSops.RemoveGroup = [USERGROUP, true]; - WSops.RemoveGroupFromRole = [USERGROUP, true]; - WSops.RemoveRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromGroup = [USERGROUP, true]; - WSops.RemoveUserCollectionFromRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromSite = [USERGROUP, true]; - WSops.RemoveUserFromGroup = [USERGROUP, true]; - WSops.RemoveUserFromRole = [USERGROUP, true]; - WSops.RemoveUserFromSite = [USERGROUP, true]; - WSops.RemoveUserFromWeb = [USERGROUP, true]; - WSops.UpdateGroupInfo = [USERGROUP, true]; - WSops.UpdateRoleDefInfo = [USERGROUP, true]; - WSops.UpdateRoleInfo = [USERGROUP, true]; - WSops.UpdateUserInfo = [USERGROUP, true]; - - WSops.AddColleague = [USERPROFILESERVICE, true]; - WSops.AddLink = [USERPROFILESERVICE, true]; - WSops.AddMembership = [USERPROFILESERVICE, true]; - WSops.AddPinnedLink = [USERPROFILESERVICE, true]; - WSops.CreateMemberGroup = [USERPROFILESERVICE, true]; - WSops.CreateUserProfileByAccountName = [USERPROFILESERVICE, true]; - WSops.GetCommonColleagues = [USERPROFILESERVICE, false]; - WSops.GetCommonManager = [USERPROFILESERVICE, false]; - WSops.GetCommonMemberships = [USERPROFILESERVICE, false]; - WSops.GetInCommon = [USERPROFILESERVICE, false]; - WSops.GetPropertyChoiceList = [USERPROFILESERVICE, false]; - WSops.GetUserColleagues = [USERPROFILESERVICE, false]; - WSops.GetUserLinks = [USERPROFILESERVICE, false]; - WSops.GetUserMemberships = [USERPROFILESERVICE, false]; - WSops.GetUserPinnedLinks = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByGuid = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByIndex = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByName = [USERPROFILESERVICE, false]; - WSops.GetUserProfileCount = [USERPROFILESERVICE, false]; - WSops.GetUserProfileSchema = [USERPROFILESERVICE, false]; - WSops.ModifyUserPropertyByAccountName = [USERPROFILESERVICE, true]; - WSops.RemoveAllColleagues = [USERPROFILESERVICE, true]; - WSops.RemoveAllLinks = [USERPROFILESERVICE, true]; - WSops.RemoveAllMemberships = [USERPROFILESERVICE, true]; - WSops.RemoveAllPinnedLinks = [USERPROFILESERVICE, true]; - WSops.RemoveColleague = [USERPROFILESERVICE, true]; - WSops.RemoveLink = [USERPROFILESERVICE, true]; - WSops.RemoveMembership = [USERPROFILESERVICE, true]; - WSops.RemovePinnedLink = [USERPROFILESERVICE, true]; - WSops.UpdateColleaguePrivacy = [USERPROFILESERVICE, true]; - WSops.UpdateLink = [USERPROFILESERVICE, true]; - WSops.UpdateMembershipPrivacy = [USERPROFILESERVICE, true]; - WSops.UpdatePinnedLink = [USERPROFILESERVICE, true]; - - WSops.DeleteAllVersions = [VERSIONS, true]; - WSops.DeleteVersion = [VERSIONS, true]; - WSops.GetVersions = [VERSIONS, false]; - WSops.RestoreVersion = [VERSIONS, true]; - - WSops.AddView = [VIEWS, true]; - WSops.DeleteView = [VIEWS, true]; - WSops.GetView = [VIEWS, false]; - WSops.GetViewHtml = [VIEWS, false]; - WSops.GetViewCollection = [VIEWS, false]; - WSops.UpdateView = [VIEWS, true]; - WSops.UpdateViewHtml = [VIEWS, true]; - - WSops.AddWebPart = [WEBPARTPAGES, true]; - WSops.AddWebPartToZone = [WEBPARTPAGES, true]; - WSops.GetWebPart2 = [WEBPARTPAGES, false]; - WSops.GetWebPartPage = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties2 = [WEBPARTPAGES, false]; - - WSops.CreateContentType = [WEBS, true]; - WSops.GetColumns = [WEBS, false]; - WSops.GetContentType = [WEBS, false]; - WSops.GetContentTypes = [WEBS, false]; - WSops.GetCustomizedPageStatus = [WEBS, false]; - WSops.GetListTemplates = [WEBS, false]; - WSops.GetObjectIdFromUrl = [WEBS, false]; // 2010 - WSops.GetWeb = [WEBS, false]; - WSops.GetWebCollection = [WEBS, false]; - WSops.GetAllSubWebCollection = [WEBS, false]; - WSops.UpdateColumns = [WEBS, true]; - WSops.UpdateContentType = [WEBS, true]; - WSops.WebUrlFromPageUrl = [WEBS, false]; - - WSops.AlterToDo = [WORKFLOW, true]; - WSops.GetTemplatesForItem = [WORKFLOW, false]; - WSops.GetToDosForItem = [WORKFLOW, false]; - WSops.GetWorkflowDataForItem = [WORKFLOW, false]; - WSops.GetWorkflowTaskData = [WORKFLOW, false]; - WSops.StartWorkflow = [WORKFLOW, true]; - - // Set up SOAP envelope - var SOAPEnvelope = {}; - SOAPEnvelope.header = ""; - SOAPEnvelope.footer = ""; - SOAPEnvelope.payload = ""; - var SOAPAction; - - - // Main function, which calls SharePoint's Web Services directly. - $.fn.SPServices = function(options) { - - // If there are no options passed in, use the defaults. Extend replaces each default with the passed option. - var opt = $.extend({}, $.fn.SPServices.defaults, options); - - // Encode options which may contain special character, esp. ampersand - for(var i=0; i < encodeOptionList.length; i++) { - if(typeof opt[encodeOptionList[i]] === "string") { - opt[encodeOptionList[i]] = encodeXml(opt[encodeOptionList[i]]); - } - } - - // Put together operation header and SOAPAction for the SOAP call based on which Web Service we're calling - SOAPEnvelope.opheader = "<" + opt.operation + " "; - switch(WSops[opt.operation][0]) { - case ALERTS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/2002/1/alerts/' >"; - SOAPAction = SCHEMASharePoint + "/soap/2002/1/alerts/"; - break; - case MEETINGS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/meetings/' >"; - SOAPAction = SCHEMASharePoint + "/soap/meetings/"; - break; - case PERMISSIONS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case PUBLISHEDLINKSSERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/"; - break; - case SEARCH: - SOAPEnvelope.opheader += "xmlns='urn:Microsoft.Search' >"; - SOAPAction = "urn:Microsoft.Search/"; - break; - case SHAREPOINTDIAGNOSTICS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/diagnostics/' >"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/diagnostics/"; - break; - case SOCIALDATASERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/SocialDataService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/SocialDataService/"; - break; - case SPELLCHECK: - SOAPEnvelope.opheader += "xmlns='http://schemas.microsoft.com/sharepoint/publishing/spelling/'"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/publishing/spelling/SpellCheck"; - break; - case TAXONOMYSERVICE: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/taxonomy/soap/' >"; - SOAPAction = SCHEMASharePoint + "/taxonomy/soap/"; - break; - case USERGROUP: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case USERPROFILESERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/UserProfileService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/UserProfileService/"; - break; - case WEBPARTPAGES: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/sharepoint/webpartpages' >"; - SOAPAction = "http://microsoft.com/sharepoint/webpartpages/"; - break; - case WORKFLOW: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/workflow/' >"; - SOAPAction = SCHEMASharePoint + "/soap/workflow/"; - break; - default: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/'>"; - SOAPAction = SCHEMASharePoint + "/soap/"; - break; - } - - // Add the operation to the SOAPAction and opfooter - SOAPAction += opt.operation; - SOAPEnvelope.opfooter = ""; - - // Build the URL for the Ajax call based on which operation we're calling - // If the webURL has been provided, then use it, else use the current site - var ajaxURL = "_vti_bin/" + WSops[opt.operation][0] + ".asmx"; - if(opt.webURL.charAt(opt.webURL.length - 1) === SLASH) { - ajaxURL = opt.webURL + ajaxURL; - } else if(opt.webURL.length > 0) { - ajaxURL = opt.webURL + SLASH + ajaxURL; - } else { - ajaxURL = $().SPServices.SPGetCurrentSite() + SLASH + ajaxURL; - } - - SOAPEnvelope.payload = ""; - // Each operation requires a different set of values. This switch statement sets them up in the SOAPEnvelope.payload. - switch(opt.operation) { - // ALERT OPERATIONS - case "GetAlerts": - break; - case "DeleteAlerts": - SOAPEnvelope.payload += ""; - for (i=0; i < opt.IDs.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.IDs[i]); - } - SOAPEnvelope.payload += ""; - break; - - // AUTHENTICATION OPERATIONS - case "Mode": - break; - case "Login": - addToPayload(opt, ["username", "password"]); - break; - - // COPY OPERATIONS - case "CopyIntoItems": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - addToPayload(opt, ["Fields", "Stream", "Results"]); - break; - case "CopyIntoItemsLocal": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - break; - case "GetItem": - addToPayload(opt, ["Url", "Fields", "Stream"]); - break; - - // FORM OPERATIONS - case "GetForm": - addToPayload(opt, ["listName", "formUrl"]); - break; - case "GetFormCollection": - addToPayload(opt, ["listName"]); - break; - - // LIST OPERATIONS - case "AddAttachment": - addToPayload(opt, ["listName", "listItemID", "fileName", "attachment"]); - break; - case "AddDiscussionBoardItem": - addToPayload(opt, ["listName", "message"]); - break; - case "AddList": - addToPayload(opt, ["listName", "description", "templateID"]); - break; - case "AddListFromFeature": - addToPayload(opt, ["listName", "description", "featureID", "templateID"]); - break; - case "ApplyContentTypeToList": - addToPayload(opt, ["webUrl", "contentTypeId", "listName"]); - break; - case "CheckInFile": - addToPayload(opt, ["pageUrl", "comment", "CheckinType"]); - break; - case "CheckOutFile": - addToPayload(opt, ["pageUrl", "checkoutToLocal", "lastmodified"]); - break; - case "CreateContentType": - addToPayload(opt, ["listName", "displayName", "parentType", "fields", "contentTypeProperties", "addToView"]); - break; - case "DeleteAttachment": - addToPayload(opt, ["listName", "listItemID", "url"]); - break; - case "DeleteContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "DeleteContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "documentUri"]); - break; - case "DeleteList": - addToPayload(opt, ["listName"]); - break; - case "GetAttachmentCollection": - addToPayload(opt, ["listName", ["listItemID", "ID"]]); - break; - case "GetList": - addToPayload(opt, ["listName"]); - break; - case "GetListAndView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetListCollection": - break; - case "GetListContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "GetListContentTypes": - addToPayload(opt, ["listName"]); - break; - case "GetListItems": - addToPayload(opt, ["listName", "viewName", ["query", "CAMLQuery"], ["viewFields", "CAMLViewFields"], ["rowLimit", "CAMLRowLimit"], ["queryOptions", "CAMLQueryOptions"]]); - break; - case "GetListItemChanges": - addToPayload(opt, ["listName", "viewFields", "since", "contains"]); - break; - case "GetListItemChangesSinceToken": - addToPayload(opt, ["listName", "viewName", "query", "viewFields", "rowLimit", "queryOptions", "changeToken", "contains"]); - break; - case "GetVersionCollection": - addToPayload(opt, ["strlistID", "strlistItemID", "strFieldName"]); - break; - case "UndoCheckOut": - addToPayload(opt, ["pageUrl"]); - break; - case "UpdateContentType": - addToPayload(opt, ["listName", "contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields", "addToView"]); - break; - case "UpdateContentTypesXmlDocument": - addToPayload(opt, ["listName", "newDocument"]); - break; - case "UpdateContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "newDocument"]); - break; - case "UpdateList": - addToPayload(opt, ["listName", "listProperties", "newFields", "updateFields", "deleteFields", "listVersion"]); - break; - case "UpdateListItems": - addToPayload(opt, ["listName"]); - if(typeof opt.updates !== "undefined" && opt.updates.length > 0) { - addToPayload(opt, ["updates"]); - } else { - SOAPEnvelope.payload += ""; - for (i=0; i < opt.valuepairs.length; i++) { - SOAPEnvelope.payload += "" + escapeColumnValue(opt.valuepairs[i][1]) + ""; - } - if(opt.batchCmd !== "New") { - SOAPEnvelope.payload += "" + opt.ID + ""; - } - SOAPEnvelope.payload += ""; - } - break; - - // MEETINGS OPERATIONS - case "AddMeeting": - addToPayload(opt, ["organizerEmail", "uid", "sequence", "utcDateStamp", "title", "location", "utcDateStart", "utcDateEnd", "nonGregorian"]); - break; - case "CreateWorkspace": - addToPayload(opt, ["title", "templateName", "lcid", "timeZoneInformation"]); - break; - case "RemoveMeeting": - addToPayload(opt, ["recurrenceId", "uid", "sequence", "utcDateStamp", "cancelMeeting"]); - break; - case "SetWorkspaceTitle": - addToPayload(opt, ["title"]); - break; - - // PEOPLE OPERATIONS - case "ResolvePrincipals": - addToPayload(opt, ["principalKeys", "principalType", "addToUserInfoList"]); - break; - case "SearchPrincipals": - addToPayload(opt, ["searchText", "maxResults", "principalType"]); - break; - - // PERMISSION OPERATIONS - case "AddPermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - case "AddPermissionCollection": - addToPayload(opt, ["objectName", "objectType", "permissionsInfoXml"]); - break; - case "GetPermissionCollection": - addToPayload(opt, ["objectName", "objectType"]); - break; - case "RemovePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType"]); - break; - case "RemovePermissionCollection": - addToPayload(opt, ["objectName", "objectType", "memberIdsXml"]); - break; - case "UpdatePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - - // PUBLISHEDLINKSSERVICE OPERATIONS - case "GetLinks": - break; - - // SEARCH OPERATIONS - case "GetPortalSearchInfo": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "GetQuerySuggestions": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "GetSearchMetadata": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "Query": - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "QueryEx": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "Registration": - SOAPEnvelope.payload += wrapNode("registrationXml", encodeXml(opt.registrationXml)); - break; - case "Status": - break; - - // SHAREPOINTDIAGNOSTICS OPERATIONS - case "SendClientScriptErrorReport": - addToPayload(opt, ["message", "file", "line", "client", "stack", "team", "originalFile"]); - break; - - // SITEDATA OPERATIONS - case "EnumerateFolder": - addToPayload(opt, ["strFolderUrl"]); - break; - case "GetAttachments": - addToPayload(opt, ["strListName", "strItemId"]); - break; - case "SiteDataGetList": - addToPayload(opt, ["strListName"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetListCollection": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSite": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSiteUrl": - addToPayload(opt, ["Url"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetWeb": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - - // SITES OPERATIONS - case "CreateWeb": - addToPayload(opt, ["url", "title", "description", "templateName", "language", "languageSpecified", - "locale", "localeSpecified", "collationLocale", "collationLocaleSpecified", "uniquePermissions", - "uniquePermissionsSpecified", "anonymous", "anonymousSpecified", "presence", "presenceSpecified"]); - break; - case "DeleteWeb": - addToPayload(opt, ["url"]); - break; - case "GetSite": - addToPayload(opt, ["SiteUrl"]); - break; - case "GetSiteTemplates": - addToPayload(opt, ["LCID", "TemplateList"]); - break; - - // SOCIALDATASERVICE OPERATIONS - case "AddComment": - addToPayload(opt, ["url", "comment", "isHighPriority", "title"]); - break; - case "AddTag": - addToPayload(opt, ["url", "termID", "title", "isPrivate"]); - break; - case "AddTagByKeyword": - addToPayload(opt, ["url", "keyword", "title", "isPrivate"]); - break; - case "CountCommentsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "CountCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "CountCommentsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountTagsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "DeleteComment": - addToPayload(opt, ["url", "lastModifiedTime"]); - break; - case "DeleteRating": - addToPayload(opt, ["url"]); - break; - case "DeleteTag": - addToPayload(opt, ["url", "termID"]); - break; - case "DeleteTagByKeyword": - addToPayload(opt, ["url", "keyword"]); - break; - case "DeleteTags": - addToPayload(opt, ["url"]); - break; - case "GetAllTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetAllTagTermsForUrlFolder": - addToPayload(opt, ["urlFolder", "maximumItemsToReturn"]); - break; - case "GetAllTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetAllTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetCommentsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetCommentsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn", "startIndex"]); - if(typeof opt.excludeItemsTime !== "undefined" && opt.excludeItemsTime.length > 0) { - SOAPEnvelope.payload += wrapNode("excludeItemsTime", opt.excludeItemsTime); - } - break; - case "GetRatingAverageOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetRatingOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "GetRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetSocialDataForFullReplication": - addToPayload(opt, ["userAccountName"]); - break; - case "GetTags": - addToPayload(opt, ["url"]); - break; - case "GetTagsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetTagTermsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn"]); - break; - case "GetTagTermsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn"]); - break; - case "GetTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetTagUrlsOfUser": - addToPayload(opt, ["termID", "userAccountName"]); - break; - case "GetTagUrlsOfUserByKeyword": - addToPayload(opt, ["keyword", "userAccountName"]); - break; - case "SetRating": - addToPayload(opt, ["url", "rating", "title", "analysisDataEntry"]); - break; - case "UpdateComment": - addToPayload(opt, ["url", "lastModifiedTime", "comment", "isHighPriority"]); - break; - - // SPELLCHECK OPERATIONS - case "SpellCheck": - addToPayload(opt, ["chunksToSpell", "declaredLanguage", "useLad"]); - break; - - // TAXONOMY OPERATIONS - case "AddTerms": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "newTerms"]); - break; - case "GetChildTermsInTerm": - addToPayload(opt, ["sspId", "lcid", "termId", "termSetId"]); - break; - case "GetChildTermsInTermSet": - addToPayload(opt, ["sspId", "lcid", "termSetId"]); - break; - case "GetKeywordTermsByGuids": - addToPayload(opt, ["termIds", "lcid"]); - break; - case "GetTermsByLabel": - addToPayload(opt, ["label", "lcid", "matchOption", "resultCollectionSize", "termIds", "addIfNotFound"]); - break; - case "GetTermSets": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "clientTimeStamps", "clientVersions"]); - break; - - // USERS AND GROUPS OPERATIONS - case "AddGroup": - addToPayload(opt, ["groupName", "ownerIdentifier", "ownerType", "defaultUserLoginName", "description"]); - break; - case "AddGroupToRole": - addToPayload(opt, ["groupName", "roleName"]); - break; - case "AddRole": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddRoleDef": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddUserCollectionToGroup": - addToPayload(opt, ["groupName", "usersInfoXml"]); - break; - case "AddUserCollectionToRole": - addToPayload(opt, ["roleName", "usersInfoXml"]); - break; - case "AddUserToGroup": - addToPayload(opt, ["groupName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "AddUserToRole": - addToPayload(opt, ["roleName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "GetAllUserCollectionFromWeb": - break; - case "GetGroupCollection": - addToPayload(opt, ["groupNamesXml"]); - break; - case "GetGroupCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetGroupCollectionFromSite": - break; - case "GetGroupCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetGroupCollectionFromWeb": - break; - case "GetGroupInfo": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollection": - addToPayload(opt, ["roleNamesXml"]); - break; - case "GetRoleCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetRoleCollectionFromWeb": - break; - case "GetRoleInfo": - addToPayload(opt, ["roleName"]); - break; - case "GetRolesAndPermissionsForCurrentUser": - break; - case "GetRolesAndPermissionsForSite": - break; - case "GetUserCollection": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "GetUserCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetUserCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetUserCollectionFromSite": - break; - case "GetUserCollectionFromWeb": - break; - case "GetUserInfo": - addToPayload(opt, ["userLoginName"]); - break; - case "GetUserLoginFromEmail": - addToPayload(opt, ["emailXml"]); - break; - case "RemoveGroup": - addToPayload(opt, ["groupName"]); - break; - case "RemoveGroupFromRole": - addToPayload(opt, ["roleName", "groupName"]); - break; - case "RemoveRole": - addToPayload(opt, ["roleName"]); - break; - case "RemoveUserCollectionFromGroup": - addToPayload(opt, ["groupName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromRole": - addToPayload(opt, ["roleName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromSite": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "RemoveUserFromGroup": - addToPayload(opt, ["groupName", "userLoginName"]); - break; - case "RemoveUserFromRole": - addToPayload(opt, ["roleName", "userLoginName"]); - break; - case "RemoveUserFromSite": - addToPayload(opt, ["userLoginName"]); - break; - case "RemoveUserFromWeb": - addToPayload(opt, ["userLoginName"]); - break; - case "UpdateGroupInfo": - addToPayload(opt, ["oldGroupName", "groupName", "ownerIdentifier", "ownerType", "description"]); - break; - case "UpdateRoleDefInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateRoleInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateUserInfo": - addToPayload(opt, ["userLoginName", "userName", "userEmail", "userNotes"]); - break; - - // USERPROFILESERVICE OPERATIONS - case "AddColleague": - addToPayload(opt, ["accountName", "colleagueAccountName", "group", "privacy", "isInWorkGroup"]); - break; - case "AddLink": - addToPayload(opt, ["accountName", "name", "url", "group", "privacy"]); - break; - case "AddMembership": - addToPayload(opt, ["accountName", "membershipInfo", "group", "privacy"]); - break; - case "AddPinnedLink": - addToPayload(opt, ["accountName", "name", "url"]); - break; - case "CreateMemberGroup": - addToPayload(opt, ["membershipInfo"]); - break; - case "CreateUserProfileByAccountName": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonManager": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetInCommon": - addToPayload(opt, ["accountName"]); - break; - case "GetPropertyChoiceList": - addToPayload(opt, ["propertyName"]); - break; - case "GetUserColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetUserLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetUserPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserProfileByGuid": - addToPayload(opt, ["guid"]); - break; - case "GetUserProfileByIndex": - addToPayload(opt, ["index"]); - break; - case "GetUserProfileByName": - // Note that this operation is inconsistent with the others, using AccountName rather than accountName - if(typeof opt.accountName !== "undefined" && opt.accountName.length > 0) { - addToPayload(opt, [["AccountName", "accountName"]]); - } else { - addToPayload(opt, ["AccountName"]); - } - break; - case "GetUserProfileCount": - break; - case "GetUserProfileSchema": - break; - case "ModifyUserPropertyByAccountName": - addToPayload(opt, ["accountName", "newData"]); - break; - case "RemoveAllColleagues": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllMemberships": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveColleague": - addToPayload(opt, ["accountName", "colleagueAccountName"]); - break; - case "RemoveLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "RemoveMembership": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference"]); - break; - case "RemovePinnedLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "UpdateColleaguePrivacy": - addToPayload(opt, ["accountName", "colleagueAccountName", "newPrivacy"]); - break; - case "UpdateLink": - addToPayload(opt, ["accountName", "data"]); - break; - case "UpdateMembershipPrivacy": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference", "newPrivacy"]); - break; - case "UpdatePinnedLink ": - addToPayload(opt, ["accountName", "data"]); - break; - - // VERSIONS OPERATIONS - case "DeleteAllVersions": - addToPayload(opt, ["fileName"]); - break; - case "DeleteVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - case "GetVersions": - addToPayload(opt, ["fileName"]); - break; - case "RestoreVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - - // VIEW OPERATIONS - case "AddView": - addToPayload(opt, ["listName", "viewName", "viewFields", "query", "rowLimit", "rowLimit", "type", "makeViewDefault"]); - break; - case "DeleteView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetViewCollection": - addToPayload(opt, ["listName"]); - break; - case "GetViewHtml": - addToPayload(opt, ["listName", "viewName"]); - break; - case "UpdateView": - addToPayload(opt, ["listName", "viewName", "viewProperties", "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - case "UpdateViewHtml": - addToPayload(opt, ["listName", "viewName", "viewProperties", "toolbar", "viewHeader", "viewBody", "viewFooter", "viewEmpty", "rowLimitExceeded", - "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - - // WEBPARTPAGES OPERATIONS - case "AddWebPart": - addToPayload(opt, ["pageUrl", "webPartXml", "storage"]); - break; - case "AddWebPartToZone": - addToPayload(opt, ["pageUrl", "webPartXml", "storage", "zoneId", "zoneIndex"]); - break; - case "GetWebPart2": - addToPayload(opt, ["pageUrl", "storageKey", "storage", "behavior"]); - break; - case "GetWebPartPage": - addToPayload(opt, ["documentName", "behavior"]); - break; - case "GetWebPartProperties": - addToPayload(opt, ["pageUrl", "storage"]); - break; - case "GetWebPartProperties2": - addToPayload(opt, ["pageUrl", "storage", "behavior"]); - break; - - // WEBS OPERATIONS - case "Webs.CreateContentType": - addToPayload(opt, ["displayName", "parentType", "newFields", "contentTypeProperties"]); - break; - case "GetColumns": - addToPayload(opt, ["webUrl"]); - break; - case "GetContentType": - addToPayload(opt, ["contentTypeId"]); - break; - case "GetContentTypes": - break; - case "GetCustomizedPageStatus": - addToPayload(opt, ["fileUrl"]); - break; - case "GetListTemplates": - break; - case "GetObjectIdFromUrl": - addToPayload(opt, ["objectUrl"]); - break; - case "GetWeb": - addToPayload(opt, [["webUrl", "webURL"]]); - break; - case "GetWebCollection": - break; - case "GetAllSubWebCollection": - break; - case "UpdateColumns": - addToPayload(opt, ["newFields", "updateFields", "deleteFields"]); - break; - case "Webs.UpdateContentType": - addToPayload(opt, ["contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields"]); - break; - case "WebUrlFromPageUrl": - addToPayload(opt, [["pageUrl", "pageURL"]]); - break; - - // WORKFLOW OPERATIONS - case "AlterToDo": - addToPayload(opt, ["item", "todoId", "todoListId", "taskData"]); - break; - case "GetTemplatesForItem": - addToPayload(opt, ["item"]); - break; - case "GetToDosForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowDataForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowTaskData": - addToPayload(opt, ["item", "listId", "taskId"]); - break; - case "StartWorkflow": - addToPayload(opt, ["item", "templateId", "workflowParameters"]); - break; - - default: - break; - } - - // Glue together the pieces of the SOAP message - var msg = SOAPEnvelope.header + SOAPEnvelope.opheader + SOAPEnvelope.payload + SOAPEnvelope.opfooter + SOAPEnvelope.footer; - - // Check to see if we've already cached the results - var cachedXML; - if(opt.cacheXML) { - cachedXML = promisesCache[msg]; - } - - if(typeof cachedXML === "undefined") { - - // Finally, make the Ajax call - var spservicesPromise = $.ajax({ - // The relative URL for the AJAX call - url: ajaxURL, - // By default, the AJAX calls are asynchronous. You can specify false to require a synchronous call. - async: opt.async, - // Before sending the msg, need to send the request header - beforeSend: function (xhr) { - // If we need to pass the SOAPAction, do so - if(WSops[opt.operation][1]) { - xhr.setRequestHeader("SOAPAction", SOAPAction); - } - }, - // Always a POST - type: "POST", - // Here is the SOAP request we've built above - data: msg, - // We're getting XML; tell jQuery so that it doesn't need to do a best guess - dataType: "xml", - // and this is its content type - contentType: "text/xml;charset='utf-8'", - complete: function(xData, Status) { - // When the call is complete, call the completefunc if there is one - if($.isFunction(opt.completefunc)) { - opt.completefunc(xData, Status); - - } - } - }).then( - function() { - // Cache the promise if requested - if(opt.cacheXML) { - promisesCache[msg] = spservicesPromise; - } - }, - function() { - // TODO: Allow for fail function - } - ); - - // Return the promise - return spservicesPromise; - - } else { - // Call the completefunc if there is one - if($.isFunction(opt.completefunc)) { - opt.completefunc(cachedXML, null); - } - // Return the cached promise - return cachedXML; - } - - - }; // End $.fn.SPServices - - // Defaults added as a function in our library means that the caller can override the defaults - // for their session by calling this function. Each operation requires a different set of options; - // we allow for all in a standardized way. - $.fn.SPServices.defaults = { - - cacheXML: false, // If true, we'll cache the XML results with jQuery's .data() function - operation: "", // The Web Service operation - webURL: "", // URL of the target Web - makeViewDefault: false, // true to make the view the default view for the list - - // For operations requiring CAML, these options will override any abstractions - CAMLViewName: "", // View name in CAML format. - CAMLQuery: "", // Query in CAML format - CAMLViewFields: "", // View fields in CAML format - CAMLRowLimit: 0, // Row limit as a string representation of an integer - CAMLQueryOptions: "", // Query options in CAML format - - // Abstractions for CAML syntax - batchCmd: "Update", // Method Cmd for UpdateListItems - valuepairs: [], // Fieldname / Fieldvalue pairs for UpdateListItems - - // As of v0.7.1, removed all options which were assigned an empty string ("") - DestinationUrls: [], // Array of destination URLs for copy operations - behavior: "Version3", // An SPWebServiceBehavior indicating whether the client supports Windows SharePoint Services 2.0 or Windows SharePoint Services 3.0: {Version2 | Version3 } - storage: "Shared", // A Storage value indicating how the Web Part is stored: {None | Personal | Shared} - objectType: "List", // objectType for operations which require it - cancelMeeting: true, // true to delete a meeting;false to remove its association with a Meeting Workspace site - nonGregorian: false, // true if the calendar is set to a format other than Gregorian;otherwise, false. - fClaim: false, // Specifies if the action is a claim or a release. Specifies true for a claim and false for a release. - recurrenceId: 0, // The recurrence ID for the meeting that needs its association removed. This parameter can be set to 0 for single-instance meetings. - sequence: 0, // An integer that is used to determine the ordering of updates in case they arrive out of sequence. Updates with a lower-than-current sequence are discarded. If the sequence is equal to the current sequence, the latest update are applied. - maximumItemsToReturn: 0, // SocialDataService maximumItemsToReturn - startIndex: 0, // SocialDataService startIndex - isHighPriority: false, // SocialDataService isHighPriority - isPrivate: false, // SocialDataService isPrivate - rating: 1, // SocialDataService rating - maxResults: 10, // Unless otherwise specified, the maximum number of principals that can be returned from a provider is 10. - principalType: "User", // Specifies user scope and other information: [None | User | DistributionList | SecurityGroup | SharePointGroup | All] - - async: true, // Allow the user to force async - completefunc: null // Function to call on completion - - }; // End $.fn.SPServices.defaults - - // Function to determine the current Web's URL. We need this for successful Ajax calls. - // The function is also available as a public function. - $.fn.SPServices.SPGetCurrentSite = function() { - - // We've already determined the current site... - if(currentContext.thisSite.length > 0) { - return currentContext.thisSite; - } - - // If we still don't know the current site, we call WebUrlFromPageUrlResult. - var msg = SOAPEnvelope.header + - "" + - ((location.href.indexOf("?") > 0) ? location.href.substr(0, location.href.indexOf("?")) : location.href) + - "" + - SOAPEnvelope.footer; - $.ajax({ - async: false, // Need this to be synchronous so we're assured of a valid value - url: "/_vti_bin/Webs.asmx", - type: "POST", - data: msg, - dataType: "xml", - contentType: "text/xml;charset=\"utf-8\"", - complete: function (xData, Status) { - currentContext.thisSite = $(xData.responseXML).find("WebUrlFromPageUrlResult").text(); - } - }); - - return currentContext.thisSite; // Return the URL - - }; // End $.fn.SPServices.SPGetCurrentSite - - // Function to set up cascading dropdowns on a SharePoint form - // (Newform.aspx, EditForm.aspx, or any other customized form.) - $.fn.SPServices.SPCascadeDropdowns = function(options) { - - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationships list - relationshipList: "", // The name of the list which contains the parent/child relationships - relationshipListParentColumn: "", // The internal name of the parent column in the relationship list - relationshipListChildColumn: "", // The internal name of the child column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListChildColumn - parentColumn: "", // The display name of the parent column in the form - childColumn: "", // The display name of the child column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relationshipList - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of childColumn. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - simpleChild: false, // [Optional] If set to true and childColumn is a complex dropdown, convert it to a simple dropdown - selectSingleOption: false, // [Optional] If set to true and there is only a single child option, select it - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - - var thisParentSetUp = false; - var thisFunction = "SPServices.SPCascadeDropdowns"; - - // Find the parent column's select (dropdown) - var parentSelect = new DropdownCtl(opt.parentColumn); - if(parentSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "parentColumn: " + opt.parentColumn , TXTColumnNotFound);return;} - - // Find the child column's select (dropdown) - var childSelect = new DropdownCtl(opt.childColumn); - if(childSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "childColumn: " + opt.childColumn, TXTColumnNotFound);return;} - - // If requested and the childColumn is a complex dropdown, convert to a simple dropdown - if(opt.simpleChild === true && childSelect.Type === "C") { - $().SPServices.SPComplexToSimpleDropdown({ - columnName: opt.childColumn - }); - // Set the childSelect to reference the new simple dropdown - childSelect = new DropdownCtl(opt.childColumn); - } - - var childColumnRequired, childColumnStatic; - - // Get information about the childColumn from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.childColumn + "']").each(function() { - // Determine whether childColumn is Required - childColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - childColumnStatic = $(this).attr("StaticName"); - // Stop looking; we're done - return false; - }); - }); - } - }); - - // Save data about each child column on the parent - var childColumn = {opt: opt, childSelect: childSelect, childColumnStatic: childColumnStatic, childColumnRequired: childColumnRequired}; - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - - // If this is the first child for this parent, then create the data object to hold the settings - if(typeof childColumns === "undefined") { - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", [childColumn]); - // If we already have a data object for this parent, then add the setting for this child to it - } else { - childColumns.push(childColumn); - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", childColumns); - thisParentSetUp = true; - } - - // We only need to bind to the event(s) if we haven't already done so - if(!thisParentSetUp) { - switch(parentSelect.Type) { - // Plain old select - case "S": - parentSelect.Obj.bind("change", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='"+ parentSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Multi-select hybrid - case "M": - // Handle the dblclick on the candidate select - parentSelect.Obj.bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle the dblclick on the selected values - parentSelect.Obj.closest("span").find("select[id$='SelectResult']").bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle a button click - parentSelect.Obj.closest("span").find("button").each(function() { - $(this).bind("click", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - }); - break; - default: - break; - } - } - // Fire the change to set the initially allowable values - cascadeDropdown(opt.parentColumn, parentSelect); - - }; // End $.fn.SPServices.SPCascadeDropdowns - - function cascadeDropdown(parentColumn, parentSelect) { - var choices = ""; - var parentSelectSelected; - var childSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var numChildOptions; - var firstChildOptionId; - var firstChildOptionValue; - - // Filter each child column - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - $(childColumns).each(function() { - - // Break out the data objects for this child column - var opt = this.opt; - var childSelect = this.childSelect; - var childColumnStatic = this.childColumnStatic; - var childColumnRequired = this.childColumnRequired; - var currentSelection; - - // Get the parent column selection(s) - parentSelectSelected = getDropdownSelected(parentSelect, opt.matchOnId); - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C" or "M", as there are multiple propertychanges - // which don't require any action. The attribute will be unique per child column in case there are - // multiple children for a given parent. - var allParentSelections = parentSelectSelected.join(";#"); - if(parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic) === allParentSelections) { - return; - } - parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic, allParentSelections); - - // Get the current child column selection(s) - childSelectSelected = getDropdownSelected(childSelect, true); - - // Find the important bits of the multi-select - if(childSelect.Type === "M") { - MultiLookupPickerdata = childSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[childSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - currentSelection = childSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - } - - // When the parent column's selected option changes, get the matching items from the relationship list - // Get the list items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListChildColumn; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - // Build up the criteria for inclusion - if(parentSelectSelected.length === 0) { - // Handle the case where no values are selected in multi-selects - camlQuery += ""; - } else if(parentSelectSelected.length === 1) { - // Only one value is selected - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[0]) + ""; - } else { - var compound = (parentSelectSelected.length > 2) ? true : false; - for(i=0; i < (parentSelectSelected.length - 1); i++) { - camlQuery += ""; - } - for(i=0; i < parentSelectSelected.length; i++) { - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[i]) + ""; - if(i>0 && (i < (parentSelectSelected.length - 1)) && compound) { - camlQuery += ""; - } - } - camlQuery += ""; - } - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - - // Make sure we don't get any items which don't have the child value - camlQuery += ""; - - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the child column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the currently selected parent column's value - CAMLQuery: camlQuery, - // Only get the parent and child columns - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: "FALSE", - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var thisFunction = "SPServices.SPCascadeDropdowns"; - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListParentColumn: " + opt.relationshipListParentColumn + " or " + - "relationshipListChildColumn: " + opt.relationshipListChildColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(childSelect.Type) { - case "S": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!childColumnRequired && (opt.promptText.length > 0)) { - childSelect.Obj.append(""); - } else if(!childColumnRequired){ - childSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = childColumnRequired ? "" : opt.noneText + "|0"; - childSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - // Get the count of items returned and save it so that we can select if it's a single option - // The item count is stored thus: - numChildOptions = parseFloat($(xData.responseXML).SPFilterNode("rs:data").attr("ItemCount")); - - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOption = {}; - - // If relationshipListChildColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListChildColumn); - - if(typeof thisValue !== "undefined" && thisValue.indexOf(";#") > 0) { - thisOption = new SplitIndex(thisValue); - } else { - thisOption.id = $(this).attr("ows_ID"); - thisOption.value = thisValue; - } - - // If the relationshipListChildColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOption.id should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOption.id)) { - thisOption.id = $(this).attr("ows_ID"); - } - - // Save the id and value for the first child option in case we need to select it (selectSingleOption option is true) - firstChildOptionId = thisOption.id; - firstChildOptionValue = thisOption.value; - - switch(childSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === childSelectSelected[0]) ? " selected='selected'" : ""; - childSelect.Obj.append("" + thisOption.value + ""); - break; - case "C": - if(thisOption.id === childSelectSelected[0]) { - childSelect.Obj.attr("value", thisOption.value); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOption.value + "|" + thisOption.id; - break; - case "M": - childSelect.Obj.append(""); - newMultiLookupPickerdata += thisOption.id + "|t" + thisOption.value + "|t |t |t"; - break; - default: - break; - } - }); - - switch(childSelect.Type) { - case "S": - childSelect.Obj.trigger("change"); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - $(childSelect.Obj).find("option[value!='0']:first").attr("selected", "selected"); - } - break; - case "C": - // Set the allowable choices - childSelect.Obj.attr("choices", choices); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - // Set the input element value - $(childSelect.Obj).attr("value", firstChildOptionValue); - // Set the value of the optHid input element - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(firstChildOptionId); - } - // If there's no selection, then remove the value in the associated hidden input element (optHid) - if(childSelect.Obj.val() === "") { - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(""); - } - break; - case "M": - // Clear the master - master.data = ""; - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - - // Clear any prior selections that are no longer valid or aren't selected - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - var thisValue = $(this).html(); - $(this).attr("selected", "selected"); - $(childSelect.Obj).find("option").filter(function() { - return $(this).text() === thisValue.replace(/&/, "&"); - }).each(function() { - if($(this).html() === thisValue) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - - // Hide any options in the candidate list which are already selected - $(childSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - childSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }); // $(childColumns).each(function() - - } // End cascadeDropdown - - - // function to convert complex dropdowns to simple dropdowns - $.fn.SPServices.SPComplexToSimpleDropdown = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox("SPServices.SPComplexToSimpleDropdown", "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // If we don't have a complex dropdown, then there is nothing to do - if(columnSelect.Type !== "C") { return; } - - // The available options are stored in the choices attribute of the complex dropdowns's input element... - var choices = $(columnSelect.Obj).attr("choices").split("|"); - // The optHid attribute contains the id of a hidden input element which stores the selected value for the commit - var columnOptHid = $(columnSelect.Obj).attr("optHid"); - var columnOptHidInput = $("input[id='" + columnOptHid + "']"); - // We need to know which option is selected already, if any - var complexSelectSelectedId = $("input[id='" + columnOptHid + "']").val(); - - // Build up the simple dropdown, giving it an easy to select id - var simpleSelectId = genContainerId("SPComplexToSimpleDropdown", opt.columnName); - - var simpleSelect = ""; - - // Append the new simple select to the form - $(columnSelect.Obj).closest("td").prepend(simpleSelect); - - // Remove the complex dropdown functionality since we don't need it anymore... - $(columnSelect.Obj).closest("span").find("img").remove(); - // ...and hide the input element - $(columnSelect.Obj).closest("span").find("input").hide(); - - // When the simple select changes... - $("#" + simpleSelectId).change(function() { - var thisVal = $(this).val(); - // ...set the optHid input element's value to the valus of the selected option... - columnOptHidInput.val(thisVal); - // ...and save the selected value as the hidden input's value only if the value is not equal to "0" (None) - $(columnSelect.Obj).val($(this).find("option[value='" + (thisVal !== "0" ? thisVal : "") + "']").html()); - }); - // Trigger a change to ensure that the selected value registers in the complex dropdown - $("#" + simpleSelectId).trigger("change"); - - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - - }; // End $.fn.SPServices.SPConvertToSimpleDropdown - - - // Function to display related information when an option is selected on a form. - $.fn.SPServices.SPDisplayRelatedInfo = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - relatedWebURL: "", // [Optional] The name of the Web (site) which contains the related list - relatedList: "", // The name of the list which contains the additional information - relatedListColumn: "", // The internal name of the related column in the related list - relatedColumns: [], // An array of related columns to display - displayFormat: "table", // The format to use in displaying the related information. Possible values are: [table, list] - headerCSSClass: "ms-vh2", // CSS class for the table headers - rowCSSClass: "ms-vb", // CSS class for the table rows - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be ed with the default query on the relatedList - numChars: 0, // If used on an input column (not a dropdown), no matching will occur until at least this number of characters has been entered - matchType: "Eq", // If used on an input column (not a dropdown), type of match. Can be any valid CAML comparison operator, most often "Eq" or "BeginsWith" - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var divId; - var relatedColumnsXML = []; - var relatedListXML; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // Generate a unique id for the container - divId = genContainerId("SPDisplayRelatedInfo", opt.columnName); - - // Get information about the related list and its columns - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - completefunc: function(xData) { - // If debug is on, notify about an error - $(xData.responseXML).find("faultcode").each(function() { - if(opt.debug) {errBox(thisFunction, "relatedList: " + opt.relatedList, "List not found"); return; } - }); - // Get info about the related list - relatedListXML = $(xData.responseXML).find("List"); - // Save the information about each column requested - for (i=0; i < opt.relatedColumns.length; i++) { - relatedColumnsXML[i] = $(xData.responseXML).find("Fields > Field[Name='" + opt.relatedColumns[i] + "']"); - } - } - }); - - switch(columnSelect.Type) { - // Plain old select - case "S": - columnSelect.Obj.bind("change", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='" + columnSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Multi-select hybrid - case "M": - if(opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, "Multi-select columns not supported by this function"); } - break; - default: - break; - } - // Fire the change to set the initially allowable values - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - - }; // End $.fn.SPServices.SPDisplayRelatedInfo - - function showRelated(opt, divId, relatedListXML, relatedColumnsXML) { - - var columnSelectSelected = null; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, opt.matchOnId); - if(columnSelect.Type === "C" && opt.numChars > 0 && columnSelectSelected[0].length < opt.numChars) { - return; - } - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C", as there are multiple propertychanges - // which don't require any action. - if(columnSelect.Obj.attr("showRelatedSelected") === columnSelectSelected[0]) { - return; - } - columnSelect.Obj.attr("showRelatedSelected", columnSelectSelected[0]); - - // Remove the old container... - $("#" + divId).remove(); - // ...and append a new, empty one - columnSelect.Obj.parent().append("
    "); - - // Get the list items which match the current selection - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - camlQuery += "" : "'/>") + - escapeColumnValue(columnSelectSelected[0]) + ""; - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - var viewFields = " "; - for (i=0; i < opt.relatedColumns.length; i++) { - viewFields += ""; - } - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - // Filter based on the column's currently selected value - CAMLQuery: camlQuery, - CAMLViewFields: "" + viewFields + "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relatedListColumn: " + opt.relatedListColumn, - "Column not found in relatedList " + opt.relatedList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relatedList: " + opt.relatedList, - "List not found"); - } - return; - }); - - var outString; - // Output each row - switch(opt.displayFormat) { - // Only implementing the table format in the first iteration (v0.2.9) - case "table": - outString = ""; - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === "undefined" && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - } - outString += ""; - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - outString += ""; - } - outString += ""; - }); - outString += "
    " + relatedColumnsXML[i].attr("DisplayName") + "
    " + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
    "; - break; - // list format implemented in v0.5.0. Still table-based, but vertical orientation. - case "list": - outString = ""; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === "undefined" && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - outString += ""; - outString += ""; - outString += ""; - } - }); - outString += "
    " + relatedColumnsXML[i].attr("DisplayName") + "" + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
    "; - break; - default: - break; - } - // Write out the results - $("#" + divId).html(outString); - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - } // End showRelated - - // Function to filter a lookup based dropdown - $.fn.SPServices.SPFilterDropdown = function(options) { - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationshipList - relationshipList: "", // The name of the list which contains the lookup values - relationshipListColumn: "", // The internal name of the column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListColumn - relationshipListSortAscending: true, // [Optional] By default, the sort is ascending. If false, descending - columnName: "", // The display name of the column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of columnName. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - CAMLQuery: "", // This CAML fragment will be applied to the relationshipList - CAMLQueryOptions: "FALSE", // Need this to mirror SharePoint's behavior, but it can be overridden - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages; if false, run silent - }, options); - - var choices = ""; - var columnSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var columnColumnRequired; - var thisFunction = "SPServices.SPFilterDropdown"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return;} - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, true); - - // Get the relationshipList items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListColumn; - var sortOrder = (opt.relationshipListSortAscending === true) ? "" : "Ascending='FALSE'"; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery; - } - camlQuery += ""; - - // Get information about columnName from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName is Required - columnColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - // Stop looking; we're done - return false; - }); - }); - } - }); - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the specified CAML - CAMLQuery: camlQuery, - // Only get the columnName's data (plus columns we can't prevent) - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: opt.CAMLQueryOptions, - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListColumn: " + opt.relationshipListColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(columnSelect.Type) { - case "S": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!columnColumnRequired && (opt.promptText.length > 0)) { - columnSelect.Obj.append(""); - } else if(!columnColumnRequired){ - columnSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = columnColumnRequired ? "" : opt.noneText + "|0"; - columnSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - - // Add an option for each item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOption = {}; - - // If relationshipListColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListColumn); - - if(typeof thisValue !== "undefined" && thisValue.indexOf(";#") > 0) { - thisOption = new SplitIndex(thisValue); - } else { - thisOption.id = $(this).attr("ows_ID"); - thisOption.value = thisValue; - } - - // If the relationshipListColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOption.id should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOption.id)) { - thisOption.id = $(this).attr("ows_ID"); - } - - switch(columnSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === columnSelectSelected[0]) ? " selected='selected'" : ""; - columnSelect.Obj.append("" + thisOption.value + ""); - break; - case "C": - if(thisOption.id === columnSelectSelected[0]) { - columnSelect.Obj.attr("value", thisOption.value); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOption.value + "|" + thisOption.id; - break; - case "M": - columnSelect.Obj.append(""); - newMultiLookupPickerdata += thisOption.id + "|t" + thisOption.value + "|t |t |t"; - break; - default: - break; - } - }); - - switch(columnSelect.Type) { - case "S": - columnSelect.Obj.trigger("change"); - break; - case "C": - columnSelect.Obj.attr("choices", choices); - columnSelect.Obj.trigger("propertychange"); - break; - case "M": - // Find the important bits of the multi-select - MultiLookupPickerdata = columnSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[columnSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - var currentSelection = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - // Clear the master - master.data = ""; - - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - // Clear any prior selections that are no longer valid - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - $(this).attr("selected", "selected"); - $(columnSelect.Obj).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - // Hide any options in the candidate list which are already selected - $(columnSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - columnSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPFilterDropdown - - - // Utility function to show the results of a Web Service call formatted well in the browser. - $.fn.SPServices.SPDebugXMLHttpResult = function(options) { - - var opt = $.extend({}, { - node: null, // An XMLHttpResult object from an ajax call - indent: 0 // Number of indents - }, options); - - var i; - var NODE_TEXT = 3; - var NODE_CDATA_SECTION = 4; - - var outString = ""; - // For each new subnode, begin rendering a new TABLE - outString += ""; - // DisplayPatterns are a bit unique, so let's handle them differently - if(opt.node.nodeName === "DisplayPattern") { - outString += ""; - // A node which has no children - } else if (!opt.node.hasChildNodes()) { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // A CDATA_SECTION node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_CDATA_SECTION) { - outString += ""; - // A TEXT node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_TEXT) { - outString += ""; - // Handle child nodes - } else { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // Since the node has child nodes, recurse - outString += ""; - } - outString += "
    " + opt.node.nodeName + - "
    " + opt.node.nodeName + - "" + ((opt.node.nodeValue !== null) ? checkLink(opt.node.nodeValue) : " ") + "
    " + showAttrs(opt.node) + "
    " + opt.node.nodeName + - "
    " + opt.node.nodeName + - "" + checkLink(opt.node.firstChild.nodeValue) + "
    " + opt.node.nodeName + "
    " + showAttrs(opt.node) + "
    "; - for (i = 0;i < opt.node.childNodes.length; i++) { - outString += $().SPServices.SPDebugXMLHttpResult({ - node: opt.node.childNodes.item(i), - indent: opt.indent + 1 - }); - } - outString += "
    "; - // Return the HTML which we have built up - return outString; - }; // End $.fn.SPServices.SPDebugXMLHttpResult - - // Function which returns the account name for the current user in DOMAIN\username format - $.fn.SPServices.SPGetCurrentUser = function(options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Site Collection. If not specified, the current Web is used. - fieldName: "Name", // Specifies which field to return from the userdisp.aspx page - fieldNames: {}, // Specifies which fields to return from the userdisp.aspx page - added in v0.7.2 to allow multiple columns - debug: false // If true, show error messages; if false, run silent - }, options); - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldName === "ID" && typeof currentContext.thisUserId !== "undefined") { - return currentContext.thisUserId; - } - - var thisField = ""; - var theseFields = {}; - var fieldCount = opt.fieldNames.length > 0 ? opt.fieldNames.length : 1; - var thisUserDisp; - var thisWeb = opt.webURL.length > 0 ? opt.webURL : $().SPServices.SPGetCurrentSite(); - - // Get the UserDisp.aspx page using AJAX - $.ajax({ - // Need this to be synchronous so we're assured of a valid value - async: false, - // Force parameter forces redirection to a page that displays the information as stored in the UserInfo table rather than My Site. - // Adding the extra Query String parameter with the current date/time forces the server to view this as a new request. - url: thisWeb + "/_layouts/userdisp.aspx?Force=True&" + new Date().getTime(), - complete: function (xData, Status) { - thisUserDisp = xData; - } - }); - - for(i=0; i < fieldCount; i++) { - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldNames[i] === "ID") { - thisField = currentContext.thisUserId; - } else { - var thisTextValue; - if(fieldCount > 1) { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldNames[i] + "\"", "gi"); - } else { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldName + "\"", "gi"); - } - $(thisUserDisp.responseText).find("table.ms-formtable td[id^='SPField']").each(function() { - if(thisTextValue.test($(this).html())) { - // Each fieldtype contains a different data type, as indicated by the id - switch($(this).attr("id")) { - case "SPFieldText": - thisField = $(this).text(); - break; - case "SPFieldNote": - thisField = $(this).find("div").html(); - break; - case "SPFieldURL": - thisField = $(this).find("img").attr("src"); - break; - // Just in case - default: - thisField = $(this).text(); - break; - } - // Stop looking; we're done - return false; - } - }); - } - if(opt.fieldNames[i] !== "ID") { - thisField = (typeof thisField !== "undefined") ? thisField.replace(/(^[\s\xA0]+|[\s\xA0]+$)/g, '') : null; - } - if(fieldCount > 1) { - theseFields[opt.fieldNames[i]] = thisField; - } - } - - return (fieldCount > 1) ? theseFields : thisField; - - }; // End $.fn.SPServices.SPGetCurrentUser - - - // Function which provides a link on a Lookup column for the user to follow - // which allows them to add a new value to the Lookup list. - // Based on http://blog.mastykarz.nl/extending-lookup-fields-add-new-item-option/ - // by Waldek Mastykarz - $.fn.SPServices.SPLookupAddNew = function(options) { - - var opt = $.extend({}, { - lookupColumn: "", // The display name of the Lookup column - promptText: "Add new {0}", // Text to use as prompt + column name - newWindow: false, // If true, the link will open in a new window *without* passing the Source. - ContentTypeID: "", // [Optional] Pass the ContentTypeID if you'd like to specify it - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var thisFunction = "SPServices.SPLookupAddNew"; - - // Find the lookup column's select (dropdown) - var lookupSelect = new DropdownCtl(opt.lookupColumn); - if(lookupSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, TXTColumnNotFound);return;} - - var newUrl = ""; - var lookupListUrl = ""; - var lookupColumnStaticName = ""; - // Use GetList for the current list to determine the details for the Lookup column - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $().SPServices.SPListNameFromUrl(), - completefunc: function (xData, Status) { - $(xData.responseXML).find("Field[DisplayName='" + opt.lookupColumn + "']").each(function() { - lookupColumnStaticName = $(this).attr("StaticName"); - // Use GetList for the Lookup column's list to determine the list's URL - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $(this).attr("List"), - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - lookupListUrl = $(this).attr("WebFullUrl"); - // Need to handle when list is in the root site - lookupListUrl = lookupListUrl !== SLASH ? lookupListUrl + SLASH : lookupListUrl; - }); - } - }); - // Get the NewItem form for the Lookup column's list - newUrl = getListFormUrl($(this).attr("List"), "NewForm"); - // Stop looking;we're done - return false; - }); - } - }); - - if(lookupListUrl.length === 0 && opt.debug) { - errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, "This column does not appear to be a lookup column"); - return; - } - if(newUrl.length > 0) { - // Build the link to the Lookup column's list enclosed in a div with the id="SPLookupAddNew_" + lookupColumnStaticName - var newHref = lookupListUrl + newUrl; - // If requested, open the link in a new window and if requested, pass the ContentTypeID - newHref += opt.newWindow ? - ((opt.ContentTypeID.length > 0) ? "?ContentTypeID=" + opt.ContentTypeID : "") + "' target='_blank'" : - "?" + ((opt.ContentTypeID.length > 0) ? "ContentTypeID=" + opt.ContentTypeID + "&" : "") + "Source=" + escapeUrl(location.href) + "'"; - var newLink = "
    " + " 0) { - camlQuery += ""; - } - camlQuery += "" + userId + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: camlQuery, - CAMLViewFields: "", - CAMLRowLimit: 1, - CAMLQueryOptions: "", - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - lastId = $(this).attr("ows_ID"); - }); - } - }); - return lastId; - }; // End $.fn.SPServices.SPGetLastItemId - - // Function which checks to see if the value for a column on the form is unique in the list. - $.fn.SPServices.SPRequireUnique = function (options) { - - var opt = $.extend({}, { - columnStaticName: "Title", // Name of the column - duplicateAction: 0, // 0 = warn, 1 = prevent - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - initMsg: "This value must be unique.", // Initial message to display after setup - initMsgCSSClass: "ms-vb", // CSS class for initial message - errMsg: "This value is not unique.", // Error message to display if not unique - errMsgCSSClass: "ms-formvalidation", // CSS class for error message - showDupes: false, // If true, show links to the duplicate item(s) after the error message - completefunc: null // Function to call on completion of rendering the change. - }, options); - - // Get the current item's ID from the Query String - var queryStringVals = $().SPServices.SPGetQueryString(); - var thisID = queryStringVals.ID; - currentContext.thisList = $().SPServices.SPListNameFromUrl(); - - // Set the messages based on the options provided - var msg = "{1}
    "; - var firstMsg = msg.replace(/\{0\}/g, opt.initMsgCSSClass).replace(/\{1\}/g, opt.initMsg); - - // We need the DisplayName - var columnDisplayName = $().SPServices.SPGetDisplayFromStatic({ - listName: currentContext.thisList, - columnStaticName: opt.columnStaticName - }); - var columnObj = $("input[Title='" + columnDisplayName + "']"); - $(columnObj).parent().append(firstMsg); - - $(columnObj).blur(function () { - var columnValueIDs = []; - // Get the columnDisplayName's value - var columnValue = $(this).attr("value"); - if(columnValue.length === 0) { return false; } - - // Call the Lists Web Service (GetListItems) to see if the value already exists - $().SPServices({ - operation: "GetListItems", - async: false, - listName: currentContext.thisList, - // Make sure we get all the items, ignoring any filters on the default view. - CAMLQuery: "", - // Filter based on columnStaticName's value - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData) { - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = opt.ignoreCase ? $(this).attr("ows_" + opt.columnStaticName).toUpperCase() : $(this).attr("ows_" + opt.columnStaticName); - // If this value already exists in columnStaticName and it's not the current item, then save the ID in the array - if((testValue === thisValue) && ($(this).attr("ows_ID") !== thisID)) { - columnValueIDs.push([$(this).attr("ows_ID"), $(this).attr("ows_" + opt.columnStaticName)]); - } - }); - } - }); - var newMsg = opt.initMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.initMsgCSSClass); - - $("input[value='OK']:disabled, input[value='Save']:disabled").removeAttr("disabled"); - if(columnValueIDs.length > 0) { - newMsg = opt.errMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.errMsgCSSClass); - if(opt.duplicateAction === 1) { - $("input[Title='" + opt.columnDisplayName + "']").focus(); - $("input[value='OK'], input[value='Save']").attr("disabled", "disabled"); - } - if(opt.showDupes) { - var out = " " + columnValueIDs.length + " duplicate item" + (columnValueIDs.length > 1 ? "s" : "") + ": "; - for (i=0;i < columnValueIDs.length; i++) { - out += "
    " + columnValueIDs[i][1] + " "; - } - $("span#SPRequireUnique" + opt.columnStaticName).append(out); - } - } - - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPRequireUnique - - // This function returns the DisplayName for a column based on the StaticName. - $.fn.SPServices.SPGetDisplayFromStatic = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnStaticName: "", // StaticName of the column - columnStaticNames: {} // StaticName of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var displayName = ""; - var displayNames = {}; - var nameCount = opt.columnStaticNames.length > 0 ? opt.columnStaticNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - displayNames[opt.columnStaticNames[i]] = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticNames[i] + "']").attr("DisplayName"); - } - } else { - displayName = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticName + "']").attr("DisplayName"); - } - } - }); - - return (nameCount > 1) ? displayNames : displayName; - - }; // End $.fn.SPServices.SPGetDisplayFromStatic - - // This function returns the StaticName for a column based on the DisplayName. - $.fn.SPServices.SPGetStaticFromDisplay = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnDisplayName: "", // DisplayName of the column - columnDisplayNames: {} // DisplayNames of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var staticName = ""; - var staticNames = {}; - var nameCount = opt.columnDisplayNames.length > 0 ? opt.columnDisplayNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - staticNames[opt.columnDisplayNames[i]] = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayNames[i] + "']").attr("StaticName"); - } - } else { - staticName = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayName + "']").attr("StaticName"); - } - } - }); - - return (nameCount > 1) ? staticNames : staticName; - - }; // End $.fn.SPServices.SPGetStaticFromDisplay - - // This function allows you to redirect to a another page from a new item form with the new - // item's ID. This allows chaining of forms from item creation onward. - $.fn.SPServices.SPRedirectWithID = function (options) { - - var opt = $.extend({}, { - redirectUrl: "", // Page for the redirect - qsParamName: "ID" // In some cases, you may want to pass the newly created item's ID with a different - // parameter name than ID. Specify that name here, if needed. - }, options); - - currentContext.thisList = $().SPServices.SPListNameFromUrl(); - var queryStringVals = $().SPServices.SPGetQueryString(); - var lastID = queryStringVals.ID; - var QSList = queryStringVals.List; - var QSRootFolder = queryStringVals.RootFolder; - var QSContentTypeId = queryStringVals.ContentTypeId; - - // On first load, change the form actions to redirect back to this page with the current lastID for this user and the - // original Source. - if(typeof queryStringVals.ID === "undefined") { - lastID = $().SPServices.SPGetLastItemId({ - listName: currentContext.thisList - }); - $("form[name='aspnetForm']").each(function() { - // This page... - var thisUrl = (location.href.indexOf("?") > 0) ? location.href.substring(0, location.href.indexOf("?")) : location.href; - // ... plus the Source if it exists - var thisSource = (typeof queryStringVals.Source === "string") ? - "Source=" + queryStringVals.Source.replace(/\//g, "%2f").replace(/:/g, "%3a") : ""; - - var newQS = []; - if(typeof QSList !== "undefined") { - newQS.push("List=" + QSList); - } - if(typeof QSRootFolder !== "undefined") { - newQS.push("RootFolder=" + QSRootFolder); - } - if(typeof QSContentTypeId !== "undefined") { - newQS.push("ContentTypeId=" + QSContentTypeId); - } - - var newAction = thisUrl + - ((newQS.length > 0) ? ("?" + newQS.join("&") + "&") : "?") + - // Set the Source to point back to this page with the lastID this user has added - "Source=" + thisUrl + - "?ID=" + lastID + - // Pass the original source as RealSource, if present - ((thisSource.length > 0) ? ("%26RealSource=" + queryStringVals.Source) : "") + - // Pass the override RedirectURL, if present - ((typeof queryStringVals.RedirectURL === "string") ? ("%26RedirectURL=" + queryStringVals.RedirectURL) : ""); - $(this).attr("action", newAction); - }); - // If this is the load after the item is saved, wait until the new item has been saved (commits are asynchronous), - // then do the redirect to redirectUrl with the new lastID, passing along the original Source. - } else { - while(queryStringVals.ID === lastID) { - lastID = $().SPServices.SPGetLastItemId({ - listName: currentContext.thisList - }); - } - // If there is a RedirectURL parameter on the Query String, then redirect there instead of the value - // specified in the options (opt.redirectUrl) - var thisRedirectUrl = (typeof queryStringVals.RedirectURL === "string") ? queryStringVals.RedirectURL : opt.redirectUrl; - location.href = thisRedirectUrl + "?" + opt.qsParamName + "=" + lastID + - ((typeof queryStringVals.RealSource === "string") ? ("&Source=" + queryStringVals.RealSource) : ""); - } - }; // End $.fn.SPServices.SPRedirectWithID - - // The SPSetMultiSelectSizes function sets the sizes of the multi-select boxes for a column on a form automagically - // based on the values they contain. The function takes into account the fontSize, fontFamily, fontWeight, etc., in its algorithm. - $.fn.SPServices.SPSetMultiSelectSizes = function (options) { - - var opt = $.extend({}, { - multiSelectColumn: "", - minWidth: 0, - maxWidth: 0, - debug: false - }, options); - - var thisFunction = "SPServices.SPSetMultiSelectSizes"; - - // Find the multi-select column - var thisMultiSelect = new DropdownCtl(opt.multiSelectColumn); - if(thisMultiSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, TXTColumnNotFound);return;} - if(thisMultiSelect.Type !== "M" && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, "Column is not multi-select.");return;} - - var possibleValues = thisMultiSelect.Obj; - var selectedValues = possibleValues.closest("span").find("select[ID$='SelectResult']"); - - // Create a temporary clone of the select to use to determine the appropriate width settings. - // We'll append it to the end of the enclosing span. - var cloneId = genContainerId("SPSetMultiSelectSizes", opt.multiSelectColumn); - possibleValues.clone().appendTo(possibleValues.closest("span")).css({ - "width": "auto", // We want the clone to resize its width based on the contents - "height": 0, // Just to keep the page clean while we are using the clone - "visibility": "hidden" // And let's keep it hidden - }).attr({ - id: cloneId, // We don't want the clone to have the same id as its source - length: 0 // And let's start with no options - }); - var cloneObj = $("#" + cloneId); - - // Add all the values to the cloned select. First the left (possible values) select... - possibleValues.find("option").each(function() { - cloneObj.append(""); - }); - // ...then the right (selected values) select (in case some values have already been selected) - selectedValues.find("option").each(function() { - cloneObj.append(""); - }); - - // We'll add 5px for a little padding on the right. - var divWidth = $("#" + cloneId).width() + 5; - var newDivWidth = divWidth; - if(opt.minWidth > 0 || opt.maxWidth > 0) { - if(divWidth < opt.minWidth) { - divWidth = opt.minWidth; - } - if(newDivWidth < opt.minWidth) { - newDivWidth = opt.minWidth; - } - if(newDivWidth > opt.maxWidth) { - newDivWidth = opt.maxWidth; - } - } - var selectWidth = divWidth; - - // Set the new widths - possibleValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - selectedValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - - // Remove the select's clone, since we're done with it - $("#" + cloneId).remove(); - }; // End $.fn.SPServices.SPSetMultiSelectSizes - - // Does an audit of a site's list forms to show where script is in use. - $.fn.SPServices.SPScriptAudit = function (options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] The name of the Web (site) to audit - listName: "", // [Optional] The name of a specific list to audit. If not present, all lists in the site are audited. - outputId: "", // The id of the DOM object for output - auditForms: true, // Audit the form pages - auditViews: true, // Audit the view pages - auditPages: true, // Audit the Pages Document Library - auditPagesListName: "Pages", // The Pages Document Library(ies), if desired. Either a single string or an array of strings. - showHiddenLists: false, // Show output for hidden lists - showNoScript: false, // Show output for lists with no scripts (effectively "verbose") - showSrc: true // Show the source location for included scripts - }, options); - - var formTypes = [["New", "NewForm.aspx", false], ["Display", "DispForm.aspx", false], ["Edit", "EditForm.aspx", false]]; - var listXml; - - // Build the table to contain the results - $("#" + opt.outputId) - .append("" + - "" + - "" + - "" + - "" + - "" + - "" + - (opt.showSrc ? "" : "") + - "" + - "
    ListPage ClassPage TypePageScript References
    "); - // Apply the CSS class to the headers - $("#SPScriptAudit th").attr("class", "ms-vh2-nofilter"); - - // Don't bother with the lists if the options don't require them - if(opt.auditForms || opt.auditViews) { - // First, get all of the lists within the site - $().SPServices({ - operation: "GetListCollection", - webURL: opt.webURL, - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - - // If listName has been specified, then only return results for that list - if((opt.listName.length === 0) || (listXml.attr("Title") === opt.listName)) { - // Don't work with hidden lists unless we're asked to - if((opt.showHiddenLists && listXml.attr("Hidden") === "False") || !opt.showHiddenLists) { - - // Audit the list's forms - if(opt.auditForms) { - // Get the list's Content Types, therefore the form pages - $().SPServices({ - operation: "GetListContentTypes", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("ContentType").each(function() { - // Don't deal with folders - if($(this).attr("ID").substring(0,6) !== "0x0120") { - var formUrls = $(this).find("FormUrls"); - for(i=0; i < formTypes.length; i++) { - // Look for a customized form... - $(formUrls).find(formTypes[i][0]).each(function() { - SPScriptAuditPage(opt, listXml, "Form", this.nodeName, - ((opt.webURL.length > 0) ? opt.webURL : $().SPServices.SPGetCurrentSite()) + SLASH + $(this).text()); - formTypes[i][2] = true; - }); - // ...else the uncustomized form - if(!formTypes[i][2]) { - var defaultViewUrl = listXml.attr("DefaultViewUrl"); - SPScriptAuditPage(opt, listXml, "Form", formTypes[i][0], - defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH)+1) + formTypes[i][1]); - } - } - // Reset the form types - for(i=0; i < formTypes.length; i++) { - formTypes[i][2] = false; - } - } - }); - } - }); - } - - // Audit the list's views - if(opt.auditViews) { - // Get the list's Views - $().SPServices({ - operation: "GetViewCollection", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("View").each(function() { - SPScriptAuditPage(opt, listXml, "View", $(this).attr("DisplayName"), $(this).attr("Url")); - }); - } - }); - } - - } - } - }); - } - }); - } - - // Don't bother with auditing pages if the options don't require it - var numLists = 0; - var listsArray = []; - if(typeof opt.auditPagesListName === "string") { - numLists = 1; - listsArray.push(opt.auditPagesListName); - } else { - numLists = opt.auditPagesListName.length; - listsArray = opt.auditPagesListName; - } - - if(opt.auditPages) { - for(i=0; i < numLists; i++) { - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: listsArray[i], - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - }); - } - }); - // Get all of the items from the Document Library - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: listsArray[i], - CAMLQuery: "Folder", - CAMLViewFields: "", - CAMLRowLimit: 0, - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisPageUrl = $(this).attr("ows_FileRef").split(";#")[1]; - var thisTitle = $(this).attr("ows_Title"); - var thisPageType = (typeof thisTitle !== "undefined") ? thisTitle : ""; - if(thisPageUrl.indexOf(".aspx") > 0) { - SPScriptAuditPage(opt, listXml, "Page", thisPageType, SLASH + thisPageUrl); - } - }); - } - }); - } - } - // Remove progress indicator and make the output pretty by cleaning up the ms-alternating CSS class - $("#SPScriptAudit tr[class='ms-alternating']:even").removeAttr("class"); - }; // End $.fn.SPServices.SPScriptAudit - - // Displays the usage of scripts in a site - function SPScriptAuditPage(opt, listXml, pageClass, pageType, pageUrl) { - - var i = 0; - var jQueryPage = 0; - var pageScriptSrc = {}; - pageScriptSrc.type = []; - pageScriptSrc.src = []; - pageScriptSrc.script = []; - var scriptRegex = RegExp("", "gi"); - - // Fetch the page - $.ajax({ - type: "GET", - url: pageUrl, - dataType: "text", - async: false, - success: function(xData) { - - var scriptMatch; - - while (scriptMatch = scriptRegex.exec(xData)) { - var scriptLanguage = getScriptAttribute(scriptMatch, "language"); - var scriptType = getScriptAttribute(scriptMatch, "type"); - var scriptSrc = getScriptAttribute(scriptMatch, "src"); - if(scriptSrc !== null && scriptSrc.length > 0 && !coreScript(scriptSrc)) { - pageScriptSrc.type.push((scriptLanguage !== null && scriptLanguage.length > 0) ? scriptLanguage : scriptType); - pageScriptSrc.src.push(scriptSrc); - jQueryPage++; - } - } - - // Only show pages without script if we've been asked to do so. - if((!opt.showNoScript && (pageScriptSrc.type.length > 0)) || opt.showNoScript) { - var pagePath = pageUrl.substring(0, pageUrl.lastIndexOf(SLASH)+1); - var out = "" + - "" + - "" + listXml.attr("Title") + ((listXml.attr("Hidden") === "True") ? '(Hidden)' : '')+ "" + - "" + pageClass + "" + - "" + pageType + "" + - "" + fileName(pageUrl) + ""; - if(opt.showSrc) { - var thisSrcPath; - out += ""; - for(i=0; i < pageScriptSrc.type.length; i++) { - thisSrcPath = (pageScriptSrc.src[i].substr(0,1) !== SLASH) ? pagePath + pageScriptSrc.src[i] : pageScriptSrc.src[i]; - out += ""; - out += ""; - } - out += "
    " + pageScriptSrc.type[i] + "" + fileName(pageScriptSrc.src[i]) + "
    "; - } - $("#SPScriptAudit").append(out); - } - } - }); - } // End of function SPScriptAuditPage - - function getScriptAttribute(source, attribute) { - var matches; - var regex = RegExp(attribute + "=(\"([^\"]*)\")|('([^']*)')", "gi"); - if(matches = regex.exec(source)) { - return matches[2]; - } - return null; - } // End of function getScriptAttribute - - // Check to see if the script reference is part of SharePoint core so that we can ignore it - function coreScript(src) { - var i; - var coreScriptLocations = ["WebResource.axd", "_layouts"]; - for(i=0; i < coreScriptLocations.length; i++) { - if(src.indexOf(coreScriptLocations[i]) > -1) { - return true; - } - } - return false; - } // End of function coreScript - - // Rearrange radio buttons or checkboxes in a form from vertical to horizontal display to save page real estate - $.fn.SPServices.SPArrangeChoices = function (options) { - - var opt = $.extend({}, { - listName: "", // The list name for the current form - columnName: "", // The display name of the column in the form - perRow: 99, // Maximum number of choices desired per row. - randomize: false // If true, randomize the order of the options - }, options); - - var columnFillInChoice = false; - var columnOptions = []; - var out; - - // Get information about columnName from the list to determine if we're allowing fill-in choices - var thisGetList = $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: (opt.listName.length > 0) ? opt.listName : $().SPServices.SPListNameFromUrl() - }); - - // when the promise is available... - thisGetList.done(function() { - var thisPayload = thisGetList.responseXML; - $(thisPayload).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName allows a fill-in choice - columnFillInChoice = ($(this).attr("FillInChoice") === "TRUE") ? true : false; - // Stop looking;we're done - return false; - }); - - var thisFormField = findFormField(opt.columnName); - - var totalChoices = $(thisFormField).find("tr").length; - var choiceNumber = 0; - var fillinPrompt; - var fillinInput; - // Collect all of the choices - $(thisFormField).find("tr").each(function() { - choiceNumber++; - // If this is the fill-in prompt, save it... - if(columnFillInChoice && choiceNumber === (totalChoices - 1)) { - fillinPrompt = $(this).find("td").html(); - // ...or if it is the fill-in input box, save it... - } else if(columnFillInChoice && choiceNumber === totalChoices) { - fillinInput = $(this).find("td").html(); - // ...else push into the columnOptions array. - } else { - columnOptions.push($(this).html()); - } - }); - out = ""; - - // If randomize is true, randomly sort the options - if(opt.randomize) { - columnOptions.sort(randOrd); - } - - // Add all of the options to the out string - for(i=0; i < columnOptions.length; i++) { - out += columnOptions[i]; - // If we've already got perRow columnOptions in the row, close off the row - if((i+1) % opt.perRow === 0) { - out += ""; - } - } - out += ""; - - // If we are allowing a fill-in choice, add that option in a separate row at the bottom - if(columnFillInChoice) { - out += "" + fillinPrompt + fillinInput + ""; - } - - // Remove the existing rows... - $(thisFormField).find("tr").remove(); - // ...and append the out string - $(thisFormField).find("table").append(out); - - }); - - }; // End $.fn.SPServices.SPArrangeChoices - - // Provide suggested values from a list for in input column based on characters typed - $.fn.SPServices.SPAutocomplete = function (options) { - - var opt = $.extend({}, { - WebURL: "", // [Optional] The name of the Web (site) which contains the sourceList - sourceList: "", // The name of the list which contains the values - sourceColumn: "", // The static name of the column which contains the values - columnName: "", // The display name of the column in the form - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relatedList - CAMLQueryOptions: "", // [Optional] For power users, allows specifying the CAMLQueryOptions for the GetListItems call - CAMLRowLimit: 0, // [Optional] Override the default view rowlimit and get all appropriate rows - filterType: "BeginsWith", // Type of filtering: [BeginsWith, Contains] - numChars: 0, // Wait until this number of characters has been typed before attempting any actions - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - highlightClass: "", // If a class is supplied, highlight the matched characters in the values by applying that class to a wrapping span - uniqueVals: false, // If set to true, the function only adds unique values to the list (no duplicates) - maxHeight: 99999, // Sets the maximum number of values to display before scrolling occurs - slideDownSpeed: "fast", // Speed at which the div should slide down when values match (milliseconds or ["fast" | "slow"]) - processingIndicator: "_layouts/images/REFRESH.GIF", // If present, show this while processing - debug: false // If true, show error messages;if false, run silent - }, options); - - var matchNum; - - // Find the input control for the column and save some of its attributes - var columnObj = $("input[Title='" + opt.columnName + "']"); - $("input[Title='" + opt.columnName + "']").css("position", ""); - var columnObjId = columnObj.attr("ID"); - var columnObjColor = columnObj.css("color"); - var columnObjWidth = columnObj.css("width"); - - if(columnObj.html() === null && opt.debug) { - errBox("SPServices.SPAutocomplete", - "columnName: " + opt.columnName, - "Column is not an input control or is not found on page"); - return; - } - - // Remove the
    which isn't needed and messes up the formatting - columnObj.closest("span").find("br").remove(); - columnObj.wrap("
    "); - - // Create a div to contain the matching values and add it to the DOM - var containerId = genContainerId("SPAutocomplete", opt.columnName); - columnObj.after("
    "); - - // Set the width to match the width of the input control - $("#" + containerId).css("width", columnObjWidth); - - // Handle keypresses - $(columnObj).keyup(function () { - - // Get the column's value - var columnValue = $(this).val(); - - // Hide the container while we're working on it - $("#" + containerId).hide(); - - // Have enough characters been typed yet? - if(columnValue.length < opt.numChars) { - return false; - } - - // Show the the processingIndicator as a background image in the input element - columnObj.css({ - "background-image": "url(" + opt.processingIndicator + ")", - "background-position": "right", - "background-repeat": "no-repeat" - }); - - // Array to hold the matched values - var matchArray = []; - - // Build the appropriate CAMLQuery - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - camlQuery += "<" + opt.filterType + ">" + columnValue + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - // Call GetListItems to find all of the potential values - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.WebURL, - listName: opt.sourceList, - CAMLQuery: camlQuery, - CAMLQueryOptions: opt.CAMLQueryOptions, - CAMLViewFields: "", - CAMLRowLimit: opt.CAMLRowLimit, - completefunc: function(xData) { - // Handle upper/lower case if ignoreCase = true - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - // See which values match and add the ones that do to matchArray - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = $(this).attr("ows_" + opt.sourceColumn); - var thisValueTest = opt.ignoreCase ? $(this).attr("ows_" + opt.sourceColumn).toUpperCase() : $(this).attr("ows_" + opt.sourceColumn); - // Make sure we have a match... - if(opt.filterType === "Contains") { - var firstMatch = thisValueTest.indexOf(testValue); - if((firstMatch >= 0) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } else { - // Handles normal case, which is BeginsWith and and other unknown values - if(testValue === thisValueTest.substr(0,testValue.length) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } - }); - } - }); - - // Build out the set of list elements to contain the available values - var out = ""; - for (i=0; i < matchArray.length; i++) { - // If a highlightClass has been supplied, wrap a span around each match - if(opt.highlightClass.length > 0) { - // Set up Regex based on whether we want to ignore case - var thisRegex = RegExp(columnValue, opt.ignoreCase ? "gi" : "g"); - // Look for all occurrences - var matches = matchArray[i].match(thisRegex); - var startLoc = 0; - // Loop for each occurrence, wrapping each in a span with the highlightClass CSS class - for (matchNum=0; matchNum < matches.length; matchNum++) { - var thisPos = matchArray[i].indexOf(matches[matchNum], startLoc); - var endPos = thisPos + matches[matchNum].length; - var thisSpan = "" + matches[matchNum] + ""; - matchArray[i] = matchArray[i].substr(0, thisPos) + thisSpan + matchArray[i].substr(endPos); - startLoc = thisPos + thisSpan.length; - } - } - // Add the value to the markup for the container - out += "
  • " + matchArray[i] + "
  • "; - } - - // Add all the list elements to the containerId container - $("#" + containerId).html(out); - // Set up hehavior for the available values in the list element - $("#" + containerId + " li").click(function () { - $("#" + containerId).fadeOut(opt.slideUpSpeed); - $("#" + columnObjId).val($(this).text()); - }).mouseover(function () { - var mouseoverCss = { - "cursor": "hand", - "color": "#ffffff", - "background": "#3399ff" - }; - $(this).css(mouseoverCss); - }).mouseout(function () { - var mouseoutCss = { - "cursor": "inherit", - "color": columnObjColor, - "background": "transparent" - }; - $(this).css(mouseoutCss); - }); - - // If we've got some values to show, then show 'em! - if(matchArray.length > 0) { - $("#" + containerId).slideDown(opt.slideDownSpeed); - } - // Remove the processing indicator - columnObj.css("background-image", ""); - }); - - }; // End $.fn.SPServices.SPAutocomplete - - // Get the Query String parameters and their values and return in an array - $.fn.SPServices.SPGetQueryString = function () { - - var queryStringVals = {}; - var matches; - var qs = location.search.substring(1, location.search.length); - var args = qs.split("&"); - var rxQS = /^([^=]+)=(.*)/i; - - for(var i=0; i < args.length; i++) { - matches = rxQS.exec(args[i]); - if(rxQS.test(location.href)) { - if(matches !== null && matches.length > 2) { - queryStringVals[matches[1]] = unescape(matches[2]).replace(/\+/g,' '); - } - } - } - return queryStringVals; - - }; // End $.fn.SPServices.SPGetQueryString - - // Get the current list's GUID (ID) from the current URL. Use of this function only makes sense if we're in a list's context, - // and we assume that we are calling it from an aspx page which is a form or view for the list. - $.fn.SPServices.SPListNameFromUrl = function (options) { - - var opt = $.extend({}, { - listName: "" // [Optional] Pass in the name or GUID of a list if you are not in its context. e.g., on a Web Part pages in the Pages library - }, options); - - // Has the list name or GUID been passed in? - if(opt.listName.length > 0) { - currentContext.thisList = opt.listName; - return currentContext.thisList; - // Do we already know the current list? - } else if(currentContext.thisList.length > 0) { - return currentContext.thisList; - } - - // Parse out the list's root URL from the current location or the passed url - var thisPage = location.href; - var thisPageBaseName = thisPage.substring(0, thisPage.indexOf(".aspx")); - var listPath = decodeURIComponent(thisPageBaseName.substring(0, thisPageBaseName.lastIndexOf(SLASH) + 1)).toUpperCase(); - - // Call GetListCollection and loop through the results to find a match with the list's URL to get the list's GUID - $().SPServices({ - operation: "GetListCollection", - async: false, - completefunc: function(xData, Status) { - $(xData.responseXML).find("List").each(function() { - var defaultViewUrl = $(this).attr("DefaultViewUrl"); - var listCollList = defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH) + 1).toUpperCase(); - if(listPath.indexOf(listCollList) > 0) { - currentContext.thisList = $(this).attr("ID"); - return false; - } - }); - } - }); - - // Return the list GUID (ID) - return currentContext.thisList; - - }; // End $.fn.SPServices.SPListNameFromUrl - - // SPUpdateMultipleListItems allows you to update multiple items in a list based upon some common characteristic or metadata criteria. - $.fn.SPServices.SPUpdateMultipleListItems = function(options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] URL of the target Web. If not specified, the current Web is used. - listName: "", // The list to operate on. - CAMLQuery: "", // A CAML fragment specifying which items in the list will be selected and updated - batchCmd: "Update", // The operation to perform. By default, Update. - valuepairs: [], // Valuepairs for the update in the form [[fieldname1, fieldvalue1], [fieldname2, fieldvalue2]...] - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var i; - var itemsToUpdate = []; - var documentsToUpdate = []; - - // Call GetListItems to find all of the items matching the CAMLQuery - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: opt.CAMLQuery, - CAMLQueryOptions: "", - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - itemsToUpdate.push($(this).attr("ows_ID")); - var fileRef = $(this).attr("ows_FileRef"); - fileRef = "/" + fileRef.substring(fileRef.indexOf(";#")+2); - documentsToUpdate.push(fileRef); - }); - } - }); - - var fieldNum; - var batch = ""; - for(i=0; i < itemsToUpdate.length; i++) { - batch += ""; - for (fieldNum=0; fieldNum < opt.valuepairs.length; fieldNum++) { - batch += "" + escapeColumnValue(opt.valuepairs[fieldNum][1]) + ""; - } - batch += "" + itemsToUpdate[i] + ""; - if(documentsToUpdate[i].length > 0) { - batch += "" + documentsToUpdate[i] + ""; - } - batch += ""; - } - batch += ""; - - // Call UpdateListItems to update all of the items matching the CAMLQuery - $().SPServices({ - operation: "UpdateListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - updates: batch, - completefunc: function(xData) { - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(xData, Status); - } - } - }); - - }; // End $.fn.SPServices.SPUpdateMultipleListItems - - // This method for finding specific nodes in the returned XML was developed by Steve Workman. See his blog post - // http://www.steveworkman.com/html5-2/javascript/2011/improving-javascript-xml-node-finding-performance-by-2000/ - // for performance details. - $.fn.SPFilterNode = function(name) { - return this.find('*').filter(function() { - return this.nodeName === name; - }); - }; // End $.fn.SPFilterNode - - - // This function converts an XML node set to JSON - // Initial implementation focuses only on GetListItems - $.fn.SPXmlToJson = function(options) { - - var opt = $.extend({}, { - mapping: {}, // columnName: mappedName: "mappedName", objectType: "objectType" - includeAllAttrs: false, // If true, return all attributes, regardless whether they are in the mapping - removeOws: true // Specifically for GetListItems, if true, the leading ows_ will be stripped off the field name - }, options); - - var attrNum; - var jsonObject = []; - - this.each(function() { - var row = {}; - var rowAttrs = this.attributes; - - // Bring back all mapped columns, even those with no value - $.each(opt.mapping, function() { - row[this.mappedName] = ""; - }); - - // Parse through the element's attributes - for(attrNum = 0; attrNum < rowAttrs.length; attrNum++) { - var thisAttrName = rowAttrs[attrNum].name; - var thisMapping = opt.mapping[thisAttrName]; - var thisObjectName = typeof thisMapping !== "undefined" ? thisMapping.mappedName : opt.removeOws ? thisAttrName.split("ows_")[1] : thisAttrName; - var thisObjectType = typeof thisMapping !== "undefined" ? thisMapping.objectType : undefined; - if(opt.includeAllAttrs || thisMapping !== undefined) { - row[thisObjectName] = attrToJson(rowAttrs[attrNum].value, thisObjectType); - } - } - // Push this item into the JSON Object - jsonObject.push(row); - - }); - - // Return the JSON object - return jsonObject; - - }; // End $.fn.SPServices.SPXmlToJson - - - function attrToJson(v, objectType) { - - var colValue; - - switch (objectType) { - case "DateTime": - case "datetime": // For calculated columns, stored as datetime;#value - // Dates have dashes instead of slashes: ows_Created="2009-08-25 14:24:48" - colValue = dateToJsonObject(v); - break; - case "User": - colValue = userToJsonObject(v); - break; - case "UserMulti": - colValue = userMultiToJsonObject(v); - break; - case "Lookup": - colValue = lookupToJsonObject(v); - break; - case "LookupMulti": - colValue = lookupMultiToJsonObject(v); - break; - case "Boolean": - colValue = booleanToJsonObject(v); - break; - case "Integer": - colValue = intToJsonObject(v); - break; - case "Counter": - colValue = intToJsonObject(v); - break; - case "MultiChoice": - colValue = choiceMultiToJsonObject(v); - break; - case "Currency": - case "float": // For calculated columns, stored as float;#value - colValue = floatToJsonObject(v); - break; - case "Calc": - colValue = calcToJsonObject(v); - break; - default: - // All other objectTypes will be simple strings - colValue = stringToJsonObject(v); - break; - } - return colValue; - } - - function stringToJsonObject(s) { - return s; - } - function intToJsonObject(s) { - return parseInt(s, 10); - } - function floatToJsonObject(s) { - return parseFloat(s); - } - function booleanToJsonObject(s) { - var out = s === "0" ? false : true; - return out; - } - function dateToJsonObject(s) { - return new Date(s.replace(/-/g, "/")); - } - function userToJsonObject(s) { - if (s.length === 0) { - return null; - } else { - var thisUser = new SplitIndex(s); - var thisUserExpanded = thisUser.value.split(",#"); - if(thisUserExpanded.length === 1) { - return {userId: thisUser.Id, userName: thisUser.value}; - } else { - return { - userId: thisUser.Id, - userName: thisUserExpanded[0].replace( /(,,)/g, ","), - loginName: thisUserExpanded[1].replace( /(,,)/g, ","), - email: thisUserExpanded[2].replace( /(,,)/g, ","), - sipAddress: thisUserExpanded[3].replace( /(,,)/g, ","), - title: thisUserExpanded[4].replace( /(,,)/g, ",") - }; - } - } - } - function userMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisUserMultiObject = []; - var thisUserMulti = s.split(";#"); - for(i=0; i < thisUserMulti.length; i=i+2) { - var thisUser = userToJsonObject(thisUserMulti[i] + ";#" + thisUserMulti[i+1]); - thisUserMultiObject.push(thisUser); - } - return thisUserMultiObject; - } - } - function lookupToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookup = new SplitIndex(s); - return {lookupId: thisLookup.id, lookupValue: thisLookup.value}; - } - } - function lookupMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookupMultiObject = []; - var thisLookupMulti = s.split(";#"); - for(i=0; i < thisLookupMulti.length; i=i+2) { - var thisLookup = lookupToJsonObject(thisLookupMulti[i] + ";#" + thisLookupMulti[i+1]); - thisLookupMultiObject.push(thisLookup); - } - return thisLookupMultiObject; - } - } - function choiceMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisChoiceMultiObject = []; - var thisChoiceMulti = s.split(";#"); - for(i=0; i < thisChoiceMulti.length; i++) { - if(thisChoiceMulti[i].length !== 0) { - thisChoiceMultiObject.push(thisChoiceMulti[i]); - } - } - return thisChoiceMultiObject; - } - } - function calcToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisCalc = s.split(";#"); - // The first value will be the calculated column value type, the second will be the value - return attrToJson(thisCalc[1], thisCalc[0]); - } - } - - // Find a People Picker in the page - // Returns references to: - // row - The TR which contains the People Picker (useful if you'd like to hide it at some point) - // contents - The element which contains the current value - // currentValue - The current value if it is set - // checkNames - The Check Names image (in case you'd like to click it at some point) - $.fn.SPFindPeoplePicker = function(options) { - - var opt = $.extend({}, { - peoplePickerDisplayName: "", // The displayName of the People Picker on the form - valueToSet: "", // The value to set the People Picker to. Should be a string containing each username or groupname separated by semi-colons. - checkNames: true // If set to true, the Check Names image will be clicked to resolve the names - }, options); - - var thisRow = $("nobr").filter(function() { - // Ensures we get a match whether or not the People Picker is required (if required, the nobr contains a span also) - return $(this).contents().eq(0).text() === opt.peoplePickerDisplayName; - }).closest("tr"); - - var thisContents = thisRow.find("div[name='upLevelDiv']"); - var thisCheckNames = thisRow.find("img[Title='Check Names']:first"); - - // If a value was provided, set the value - if(opt.valueToSet.length > 0) { - thisContents.html(opt.valueToSet); - } - - // If checkName is true, click the check names icon - if(opt.checkNames) { - thisCheckNames.click(); - } - var thisCurrentValue = $.trim(thisContents.text()); - - // Parse the entity data - var dictionaryEntries = []; - - // IE - thisContents.children("span").each(function() { - - // Grab the entity data - var thisData = $(this).find("div[data]").attr("data"); - - var dictionaryEntry = {}; - - // Entity data is only available in IE - if(typeof thisData !== "undefined") { - var arrayOfDictionaryEntry = $.parseXML(thisData); - var $xml = $(arrayOfDictionaryEntry); - - $xml.find("DictionaryEntry").each(function() { - var key = $(this).find("Key").text(); - var value = $(this).find("Value").text(); - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - // For other browsers, we'll call GetUserInfo to get the data - } else { - $().SPServices({ - operation: "GetUserInfo", - async: false, - cacheXML: true, - userLoginName: $(this).attr("title"), - completefunc: function(xData) { - - $(xData.responseXML).find("User").each(function() { - - $.each(this.attributes, function(i, attrib){ - var key = attrib.name; - var value = attrib.value; - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - }); - } - }); - } - }); - - return {row: thisRow, contents: thisContents, currentValue: thisCurrentValue, checkNames: thisCheckNames, dictionaryEntries: dictionaryEntries}; - }; - - // Return the current version of SPServices as a string - $.fn.SPServices.Version = function () { - - return VERSION; - - }; // End $.fn.SPServices.Version - - -////// PRIVATE FUNCTIONS //////// - - // Get the current context (as much as we can) on startup - // See: http://johnliu.net/blog/2012/2/3/sharepoint-javascript-current-page-context-info.html - function SPServicesContext() { - - // SharePoint 2010 gives us a context variable - if(typeof _spPageContextInfo !== "undefined") { - this.thisSite = _spPageContextInfo.webServerRelativeUrl; - this.thisList = _spPageContextInfo.pageListId; - this.thisUserId = _spPageContextInfo.userId; - // In SharePoint 2007, we know the UserID only - } else { - this.thisSite = ""; - this.thisList = ""; - this.thisUserId = (typeof _spUserId !== "undefined") ? _spUserId : undefined; - } - - } // End of function SPServicesContext - - - // Display a column (field) formatted correctly based on its definition in the list. - // NOTE: Currently not dealing with locale differences. - // columnXML The XML node for the column from a GetList operation - // columnValue The text representation of the column's value - // opt The current set of options - function showColumn(listXML, columnXML, columnValue, opt) { - - if(typeof columnValue === "undefined") { - return ""; - } - - var i; - var outString = ""; - var dispUrl; - var numDecimals; - var outArray =[]; - var webUrl = opt.relatedWebURL.length > 0 ? opt.relatedWebURL : $().SPServices.SPGetCurrentSite(); - - switch(columnXML.attr("Type")) { - case "Text": - outString = columnValue; - break; - case "URL": - switch(columnXML.attr("Format")) { - // URL as hyperlink - case "Hyperlink": - outString = "
    " + - columnValue.substring(columnValue.search(",") + 1) + ""; - break; - // URL as image - case "Image": - outString = "" + columnValue.substring(columnValue.search(",") + 1) +
-							""; - break; - // Just in case - default: - outString = columnValue; - break; - } - break; - case "User": - case "UserMulti": - var userMultiValues = columnValue.split(";#"); - for(i=0; i < userMultiValues.length; i = i+2) { - outArray.push("" + - userMultiValues[i+1] + ""); - } - outString = outArray.join(", "); - break; - case "Calculated": - var calcColumn = columnValue.split(";#"); - outString = calcColumn[1]; - break; - case "Number": - numDecimals = columnXML.attr("Decimals"); - outString = typeof numDecimals === "undefined" ? - parseFloat(columnValue).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Currency": - numDecimals = columnXML.attr("Decimals"); - outString = typeof numDecimals === "undefined" ? - parseFloat(columnValue).toFixed(2).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Lookup": - switch(columnXML.attr("Name")) { - case "FileRef": - // Get the display form URL for the lookup source list - dispUrl = listXML.attr("BaseType") === "1" ? listXML.attr("RootFolder") + SLASH + "Forms/DispForm.aspx" : - listXML.attr("RootFolder") + SLASH + "DispForm.aspx"; - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - case "FileDirRef": - // Get the display form URL for the lookup source list - dispUrl = SLASH + columnValue.substring(columnValue.search(";#") + 2); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - // Any other lookup column - default: - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - } - break; - case "LookupMulti": - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - // Show all the values as links to the items, separated by commas - outString = ""; - if(columnValue.length > 0) { - var lookupMultiValues = columnValue.split(";#"); - for(i=0; i < lookupMultiValues.length / 2; i++) { - outArray.push("" + - lookupMultiValues[(i * 2) + 1] + ""); - } - } - outString = outArray.join(", "); - break; - case "File": - fileName = columnValue.substring(columnValue.search(";#") + 2); - outString = "" + fileName + ""; - break; - case "Counter": - outString = columnValue; - break; - case "DateTime": - outString = columnValue; - break; - default: - outString = columnValue; - break; - } - return outString; - } // End of function showColumn - - - // Show a single attribute of a node, enclosed in a table - // node The XML node - // opt The current set of options - function showAttrs(node) { - var i; - var out = ""; - for (i=0; i < node.attributes.length; i++) { - out += ""; - } - out += "
    " + i + "" + - node.attributes.item(i).nodeName + "" + checkLink(node.attributes.item(i).nodeValue) + "
    "; - return out; - } // End of function showAttrs - - - // Find a dropdown (or multi-select) in the DOM. Returns the dropdown onject and its type: - // S = Simple (select);C = Compound (input + select hybrid);M = Multi-select (select hybrid) - function DropdownCtl(colName) { - // Simple - if((this.Obj = $("select[Title='" + colName + "']")).length === 1) { - this.Type = "S"; - // Compound - } else if((this.Obj = $("input[Title='" + colName + "']")).length === 1) { - this.Type = "C"; - // Multi-select: This will find the multi-select column control in English and most other languages sites where the Title looks like 'Column Name possible values' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title^='" + colName + " ']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Russian site (and perhaps others) where the Title looks like 'Выбранных значений: Column Name' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=': " + colName + "']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a German site (and perhaps others) where the Title looks like 'Mögliche Werte für "Column name".' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$='\"" + colName + "\".']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Italian site (and perhaps others) where the Title looks like "Valori possibili Column name" - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=' " + colName + "']")).length === 1) { - this.Type = "M"; - } else { - this.Type = null; - } - } // End of function DropdownCtl - - - // Returns the selected value(s) for a dropdown in an array. Expects a dropdown object as returned by the DropdownCtl function. - // If matchOnId is true, returns the ids rather than the text values for the selection options(s). - function getDropdownSelected(columnSelect, matchOnId) { - - var columnSelectSelected = []; - - switch(columnSelect.Type) { - case "S": - if(matchOnId) { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").text() || []); - } - break; - case "C": - if(matchOnId) { - columnSelectSelected.push($("input[id='"+ columnSelect.Obj.attr("optHid") + "']").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.attr("value") || []); - } - break; - case "M": - var columnSelections = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - $(columnSelections).find("option").each(function() { - columnSelectSelected.push($(this).html()); - }); - break; - default: - break; - } - return columnSelectSelected; - - } // End of function getDropdownSelected - - // Build an error message based on passed parameters - function errBox(func, param, msg) { - var errMsg = "Error in function
    " + func + "
    " + - "Parameter
    " + param + "
    " + - "Message
    " + msg + "

    " + - "Click to continue
    "; - modalBox(errMsg); - } // End of function errBox - - // Call this function to pop up a branded modal msgBox - function modalBox(msg) { - var boxCSS = "position:absolute;width:300px;height:150px;padding:10px;background-color:#000000;color:#ffffff;z-index:30;font-family:'Arial';font-size:12px;display:none;"; - $("#aspnetForm").parent().append("
    " + msg); - var height = $("#SPServices_msgBox").height(); - var width = $("#SPServices_msgBox").width(); - var leftVal = ($(window).width() / 2) - (width / 2) + "px"; - var topVal = ($(window).height() / 2) - (height / 2) - 100 + "px"; - $("#SPServices_msgBox").css({border:'5px #C02000 solid', left:leftVal, top:topVal}).show().fadeTo("slow", 0.75).click(function () { - $(this).fadeOut("3000", function () { - $(this).remove(); - }); - }); - } // End of function modalBox - - // Generate a unique id for a containing div using the function name and the column display name - function genContainerId(funcname, columnName) { - return funcname + "_" + $().SPServices.SPGetStaticFromDisplay({ - listName: $().SPServices.SPListNameFromUrl(), - columnDisplayName: columnName - }); - } // End of function genContainerId - - // Get the URL for a specified form for a list - function getListFormUrl(l, f) { - - var u; - $().SPServices({ - operation: "GetFormCollection", - async: false, - listName: l, - completefunc: function (xData, Status) { - u = $(xData.responseXML).find("Form[Type='" + f + "']").attr("Url"); - } - }); - return u; - - } // End of function getListFormUrl - - // Add the option values to the SOAPEnvelope.payload for the operation - // opt = options for the call - // paramArray = an array of option names to add to the payload - // "paramName" if the parameter name and the option name match - // ["paramName", "optionName"] if the parameter name and the option name are different (this handles early "wrappings" with inconsistent naming) - function addToPayload(opt, paramArray) { - - var i; - - for (i=0; i < paramArray.length; i++) { - // the parameter name and the option name match - if(typeof paramArray[i] === "string") { - SOAPEnvelope.payload += wrapNode(paramArray[i], opt[paramArray[i]]); - // the parameter name and the option name are different - } else if(paramArray[i].length === 2) { - SOAPEnvelope.payload += wrapNode(paramArray[i][0], opt[paramArray[i][1]]); - // something isn't right, so report it - } else { - errBox(opt.operation, "paramArray[" + i + "]: " + paramArray[i], "Invalid paramArray element passed to addToPayload()"); - } - } - } // End of function addToPayload - - // Finds the td which contains a form field in default forms using the comment which contains: - // - // as the "anchor" to find it. Necessary because SharePoint doesn't give all field types ids or specific classes. - function findFormField(columnName) { - var thisFormBody; - // There's no easy way to find one of these columns; we'll look for the comment with the columnName - var searchText = RegExp("FieldName=\"" + columnName.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&") + "\"", "gi"); - // Loop through all of the ms-formbody table cells - $("td.ms-formbody, td.ms-formbodysurvey").each(function() { - // Check for the right comment - if(searchText.test($(this).html())) { - thisFormBody = $(this); - // Found it, so we're done - return false; - } - }); - return thisFormBody; - } // End of function findFormField - - // The SiteData operations have the same names as other Web Service operations. To make them easy to call and unique, I'm using - // the SiteData prefix on their names. This function replaces that name with the right name in the SOAPEnvelope. - function siteDataFixSOAPEnvelope(SOAPEnvelope, siteDataOperation) { - var siteDataOp = siteDataOperation.substring(8); - SOAPEnvelope.opheader = SOAPEnvelope.opheader.replace(siteDataOperation, siteDataOp); - SOAPEnvelope.opfooter = SOAPEnvelope.opfooter.replace(siteDataOperation, siteDataOp); - return SOAPEnvelope; - } // End of function siteDataFixSOAPEnvelope - - // Wrap an XML node (n) around a value (v) - function wrapNode(n, v) { - var thisValue = typeof v !== "undefined" ? v : ""; - return "<" + n + ">" + thisValue + ""; - } - - // Generate a random number for sorting arrays randomly - function randOrd() { - return (Math.round(Math.random())-0.5); - } - - // If a string is a URL, format it as a link, else return the string as-is - function checkLink(s) { - return ((s.indexOf("http") === 0) || (s.indexOf(SLASH) === 0)) ? "" + s + "" : s; - } - - // Get the filename from the full URL - function fileName(s) { - return s.substring(s.lastIndexOf(SLASH)+1,s.length); - } - -/* Taken from http://dracoblue.net/dev/encodedecode-special-xml-characters-in-javascript/155/ */ - var xml_special_to_escaped_one_map = { - '&': '&', - '"': '"', - '<': '<', - '>': '>'}; - var escaped_one_to_xml_special_map = { - '&': '&', - '"': '"', - '<': '<', - '>': '>'}; - - function encodeXml(string) { - return string.replace(/([\&"<>])/g, function(str, item) { - return xml_special_to_escaped_one_map[item]; - }); - } - function decodeXml(string) { - return string.replace(/("|<|>|&)/g, - function(str, item) { - return escaped_one_to_xml_special_map[item]; - }); - } -/* Taken from http://dracoblue.net/dev/encodedecode-special-xml-characters-in-javascript/155/ */ - - // Escape column values - function escapeColumnValue(s) { - if(typeof s === "string") { - return s.replace(/&(?![a-zA-Z]{1,8};)/g, "&"); - } else { - return s; - } - } - - // Escape Url - function escapeUrl(u) { - return u.replace(/&/g,'%26'); - } - - // Split values like 1;#value into id and value - function SplitIndex(s) { - var spl = s.split(";#"); - this.id = spl[0]; - this.value = spl[1]; - } - - -})(jQuery); \ No newline at end of file diff --git a/jquery.SPServices-2013.01ALPHA4.js b/jquery.SPServices-2013.01ALPHA4.js deleted file mode 100644 index f083ad6..0000000 --- a/jquery.SPServices-2013.01ALPHA4.js +++ /dev/null @@ -1,4068 +0,0 @@ -/* - * SPServices - Work with SharePoint's Web Services using jQuery - * Version 0.7.3 - * @requires jQuery v1.5 or greater - jQuery 1.7+ recommended - * - * Copyright (c) 2009-2013 Sympraxis Consulting LLC - * Examples and docs at: - * http://spservices.codeplex.com - * Licensed under the MIT license: - * http://www.opensource.org/licenses/mit-license.php - */ -/* - * @description Work with SharePoint's Web Services using jQuery - * @type jQuery - * @name SPServices - * @category Plugins/SPServices - * @author Sympraxis Consulting LLC/marc.anderson@sympraxisconsulting.com - */ -/* jshint undef: true */ -/* global _spUserId, _spPageContextInfo, GipAddSelectedItems, GipRemoveSelectedItems, GipGetGroupData */ - -(function ($) { - - "use strict"; - - // Version info - var VERSION = "0.7.3"; // TODO: Update version - - // String constants - // General - var SLASH = "/"; - var TXTColumnNotFound = "Column not found on page"; - var SCHEMASharePoint = "http://schemas.microsoft.com/sharepoint"; - - // Caching - var promisesCache = {}; - - // Web Service names - var ALERTS = "Alerts"; - var AUTHENTICATION = "Authentication"; - var COPY = "Copy"; - var FORMS = "Forms"; - var LISTS = "Lists"; - var MEETINGS = "Meetings"; - var PEOPLE = "People"; - var PERMISSIONS = "Permissions"; - var PUBLISHEDLINKSSERVICE = "PublishedLinksService"; - var SEARCH = "Search"; - var SHAREPOINTDIAGNOSTICS = "SharePointDiagnostics"; - var SITEDATA = "SiteData"; - var SITES = "Sites"; - var SOCIALDATASERVICE = "SocialDataService"; - var SPELLCHECK = "SpellCheck"; - var TAXONOMYSERVICE = "TaxonomyClientService"; - var USERGROUP = "usergroup"; - var USERPROFILESERVICE = "UserProfileService"; - var VERSIONS = "Versions"; - var VIEWS = "Views"; - var WEBPARTPAGES = "WebPartPages"; - var WEBS = "Webs"; - var WORKFLOW = "Workflow"; - - // Global variables - var currentContext = new SPServicesContext(); // Variable to hold the current context as we figure it out - var i = 0; // Generic loop counter - var encodeOptionList = ["listName", "description"]; // Used to encode options which may contain special characters - - - // Array to store Web Service information - // WSops.OpName = [WebService, needs_SOAPAction]; - // OpName The name of the Web Service operation -> These names are unique - // WebService The name of the WebService this operation belongs to - // needs_SOAPAction Boolean indicating whether the operatio needs to have the SOAPAction passed in the setRequestHeaderfunction. - // true if the operation does a write, else false - - var WSops = []; - - WSops.GetAlerts = [ALERTS, false]; - WSops.DeleteAlerts = [ALERTS, true]; - - WSops.Mode = [AUTHENTICATION, false]; - WSops.Login = [AUTHENTICATION, false]; - - WSops.CopyIntoItems = [COPY, true]; - WSops.CopyIntoItemsLocal = [COPY, true]; - WSops.GetItem = [COPY, false]; - - WSops.GetForm = [FORMS, false]; - WSops.GetFormCollection = [FORMS, false]; - - WSops.AddAttachment = [LISTS, true]; - WSops.AddDiscussionBoardItem = [LISTS, true]; - WSops.AddList = [LISTS, true]; - WSops.AddListFromFeature = [LISTS, true]; - WSops.ApplyContentTypeToList = [LISTS, true]; - WSops.CheckInFile = [LISTS, true]; - WSops.CheckOutFile = [LISTS, true]; - WSops.CreateContentType = [LISTS, true]; - WSops.DeleteAttachment = [LISTS, true]; - WSops.DeleteContentType = [LISTS, true]; - WSops.DeleteContentTypeXmlDocument = [LISTS, true]; - WSops.DeleteList = [LISTS, true]; - WSops.GetAttachmentCollection = [LISTS, false]; - WSops.GetList = [LISTS, false]; - WSops.GetListAndView = [LISTS, false]; - WSops.GetListCollection = [LISTS, false]; - WSops.GetListContentType = [LISTS, false]; - WSops.GetListContentTypes = [LISTS, false]; - WSops.GetListItemChanges = [LISTS, false]; - WSops.GetListItemChangesSinceToken = [LISTS, false]; - WSops.GetListItems = [LISTS, false]; - WSops.GetVersionCollection = [LISTS, false]; - WSops.UndoCheckOut = [LISTS, true]; - WSops.UpdateContentType = [LISTS, true]; - WSops.UpdateContentTypesXmlDocument = [LISTS, true]; - WSops.UpdateContentTypeXmlDocument = [LISTS, true]; - WSops.UpdateList = [LISTS, true]; - WSops.UpdateListItems = [LISTS, true]; - - WSops.AddMeeting = [MEETINGS, true]; - WSops.CreateWorkspace = [MEETINGS, true]; - WSops.RemoveMeeting = [MEETINGS, true]; - WSops.SetWorkSpaceTitle = [MEETINGS, true]; - - WSops.ResolvePrincipals = [PEOPLE, false]; - WSops.SearchPrincipals = [PEOPLE, false]; - - WSops.AddPermission = [PERMISSIONS, true]; - WSops.AddPermissionCollection = [PERMISSIONS, true]; - WSops.GetPermissionCollection = [PERMISSIONS, true]; - WSops.RemovePermission = [PERMISSIONS, true]; - WSops.RemovePermissionCollection = [PERMISSIONS, true]; - WSops.UpdatePermission = [PERMISSIONS, true]; - - WSops.GetLinks = [PUBLISHEDLINKSSERVICE, true]; - - WSops.GetPortalSearchInfo = [SEARCH, false]; - WSops.GetQuerySuggestions = [SEARCH, false]; - WSops.GetSearchMetadata = [SEARCH, false]; - WSops.Query = [SEARCH, false]; - WSops.QueryEx = [SEARCH, false]; - WSops.Registration = [SEARCH, false]; - WSops.Status = [SEARCH, false]; - - WSops.SendClientScriptErrorReport = [SHAREPOINTDIAGNOSTICS,true]; - - WSops.GetAttachments = [SITEDATA, false]; - WSops.EnumerateFolder = [SITEDATA, false]; - WSops.SiteDataGetList = [SITEDATA, false]; - WSops.SiteDataGetListCollection = [SITEDATA, false]; - WSops.SiteDataGetSite = [SITEDATA, false]; - WSops.SiteDataGetSiteUrl = [SITEDATA, false]; - WSops.SiteDataGetWeb = [SITEDATA, false]; - - WSops.CreateWeb = [SITES, true]; - WSops.DeleteWeb = [SITES, false]; - WSops.GetSite = [SITES, false]; - WSops.GetSiteTemplates = [SITES, false]; - - WSops.AddComment = [SOCIALDATASERVICE, true]; - WSops.AddTag = [SOCIALDATASERVICE, true]; - WSops.AddTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.CountCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountTagsOfUser = [SOCIALDATASERVICE, false]; - WSops.DeleteComment = [SOCIALDATASERVICE, true]; - WSops.DeleteRating = [SOCIALDATASERVICE, true]; - WSops.DeleteTag = [SOCIALDATASERVICE, true]; - WSops.DeleteTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.DeleteTags = [SOCIALDATASERVICE, true]; - WSops.GetAllTagTerms = [SOCIALDATASERVICE, false]; - WSops.GetAllTagTermsForUrlFolder = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrls = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrlsByKeyword = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingAverageOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetSocialDataForFullReplication = [SOCIALDATASERVICE, false]; - WSops.GetTags = [SOCIALDATASERVICE, true]; - WSops.GetTagsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTerms = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOnUrl = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUserByKeyword = [SOCIALDATASERVICE, true]; - WSops.GetTagUrls = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsByKeyword = [SOCIALDATASERVICE, true]; - WSops.SetRating = [SOCIALDATASERVICE, true]; - WSops.UpdateComment = [SOCIALDATASERVICE, true]; - - WSops.SpellCheck = [SPELLCHECK, false]; - - // Taxonomy Service Calls - // Updated 2011.01.27 by Thomas McMillan - WSops.AddTerms = [TAXONOMYSERVICE, true]; - WSops.GetChildTermsInTerm = [TAXONOMYSERVICE, false]; - WSops.GetChildTermsInTermSet = [TAXONOMYSERVICE, false]; - WSops.GetKeywordTermsByGuids = [TAXONOMYSERVICE, false]; - WSops.GetTermsByLabel = [TAXONOMYSERVICE, false]; - WSops.GetTermSets = [TAXONOMYSERVICE, false]; - - WSops.AddGroup = [USERGROUP, true]; - WSops.AddGroupToRole = [USERGROUP, true]; - WSops.AddRole = [USERGROUP, true]; - WSops.AddRoleDef = [USERGROUP, true]; - WSops.AddUserCollectionToGroup = [USERGROUP, true]; - WSops.AddUserCollectionToRole = [USERGROUP, true]; - WSops.AddUserToGroup = [USERGROUP, true]; - WSops.AddUserToRole = [USERGROUP, true]; - WSops.GetAllUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupCollection = [USERGROUP, false]; - WSops.GetGroupCollectionFromRole = [USERGROUP, false]; - WSops.GetGroupCollectionFromSite = [USERGROUP, false]; - WSops.GetGroupCollectionFromUser = [USERGROUP, false]; - WSops.GetGroupCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupInfo = [USERGROUP, false]; - WSops.GetRoleCollection = [USERGROUP, false]; - WSops.GetRoleCollectionFromGroup = [USERGROUP, false]; - WSops.GetRoleCollectionFromUser = [USERGROUP, false]; - WSops.GetRoleCollectionFromWeb = [USERGROUP, false]; - WSops.GetRoleInfo = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForCurrentUser = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForSite = [USERGROUP, false]; - WSops.GetUserCollection = [USERGROUP, false]; - WSops.GetUserCollectionFromGroup = [USERGROUP, false]; - WSops.GetUserCollectionFromRole = [USERGROUP, false]; - WSops.GetUserCollectionFromSite = [USERGROUP, false]; - WSops.GetUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetUserInfo = [USERGROUP, false]; - WSops.GetUserLoginFromEmail = [USERGROUP, false]; - WSops.RemoveGroup = [USERGROUP, true]; - WSops.RemoveGroupFromRole = [USERGROUP, true]; - WSops.RemoveRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromGroup = [USERGROUP, true]; - WSops.RemoveUserCollectionFromRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromSite = [USERGROUP, true]; - WSops.RemoveUserFromGroup = [USERGROUP, true]; - WSops.RemoveUserFromRole = [USERGROUP, true]; - WSops.RemoveUserFromSite = [USERGROUP, true]; - WSops.RemoveUserFromWeb = [USERGROUP, true]; - WSops.UpdateGroupInfo = [USERGROUP, true]; - WSops.UpdateRoleDefInfo = [USERGROUP, true]; - WSops.UpdateRoleInfo = [USERGROUP, true]; - WSops.UpdateUserInfo = [USERGROUP, true]; - - WSops.AddColleague = [USERPROFILESERVICE, true]; - WSops.AddLink = [USERPROFILESERVICE, true]; - WSops.AddMembership = [USERPROFILESERVICE, true]; - WSops.AddPinnedLink = [USERPROFILESERVICE, true]; - WSops.CreateMemberGroup = [USERPROFILESERVICE, true]; - WSops.CreateUserProfileByAccountName = [USERPROFILESERVICE, true]; - WSops.GetCommonColleagues = [USERPROFILESERVICE, false]; - WSops.GetCommonManager = [USERPROFILESERVICE, false]; - WSops.GetCommonMemberships = [USERPROFILESERVICE, false]; - WSops.GetInCommon = [USERPROFILESERVICE, false]; - WSops.GetPropertyChoiceList = [USERPROFILESERVICE, false]; - WSops.GetUserColleagues = [USERPROFILESERVICE, false]; - WSops.GetUserLinks = [USERPROFILESERVICE, false]; - WSops.GetUserMemberships = [USERPROFILESERVICE, false]; - WSops.GetUserPinnedLinks = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByGuid = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByIndex = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByName = [USERPROFILESERVICE, false]; - WSops.GetUserProfileCount = [USERPROFILESERVICE, false]; - WSops.GetUserProfileSchema = [USERPROFILESERVICE, false]; - WSops.ModifyUserPropertyByAccountName = [USERPROFILESERVICE, true]; - WSops.RemoveAllColleagues = [USERPROFILESERVICE, true]; - WSops.RemoveAllLinks = [USERPROFILESERVICE, true]; - WSops.RemoveAllMemberships = [USERPROFILESERVICE, true]; - WSops.RemoveAllPinnedLinks = [USERPROFILESERVICE, true]; - WSops.RemoveColleague = [USERPROFILESERVICE, true]; - WSops.RemoveLink = [USERPROFILESERVICE, true]; - WSops.RemoveMembership = [USERPROFILESERVICE, true]; - WSops.RemovePinnedLink = [USERPROFILESERVICE, true]; - WSops.UpdateColleaguePrivacy = [USERPROFILESERVICE, true]; - WSops.UpdateLink = [USERPROFILESERVICE, true]; - WSops.UpdateMembershipPrivacy = [USERPROFILESERVICE, true]; - WSops.UpdatePinnedLink = [USERPROFILESERVICE, true]; - - WSops.DeleteAllVersions = [VERSIONS, true]; - WSops.DeleteVersion = [VERSIONS, true]; - WSops.GetVersions = [VERSIONS, false]; - WSops.RestoreVersion = [VERSIONS, true]; - - WSops.AddView = [VIEWS, true]; - WSops.DeleteView = [VIEWS, true]; - WSops.GetView = [VIEWS, false]; - WSops.GetViewHtml = [VIEWS, false]; - WSops.GetViewCollection = [VIEWS, false]; - WSops.UpdateView = [VIEWS, true]; - WSops.UpdateViewHtml = [VIEWS, true]; - - WSops.AddWebPart = [WEBPARTPAGES, true]; - WSops.AddWebPartToZone = [WEBPARTPAGES, true]; - WSops.GetWebPart2 = [WEBPARTPAGES, false]; - WSops.GetWebPartPage = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties2 = [WEBPARTPAGES, false]; - - WSops.CreateContentType = [WEBS, true]; - WSops.GetColumns = [WEBS, false]; - WSops.GetContentType = [WEBS, false]; - WSops.GetContentTypes = [WEBS, false]; - WSops.GetCustomizedPageStatus = [WEBS, false]; - WSops.GetListTemplates = [WEBS, false]; - WSops.GetObjectIdFromUrl = [WEBS, false]; // 2010 - WSops.GetWeb = [WEBS, false]; - WSops.GetWebCollection = [WEBS, false]; - WSops.GetAllSubWebCollection = [WEBS, false]; - WSops.UpdateColumns = [WEBS, true]; - WSops.UpdateContentType = [WEBS, true]; - WSops.WebUrlFromPageUrl = [WEBS, false]; - - WSops.AlterToDo = [WORKFLOW, true]; - WSops.GetTemplatesForItem = [WORKFLOW, false]; - WSops.GetToDosForItem = [WORKFLOW, false]; - WSops.GetWorkflowDataForItem = [WORKFLOW, false]; - WSops.GetWorkflowTaskData = [WORKFLOW, false]; - WSops.StartWorkflow = [WORKFLOW, true]; - - // Set up SOAP envelope - var SOAPEnvelope = {}; - SOAPEnvelope.header = ""; - SOAPEnvelope.footer = ""; - SOAPEnvelope.payload = ""; - var SOAPAction; - - - // Main function, which calls SharePoint's Web Services directly. - $.fn.SPServices = function(options) { - - // If there are no options passed in, use the defaults. Extend replaces each default with the passed option. - var opt = $.extend({}, $.fn.SPServices.defaults, options); - - // Encode options which may contain special character, esp. ampersand - for(var i=0; i < encodeOptionList.length; i++) { - if(typeof opt[encodeOptionList[i]] === "string") { - opt[encodeOptionList[i]] = encodeXml(opt[encodeOptionList[i]]); - } - } - - // Put together operation header and SOAPAction for the SOAP call based on which Web Service we're calling - SOAPEnvelope.opheader = "<" + opt.operation + " "; - switch(WSops[opt.operation][0]) { - case ALERTS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/2002/1/alerts/' >"; - SOAPAction = SCHEMASharePoint + "/soap/2002/1/alerts/"; - break; - case MEETINGS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/meetings/' >"; - SOAPAction = SCHEMASharePoint + "/soap/meetings/"; - break; - case PERMISSIONS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case PUBLISHEDLINKSSERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/"; - break; - case SEARCH: - SOAPEnvelope.opheader += "xmlns='urn:Microsoft.Search' >"; - SOAPAction = "urn:Microsoft.Search/"; - break; - case SHAREPOINTDIAGNOSTICS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/diagnostics/' >"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/diagnostics/"; - break; - case SOCIALDATASERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/SocialDataService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/SocialDataService/"; - break; - case SPELLCHECK: - SOAPEnvelope.opheader += "xmlns='http://schemas.microsoft.com/sharepoint/publishing/spelling/'"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/publishing/spelling/SpellCheck"; - break; - case TAXONOMYSERVICE: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/taxonomy/soap/' >"; - SOAPAction = SCHEMASharePoint + "/taxonomy/soap/"; - break; - case USERGROUP: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case USERPROFILESERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/UserProfileService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/UserProfileService/"; - break; - case WEBPARTPAGES: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/sharepoint/webpartpages' >"; - SOAPAction = "http://microsoft.com/sharepoint/webpartpages/"; - break; - case WORKFLOW: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/workflow/' >"; - SOAPAction = SCHEMASharePoint + "/soap/workflow/"; - break; - default: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/'>"; - SOAPAction = SCHEMASharePoint + "/soap/"; - break; - } - - // Add the operation to the SOAPAction and opfooter - SOAPAction += opt.operation; - SOAPEnvelope.opfooter = ""; - - // Build the URL for the Ajax call based on which operation we're calling - // If the webURL has been provided, then use it, else use the current site - var ajaxURL = "_vti_bin/" + WSops[opt.operation][0] + ".asmx"; - if(opt.webURL.charAt(opt.webURL.length - 1) === SLASH) { - ajaxURL = opt.webURL + ajaxURL; - } else if(opt.webURL.length > 0) { - ajaxURL = opt.webURL + SLASH + ajaxURL; - } else { - ajaxURL = $().SPServices.SPGetCurrentSite() + SLASH + ajaxURL; - } - - SOAPEnvelope.payload = ""; - // Each operation requires a different set of values. This switch statement sets them up in the SOAPEnvelope.payload. - switch(opt.operation) { - // ALERT OPERATIONS - case "GetAlerts": - break; - case "DeleteAlerts": - SOAPEnvelope.payload += ""; - for (i=0; i < opt.IDs.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.IDs[i]); - } - SOAPEnvelope.payload += ""; - break; - - // AUTHENTICATION OPERATIONS - case "Mode": - break; - case "Login": - addToPayload(opt, ["username", "password"]); - break; - - // COPY OPERATIONS - case "CopyIntoItems": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - addToPayload(opt, ["Fields", "Stream", "Results"]); - break; - case "CopyIntoItemsLocal": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - break; - case "GetItem": - addToPayload(opt, ["Url", "Fields", "Stream"]); - break; - - // FORM OPERATIONS - case "GetForm": - addToPayload(opt, ["listName", "formUrl"]); - break; - case "GetFormCollection": - addToPayload(opt, ["listName"]); - break; - - // LIST OPERATIONS - case "AddAttachment": - addToPayload(opt, ["listName", "listItemID", "fileName", "attachment"]); - break; - case "AddDiscussionBoardItem": - addToPayload(opt, ["listName", "message"]); - break; - case "AddList": - addToPayload(opt, ["listName", "description", "templateID"]); - break; - case "AddListFromFeature": - addToPayload(opt, ["listName", "description", "featureID", "templateID"]); - break; - case "ApplyContentTypeToList": - addToPayload(opt, ["webUrl", "contentTypeId", "listName"]); - break; - case "CheckInFile": - addToPayload(opt, ["pageUrl", "comment", "CheckinType"]); - break; - case "CheckOutFile": - addToPayload(opt, ["pageUrl", "checkoutToLocal", "lastmodified"]); - break; - case "CreateContentType": - addToPayload(opt, ["listName", "displayName", "parentType", "fields", "contentTypeProperties", "addToView"]); - break; - case "DeleteAttachment": - addToPayload(opt, ["listName", "listItemID", "url"]); - break; - case "DeleteContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "DeleteContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "documentUri"]); - break; - case "DeleteList": - addToPayload(opt, ["listName"]); - break; - case "GetAttachmentCollection": - addToPayload(opt, ["listName", ["listItemID", "ID"]]); - break; - case "GetList": - addToPayload(opt, ["listName"]); - break; - case "GetListAndView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetListCollection": - break; - case "GetListContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "GetListContentTypes": - addToPayload(opt, ["listName"]); - break; - case "GetListItems": - addToPayload(opt, ["listName", "viewName", ["query", "CAMLQuery"], ["viewFields", "CAMLViewFields"], ["rowLimit", "CAMLRowLimit"], ["queryOptions", "CAMLQueryOptions"]]); - break; - case "GetListItemChanges": - addToPayload(opt, ["listName", "viewFields", "since", "contains"]); - break; - case "GetListItemChangesSinceToken": - addToPayload(opt, ["listName", "viewName", "query", "viewFields", "rowLimit", "queryOptions", "changeToken", "contains"]); - break; - case "GetVersionCollection": - addToPayload(opt, ["strlistID", "strlistItemID", "strFieldName"]); - break; - case "UndoCheckOut": - addToPayload(opt, ["pageUrl"]); - break; - case "UpdateContentType": - addToPayload(opt, ["listName", "contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields", "addToView"]); - break; - case "UpdateContentTypesXmlDocument": - addToPayload(opt, ["listName", "newDocument"]); - break; - case "UpdateContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "newDocument"]); - break; - case "UpdateList": - addToPayload(opt, ["listName", "listProperties", "newFields", "updateFields", "deleteFields", "listVersion"]); - break; - case "UpdateListItems": - addToPayload(opt, ["listName"]); - if(typeof opt.updates !== "undefined" && opt.updates.length > 0) { - addToPayload(opt, ["updates"]); - } else { - SOAPEnvelope.payload += ""; - for (i=0; i < opt.valuepairs.length; i++) { - SOAPEnvelope.payload += "" + escapeColumnValue(opt.valuepairs[i][1]) + ""; - } - if(opt.batchCmd !== "New") { - SOAPEnvelope.payload += "" + opt.ID + ""; - } - SOAPEnvelope.payload += ""; - } - break; - - // MEETINGS OPERATIONS - case "AddMeeting": - addToPayload(opt, ["organizerEmail", "uid", "sequence", "utcDateStamp", "title", "location", "utcDateStart", "utcDateEnd", "nonGregorian"]); - break; - case "CreateWorkspace": - addToPayload(opt, ["title", "templateName", "lcid", "timeZoneInformation"]); - break; - case "RemoveMeeting": - addToPayload(opt, ["recurrenceId", "uid", "sequence", "utcDateStamp", "cancelMeeting"]); - break; - case "SetWorkspaceTitle": - addToPayload(opt, ["title"]); - break; - - // PEOPLE OPERATIONS - case "ResolvePrincipals": - addToPayload(opt, ["principalKeys", "principalType", "addToUserInfoList"]); - break; - case "SearchPrincipals": - addToPayload(opt, ["searchText", "maxResults", "principalType"]); - break; - - // PERMISSION OPERATIONS - case "AddPermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - case "AddPermissionCollection": - addToPayload(opt, ["objectName", "objectType", "permissionsInfoXml"]); - break; - case "GetPermissionCollection": - addToPayload(opt, ["objectName", "objectType"]); - break; - case "RemovePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType"]); - break; - case "RemovePermissionCollection": - addToPayload(opt, ["objectName", "objectType", "memberIdsXml"]); - break; - case "UpdatePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - - // PUBLISHEDLINKSSERVICE OPERATIONS - case "GetLinks": - break; - - // SEARCH OPERATIONS - case "GetPortalSearchInfo": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "GetQuerySuggestions": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "GetSearchMetadata": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "Query": - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "QueryEx": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "Registration": - SOAPEnvelope.payload += wrapNode("registrationXml", encodeXml(opt.registrationXml)); - break; - case "Status": - break; - - // SHAREPOINTDIAGNOSTICS OPERATIONS - case "SendClientScriptErrorReport": - addToPayload(opt, ["message", "file", "line", "client", "stack", "team", "originalFile"]); - break; - - // SITEDATA OPERATIONS - case "EnumerateFolder": - addToPayload(opt, ["strFolderUrl"]); - break; - case "GetAttachments": - addToPayload(opt, ["strListName", "strItemId"]); - break; - case "SiteDataGetList": - addToPayload(opt, ["strListName"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetListCollection": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSite": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSiteUrl": - addToPayload(opt, ["Url"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetWeb": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - - // SITES OPERATIONS - case "CreateWeb": - addToPayload(opt, ["url", "title", "description", "templateName", "language", "languageSpecified", - "locale", "localeSpecified", "collationLocale", "collationLocaleSpecified", "uniquePermissions", - "uniquePermissionsSpecified", "anonymous", "anonymousSpecified", "presence", "presenceSpecified"]); - break; - case "DeleteWeb": - addToPayload(opt, ["url"]); - break; - case "GetSite": - addToPayload(opt, ["SiteUrl"]); - break; - case "GetSiteTemplates": - addToPayload(opt, ["LCID", "TemplateList"]); - break; - - // SOCIALDATASERVICE OPERATIONS - case "AddComment": - addToPayload(opt, ["url", "comment", "isHighPriority", "title"]); - break; - case "AddTag": - addToPayload(opt, ["url", "termID", "title", "isPrivate"]); - break; - case "AddTagByKeyword": - addToPayload(opt, ["url", "keyword", "title", "isPrivate"]); - break; - case "CountCommentsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "CountCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "CountCommentsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountTagsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "DeleteComment": - addToPayload(opt, ["url", "lastModifiedTime"]); - break; - case "DeleteRating": - addToPayload(opt, ["url"]); - break; - case "DeleteTag": - addToPayload(opt, ["url", "termID"]); - break; - case "DeleteTagByKeyword": - addToPayload(opt, ["url", "keyword"]); - break; - case "DeleteTags": - addToPayload(opt, ["url"]); - break; - case "GetAllTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetAllTagTermsForUrlFolder": - addToPayload(opt, ["urlFolder", "maximumItemsToReturn"]); - break; - case "GetAllTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetAllTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetCommentsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetCommentsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn", "startIndex"]); - if(typeof opt.excludeItemsTime !== "undefined" && opt.excludeItemsTime.length > 0) { - SOAPEnvelope.payload += wrapNode("excludeItemsTime", opt.excludeItemsTime); - } - break; - case "GetRatingAverageOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetRatingOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "GetRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetSocialDataForFullReplication": - addToPayload(opt, ["userAccountName"]); - break; - case "GetTags": - addToPayload(opt, ["url"]); - break; - case "GetTagsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetTagTermsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn"]); - break; - case "GetTagTermsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn"]); - break; - case "GetTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetTagUrlsOfUser": - addToPayload(opt, ["termID", "userAccountName"]); - break; - case "GetTagUrlsOfUserByKeyword": - addToPayload(opt, ["keyword", "userAccountName"]); - break; - case "SetRating": - addToPayload(opt, ["url", "rating", "title", "analysisDataEntry"]); - break; - case "UpdateComment": - addToPayload(opt, ["url", "lastModifiedTime", "comment", "isHighPriority"]); - break; - - // SPELLCHECK OPERATIONS - case "SpellCheck": - addToPayload(opt, ["chunksToSpell", "declaredLanguage", "useLad"]); - break; - - // TAXONOMY OPERATIONS - case "AddTerms": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "newTerms"]); - break; - case "GetChildTermsInTerm": - addToPayload(opt, ["sspId", "lcid", "termId", "termSetId"]); - break; - case "GetChildTermsInTermSet": - addToPayload(opt, ["sspId", "lcid", "termSetId"]); - break; - case "GetKeywordTermsByGuids": - addToPayload(opt, ["termIds", "lcid"]); - break; - case "GetTermsByLabel": - addToPayload(opt, ["label", "lcid", "matchOption", "resultCollectionSize", "termIds", "addIfNotFound"]); - break; - case "GetTermSets": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "clientTimeStamps", "clientVersions"]); - break; - - // USERS AND GROUPS OPERATIONS - case "AddGroup": - addToPayload(opt, ["groupName", "ownerIdentifier", "ownerType", "defaultUserLoginName", "description"]); - break; - case "AddGroupToRole": - addToPayload(opt, ["groupName", "roleName"]); - break; - case "AddRole": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddRoleDef": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddUserCollectionToGroup": - addToPayload(opt, ["groupName", "usersInfoXml"]); - break; - case "AddUserCollectionToRole": - addToPayload(opt, ["roleName", "usersInfoXml"]); - break; - case "AddUserToGroup": - addToPayload(opt, ["groupName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "AddUserToRole": - addToPayload(opt, ["roleName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "GetAllUserCollectionFromWeb": - break; - case "GetGroupCollection": - addToPayload(opt, ["groupNamesXml"]); - break; - case "GetGroupCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetGroupCollectionFromSite": - break; - case "GetGroupCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetGroupCollectionFromWeb": - break; - case "GetGroupInfo": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollection": - addToPayload(opt, ["roleNamesXml"]); - break; - case "GetRoleCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetRoleCollectionFromWeb": - break; - case "GetRoleInfo": - addToPayload(opt, ["roleName"]); - break; - case "GetRolesAndPermissionsForCurrentUser": - break; - case "GetRolesAndPermissionsForSite": - break; - case "GetUserCollection": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "GetUserCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetUserCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetUserCollectionFromSite": - break; - case "GetUserCollectionFromWeb": - break; - case "GetUserInfo": - addToPayload(opt, ["userLoginName"]); - break; - case "GetUserLoginFromEmail": - addToPayload(opt, ["emailXml"]); - break; - case "RemoveGroup": - addToPayload(opt, ["groupName"]); - break; - case "RemoveGroupFromRole": - addToPayload(opt, ["roleName", "groupName"]); - break; - case "RemoveRole": - addToPayload(opt, ["roleName"]); - break; - case "RemoveUserCollectionFromGroup": - addToPayload(opt, ["groupName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromRole": - addToPayload(opt, ["roleName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromSite": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "RemoveUserFromGroup": - addToPayload(opt, ["groupName", "userLoginName"]); - break; - case "RemoveUserFromRole": - addToPayload(opt, ["roleName", "userLoginName"]); - break; - case "RemoveUserFromSite": - addToPayload(opt, ["userLoginName"]); - break; - case "RemoveUserFromWeb": - addToPayload(opt, ["userLoginName"]); - break; - case "UpdateGroupInfo": - addToPayload(opt, ["oldGroupName", "groupName", "ownerIdentifier", "ownerType", "description"]); - break; - case "UpdateRoleDefInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateRoleInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateUserInfo": - addToPayload(opt, ["userLoginName", "userName", "userEmail", "userNotes"]); - break; - - // USERPROFILESERVICE OPERATIONS - case "AddColleague": - addToPayload(opt, ["accountName", "colleagueAccountName", "group", "privacy", "isInWorkGroup"]); - break; - case "AddLink": - addToPayload(opt, ["accountName", "name", "url", "group", "privacy"]); - break; - case "AddMembership": - addToPayload(opt, ["accountName", "membershipInfo", "group", "privacy"]); - break; - case "AddPinnedLink": - addToPayload(opt, ["accountName", "name", "url"]); - break; - case "CreateMemberGroup": - addToPayload(opt, ["membershipInfo"]); - break; - case "CreateUserProfileByAccountName": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonManager": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetInCommon": - addToPayload(opt, ["accountName"]); - break; - case "GetPropertyChoiceList": - addToPayload(opt, ["propertyName"]); - break; - case "GetUserColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetUserLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetUserPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserProfileByGuid": - addToPayload(opt, ["guid"]); - break; - case "GetUserProfileByIndex": - addToPayload(opt, ["index"]); - break; - case "GetUserProfileByName": - // Note that this operation is inconsistent with the others, using AccountName rather than accountName - if(typeof opt.accountName !== "undefined" && opt.accountName.length > 0) { - addToPayload(opt, [["AccountName", "accountName"]]); - } else { - addToPayload(opt, ["AccountName"]); - } - break; - case "GetUserProfileCount": - break; - case "GetUserProfileSchema": - break; - case "ModifyUserPropertyByAccountName": - addToPayload(opt, ["accountName", "newData"]); - break; - case "RemoveAllColleagues": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllMemberships": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveColleague": - addToPayload(opt, ["accountName", "colleagueAccountName"]); - break; - case "RemoveLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "RemoveMembership": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference"]); - break; - case "RemovePinnedLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "UpdateColleaguePrivacy": - addToPayload(opt, ["accountName", "colleagueAccountName", "newPrivacy"]); - break; - case "UpdateLink": - addToPayload(opt, ["accountName", "data"]); - break; - case "UpdateMembershipPrivacy": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference", "newPrivacy"]); - break; - case "UpdatePinnedLink ": - addToPayload(opt, ["accountName", "data"]); - break; - - // VERSIONS OPERATIONS - case "DeleteAllVersions": - addToPayload(opt, ["fileName"]); - break; - case "DeleteVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - case "GetVersions": - addToPayload(opt, ["fileName"]); - break; - case "RestoreVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - - // VIEW OPERATIONS - case "AddView": - addToPayload(opt, ["listName", "viewName", "viewFields", "query", "rowLimit", "rowLimit", "type", "makeViewDefault"]); - break; - case "DeleteView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetViewCollection": - addToPayload(opt, ["listName"]); - break; - case "GetViewHtml": - addToPayload(opt, ["listName", "viewName"]); - break; - case "UpdateView": - addToPayload(opt, ["listName", "viewName", "viewProperties", "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - case "UpdateViewHtml": - addToPayload(opt, ["listName", "viewName", "viewProperties", "toolbar", "viewHeader", "viewBody", "viewFooter", "viewEmpty", "rowLimitExceeded", - "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - - // WEBPARTPAGES OPERATIONS - case "AddWebPart": - addToPayload(opt, ["pageUrl", "webPartXml", "storage"]); - break; - case "AddWebPartToZone": - addToPayload(opt, ["pageUrl", "webPartXml", "storage", "zoneId", "zoneIndex"]); - break; - case "GetWebPart2": - addToPayload(opt, ["pageUrl", "storageKey", "storage", "behavior"]); - break; - case "GetWebPartPage": - addToPayload(opt, ["documentName", "behavior"]); - break; - case "GetWebPartProperties": - addToPayload(opt, ["pageUrl", "storage"]); - break; - case "GetWebPartProperties2": - addToPayload(opt, ["pageUrl", "storage", "behavior"]); - break; - - // WEBS OPERATIONS - case "Webs.CreateContentType": - addToPayload(opt, ["displayName", "parentType", "newFields", "contentTypeProperties"]); - break; - case "GetColumns": - addToPayload(opt, ["webUrl"]); - break; - case "GetContentType": - addToPayload(opt, ["contentTypeId"]); - break; - case "GetContentTypes": - break; - case "GetCustomizedPageStatus": - addToPayload(opt, ["fileUrl"]); - break; - case "GetListTemplates": - break; - case "GetObjectIdFromUrl": - addToPayload(opt, ["objectUrl"]); - break; - case "GetWeb": - addToPayload(opt, [["webUrl", "webURL"]]); - break; - case "GetWebCollection": - break; - case "GetAllSubWebCollection": - break; - case "UpdateColumns": - addToPayload(opt, ["newFields", "updateFields", "deleteFields"]); - break; - case "Webs.UpdateContentType": - addToPayload(opt, ["contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields"]); - break; - case "WebUrlFromPageUrl": - addToPayload(opt, [["pageUrl", "pageURL"]]); - break; - - // WORKFLOW OPERATIONS - case "AlterToDo": - addToPayload(opt, ["item", "todoId", "todoListId", "taskData"]); - break; - case "GetTemplatesForItem": - addToPayload(opt, ["item"]); - break; - case "GetToDosForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowDataForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowTaskData": - addToPayload(opt, ["item", "listId", "taskId"]); - break; - case "StartWorkflow": - addToPayload(opt, ["item", "templateId", "workflowParameters"]); - break; - - default: - break; - } - - // Glue together the pieces of the SOAP message - var msg = SOAPEnvelope.header + SOAPEnvelope.opheader + SOAPEnvelope.payload + SOAPEnvelope.opfooter + SOAPEnvelope.footer; - - // Check to see if we've already cached the results - var cachedXML; - if(opt.cacheXML) { - cachedXML = promisesCache[msg]; - } - - if(typeof cachedXML === "undefined") { - - // Finally, make the Ajax call - var spservicesPromise = $.ajax({ - // The relative URL for the AJAX call - url: ajaxURL, - // By default, the AJAX calls are asynchronous. You can specify false to require a synchronous call. - async: opt.async, - // Before sending the msg, need to send the request header - beforeSend: function (xhr) { - // If we need to pass the SOAPAction, do so - if(WSops[opt.operation][1]) { - xhr.setRequestHeader("SOAPAction", SOAPAction); - } - }, - // Always a POST - type: "POST", - // Here is the SOAP request we've built above - data: msg, - // We're getting XML; tell jQuery so that it doesn't need to do a best guess - dataType: "xml", - // and this is its content type - contentType: "text/xml;charset='utf-8'", - complete: function(xData, Status) { - // When the call is complete, call the completefunc if there is one - if($.isFunction(opt.completefunc)) { - opt.completefunc(xData, Status); - - } - } - }); - - spservicesPromise.then( - function() { - // Cache the promise if requested - if(opt.cacheXML) { - promisesCache[msg] = spservicesPromise; - } - }, - function() { - // TODO: Allow for fail function - } - ); - - // Return the promise - return spservicesPromise; - - } else { - // Call the completefunc if there is one - if($.isFunction(opt.completefunc)) { - opt.completefunc(cachedXML, null); - } - // Return the cached promise - return cachedXML; - } - - }; // End $.fn.SPServices - - // Defaults added as a function in our library means that the caller can override the defaults - // for their session by calling this function. Each operation requires a different set of options; - // we allow for all in a standardized way. - $.fn.SPServices.defaults = { - - cacheXML: false, // If true, we'll cache the XML results with jQuery's .data() function - operation: "", // The Web Service operation - webURL: "", // URL of the target Web - makeViewDefault: false, // true to make the view the default view for the list - - // For operations requiring CAML, these options will override any abstractions - CAMLViewName: "", // View name in CAML format. - CAMLQuery: "", // Query in CAML format - CAMLViewFields: "", // View fields in CAML format - CAMLRowLimit: 0, // Row limit as a string representation of an integer - CAMLQueryOptions: "", // Query options in CAML format - - // Abstractions for CAML syntax - batchCmd: "Update", // Method Cmd for UpdateListItems - valuepairs: [], // Fieldname / Fieldvalue pairs for UpdateListItems - - // As of v0.7.1, removed all options which were assigned an empty string ("") - DestinationUrls: [], // Array of destination URLs for copy operations - behavior: "Version3", // An SPWebServiceBehavior indicating whether the client supports Windows SharePoint Services 2.0 or Windows SharePoint Services 3.0: {Version2 | Version3 } - storage: "Shared", // A Storage value indicating how the Web Part is stored: {None | Personal | Shared} - objectType: "List", // objectType for operations which require it - cancelMeeting: true, // true to delete a meeting;false to remove its association with a Meeting Workspace site - nonGregorian: false, // true if the calendar is set to a format other than Gregorian;otherwise, false. - fClaim: false, // Specifies if the action is a claim or a release. Specifies true for a claim and false for a release. - recurrenceId: 0, // The recurrence ID for the meeting that needs its association removed. This parameter can be set to 0 for single-instance meetings. - sequence: 0, // An integer that is used to determine the ordering of updates in case they arrive out of sequence. Updates with a lower-than-current sequence are discarded. If the sequence is equal to the current sequence, the latest update are applied. - maximumItemsToReturn: 0, // SocialDataService maximumItemsToReturn - startIndex: 0, // SocialDataService startIndex - isHighPriority: false, // SocialDataService isHighPriority - isPrivate: false, // SocialDataService isPrivate - rating: 1, // SocialDataService rating - maxResults: 10, // Unless otherwise specified, the maximum number of principals that can be returned from a provider is 10. - principalType: "User", // Specifies user scope and other information: [None | User | DistributionList | SecurityGroup | SharePointGroup | All] - - async: true, // Allow the user to force async - completefunc: null // Function to call on completion - - }; // End $.fn.SPServices.defaults - - // Function to determine the current Web's URL. We need this for successful Ajax calls. - // The function is also available as a public function. - $.fn.SPServices.SPGetCurrentSite = function() { - - // We've already determined the current site... - if(currentContext.thisSite.length > 0) { - return currentContext.thisSite; - } - - // If we still don't know the current site, we call WebUrlFromPageUrlResult. - var msg = SOAPEnvelope.header + - "" + - ((location.href.indexOf("?") > 0) ? location.href.substr(0, location.href.indexOf("?")) : location.href) + - "" + - SOAPEnvelope.footer; - $.ajax({ - async: false, // Need this to be synchronous so we're assured of a valid value - url: "/_vti_bin/Webs.asmx", - type: "POST", - data: msg, - dataType: "xml", - contentType: "text/xml;charset=\"utf-8\"", - complete: function (xData, Status) { - currentContext.thisSite = $(xData.responseXML).find("WebUrlFromPageUrlResult").text(); - } - }); - - return currentContext.thisSite; // Return the URL - - }; // End $.fn.SPServices.SPGetCurrentSite - - // Function to set up cascading dropdowns on a SharePoint form - // (Newform.aspx, EditForm.aspx, or any other customized form.) - $.fn.SPServices.SPCascadeDropdowns = function(options) { - - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationships list - relationshipList: "", // The name of the list which contains the parent/child relationships - relationshipListParentColumn: "", // The internal name of the parent column in the relationship list - relationshipListChildColumn: "", // The internal name of the child column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListChildColumn - parentColumn: "", // The display name of the parent column in the form - childColumn: "", // The display name of the child column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relationshipList - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of childColumn. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - simpleChild: false, // [Optional] If set to true and childColumn is a complex dropdown, convert it to a simple dropdown - selectSingleOption: false, // [Optional] If set to true and there is only a single child option, select it - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - - var thisParentSetUp = false; - var thisFunction = "SPServices.SPCascadeDropdowns"; - - // Find the parent column's select (dropdown) - var parentSelect = new DropdownCtl(opt.parentColumn); - if(parentSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "parentColumn: " + opt.parentColumn , TXTColumnNotFound);return;} - - // Find the child column's select (dropdown) - var childSelect = new DropdownCtl(opt.childColumn); - if(childSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "childColumn: " + opt.childColumn, TXTColumnNotFound);return;} - - // If requested and the childColumn is a complex dropdown, convert to a simple dropdown - if(opt.simpleChild === true && childSelect.Type === "C") { - $().SPServices.SPComplexToSimpleDropdown({ - columnName: opt.childColumn - }); - // Set the childSelect to reference the new simple dropdown - childSelect = new DropdownCtl(opt.childColumn); - } - - var childColumnRequired, childColumnStatic; - - // Get information about the childColumn from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.childColumn + "']").each(function() { - // Determine whether childColumn is Required - childColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - childColumnStatic = $(this).attr("StaticName"); - // Stop looking; we're done - return false; - }); - }); - } - }); - - // Save data about each child column on the parent - var childColumn = {opt: opt, childSelect: childSelect, childColumnStatic: childColumnStatic, childColumnRequired: childColumnRequired}; - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - - // If this is the first child for this parent, then create the data object to hold the settings - if(typeof childColumns === "undefined") { - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", [childColumn]); - // If we already have a data object for this parent, then add the setting for this child to it - } else { - childColumns.push(childColumn); - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", childColumns); - thisParentSetUp = true; - } - - // We only need to bind to the event(s) if we haven't already done so - if(!thisParentSetUp) { - switch(parentSelect.Type) { - // Plain old select - case "S": - parentSelect.Obj.bind("change", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='"+ parentSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Multi-select hybrid - case "M": - // Handle the dblclick on the candidate select - parentSelect.Obj.bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle the dblclick on the selected values - parentSelect.Obj.closest("span").find("select[id$='SelectResult']").bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle a button click - parentSelect.Obj.closest("span").find("button").each(function() { - $(this).bind("click", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - }); - break; - default: - break; - } - } - // Fire the change to set the initially allowable values - cascadeDropdown(opt.parentColumn, parentSelect); - - }; // End $.fn.SPServices.SPCascadeDropdowns - - function cascadeDropdown(parentColumn, parentSelect) { - var choices = ""; - var parentSelectSelected; - var childSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var numChildOptions; - var firstChildOptionId; - var firstChildOptionValue; - - // Filter each child column - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - $(childColumns).each(function() { - - // Break out the data objects for this child column - var opt = this.opt; - var childSelect = this.childSelect; - var childColumnStatic = this.childColumnStatic; - var childColumnRequired = this.childColumnRequired; - var currentSelection; - - // Get the parent column selection(s) - parentSelectSelected = getDropdownSelected(parentSelect, opt.matchOnId); - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C" or "M", as there are multiple propertychanges - // which don't require any action. The attribute will be unique per child column in case there are - // multiple children for a given parent. - var allParentSelections = parentSelectSelected.join(";#"); - if(parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic) === allParentSelections) { - return; - } - parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic, allParentSelections); - - // Get the current child column selection(s) - childSelectSelected = getDropdownSelected(childSelect, true); - - // Find the important bits of the multi-select - if(childSelect.Type === "M") { - MultiLookupPickerdata = childSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[childSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - currentSelection = childSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - } - - // When the parent column's selected option changes, get the matching items from the relationship list - // Get the list items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListChildColumn; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - // Build up the criteria for inclusion - if(parentSelectSelected.length === 0) { - // Handle the case where no values are selected in multi-selects - camlQuery += ""; - } else if(parentSelectSelected.length === 1) { - // Only one value is selected - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[0]) + ""; - } else { - var compound = (parentSelectSelected.length > 2) ? true : false; - for(i=0; i < (parentSelectSelected.length - 1); i++) { - camlQuery += ""; - } - for(i=0; i < parentSelectSelected.length; i++) { - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[i]) + ""; - if(i>0 && (i < (parentSelectSelected.length - 1)) && compound) { - camlQuery += ""; - } - } - camlQuery += ""; - } - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - - // Make sure we don't get any items which don't have the child value - camlQuery += ""; - - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the child column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the currently selected parent column's value - CAMLQuery: camlQuery, - // Only get the parent and child columns - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: "FALSE", - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var thisFunction = "SPServices.SPCascadeDropdowns"; - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListParentColumn: " + opt.relationshipListParentColumn + " or " + - "relationshipListChildColumn: " + opt.relationshipListChildColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(childSelect.Type) { - case "S": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!childColumnRequired && (opt.promptText.length > 0)) { - childSelect.Obj.append(""); - } else if(!childColumnRequired){ - childSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = childColumnRequired ? "" : opt.noneText + "|0"; - childSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - // Get the count of items returned and save it so that we can select if it's a single option - // The item count is stored thus: - numChildOptions = parseFloat($(xData.responseXML).SPFilterNode("rs:data").attr("ItemCount")); - - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOption = {}; - - // If relationshipListChildColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListChildColumn); - - if(typeof thisValue !== "undefined" && thisValue.indexOf(";#") > 0) { - thisOption = new SplitIndex(thisValue); - } else { - thisOption.id = $(this).attr("ows_ID"); - thisOption.value = thisValue; - } - - // If the relationshipListChildColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOption.id should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOption.id)) { - thisOption.id = $(this).attr("ows_ID"); - } - - // Save the id and value for the first child option in case we need to select it (selectSingleOption option is true) - firstChildOptionId = thisOption.id; - firstChildOptionValue = thisOption.value; - - switch(childSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === childSelectSelected[0]) ? " selected='selected'" : ""; - childSelect.Obj.append("" + thisOption.value + ""); - break; - case "C": - if(thisOption.id === childSelectSelected[0]) { - childSelect.Obj.attr("value", thisOption.value); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOption.value + "|" + thisOption.id; - break; - case "M": - childSelect.Obj.append(""); - newMultiLookupPickerdata += thisOption.id + "|t" + thisOption.value + "|t |t |t"; - break; - default: - break; - } - }); - - switch(childSelect.Type) { - case "S": - childSelect.Obj.trigger("change"); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - $(childSelect.Obj).find("option[value!='0']:first").attr("selected", "selected"); - } - break; - case "C": - // Set the allowable choices - childSelect.Obj.attr("choices", choices); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - // Set the input element value - $(childSelect.Obj).attr("value", firstChildOptionValue); - // Set the value of the optHid input element - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(firstChildOptionId); - } - // If there's no selection, then remove the value in the associated hidden input element (optHid) - if(childSelect.Obj.val() === "") { - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(""); - } - break; - case "M": - // Clear the master - master.data = ""; - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - - // Clear any prior selections that are no longer valid or aren't selected - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - var thisValue = $(this).html(); - $(this).attr("selected", "selected"); - $(childSelect.Obj).find("option").filter(function() { - return $(this).text() === thisValue.replace(/&/, "&"); - }).each(function() { - if($(this).html() === thisValue) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - - // Hide any options in the candidate list which are already selected - $(childSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - childSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }); // $(childColumns).each(function() - - } // End cascadeDropdown - - - // function to convert complex dropdowns to simple dropdowns - $.fn.SPServices.SPComplexToSimpleDropdown = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox("SPServices.SPComplexToSimpleDropdown", "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // If we don't have a complex dropdown, then there is nothing to do - if(columnSelect.Type !== "C") { return; } - - // The available options are stored in the choices attribute of the complex dropdowns's input element... - var choices = $(columnSelect.Obj).attr("choices").split("|"); - // The optHid attribute contains the id of a hidden input element which stores the selected value for the commit - var columnOptHid = $(columnSelect.Obj).attr("optHid"); - var columnOptHidInput = $("input[id='" + columnOptHid + "']"); - // We need to know which option is selected already, if any - var complexSelectSelectedId = $("input[id='" + columnOptHid + "']").val(); - - // Build up the simple dropdown, giving it an easy to select id - var simpleSelectId = genContainerId("SPComplexToSimpleDropdown", opt.columnName); - - var simpleSelect = ""; - - // Append the new simple select to the form - $(columnSelect.Obj).closest("td").prepend(simpleSelect); - - // Remove the complex dropdown functionality since we don't need it anymore... - $(columnSelect.Obj).closest("span").find("img").remove(); - // ...and hide the input element - $(columnSelect.Obj).closest("span").find("input").hide(); - - // When the simple select changes... - $("#" + simpleSelectId).change(function() { - var thisVal = $(this).val(); - // ...set the optHid input element's value to the valus of the selected option... - columnOptHidInput.val(thisVal); - // ...and save the selected value as the hidden input's value only if the value is not equal to "0" (None) - $(columnSelect.Obj).val($(this).find("option[value='" + (thisVal !== "0" ? thisVal : "") + "']").html()); - }); - // Trigger a change to ensure that the selected value registers in the complex dropdown - $("#" + simpleSelectId).trigger("change"); - - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - - }; // End $.fn.SPServices.SPConvertToSimpleDropdown - - - // Function to display related information when an option is selected on a form. - $.fn.SPServices.SPDisplayRelatedInfo = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - relatedWebURL: "", // [Optional] The name of the Web (site) which contains the related list - relatedList: "", // The name of the list which contains the additional information - relatedListColumn: "", // The internal name of the related column in the related list - relatedColumns: [], // An array of related columns to display - displayFormat: "table", // The format to use in displaying the related information. Possible values are: [table, list] - headerCSSClass: "ms-vh2", // CSS class for the table headers - rowCSSClass: "ms-vb", // CSS class for the table rows - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be ed with the default query on the relatedList - numChars: 0, // If used on an input column (not a dropdown), no matching will occur until at least this number of characters has been entered - matchType: "Eq", // If used on an input column (not a dropdown), type of match. Can be any valid CAML comparison operator, most often "Eq" or "BeginsWith" - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var divId; - var relatedColumnsXML = []; - var relatedListXML; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // Generate a unique id for the container - divId = genContainerId("SPDisplayRelatedInfo", opt.columnName); - - // Get information about the related list and its columns - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - completefunc: function(xData) { - // If debug is on, notify about an error - $(xData.responseXML).find("faultcode").each(function() { - if(opt.debug) {errBox(thisFunction, "relatedList: " + opt.relatedList, "List not found"); return; } - }); - // Get info about the related list - relatedListXML = $(xData.responseXML).find("List"); - // Save the information about each column requested - for (i=0; i < opt.relatedColumns.length; i++) { - relatedColumnsXML[i] = $(xData.responseXML).find("Fields > Field[Name='" + opt.relatedColumns[i] + "']"); - } - } - }); - - switch(columnSelect.Type) { - // Plain old select - case "S": - columnSelect.Obj.bind("change", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='" + columnSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Multi-select hybrid - case "M": - if(opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, "Multi-select columns not supported by this function"); } - break; - default: - break; - } - // Fire the change to set the initially allowable values - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - - }; // End $.fn.SPServices.SPDisplayRelatedInfo - - function showRelated(opt, divId, relatedListXML, relatedColumnsXML) { - - var columnSelectSelected = null; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, opt.matchOnId); - if(columnSelect.Type === "C" && opt.numChars > 0 && columnSelectSelected[0].length < opt.numChars) { - return; - } - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C", as there are multiple propertychanges - // which don't require any action. - if(columnSelect.Obj.attr("showRelatedSelected") === columnSelectSelected[0]) { - return; - } - columnSelect.Obj.attr("showRelatedSelected", columnSelectSelected[0]); - - // Remove the old container... - $("#" + divId).remove(); - // ...and append a new, empty one - columnSelect.Obj.parent().append("
    "); - - // Get the list items which match the current selection - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - camlQuery += "" : "'/>") + - escapeColumnValue(columnSelectSelected[0]) + ""; - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - var viewFields = " "; - for (i=0; i < opt.relatedColumns.length; i++) { - viewFields += ""; - } - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - // Filter based on the column's currently selected value - CAMLQuery: camlQuery, - CAMLViewFields: "" + viewFields + "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relatedListColumn: " + opt.relatedListColumn, - "Column not found in relatedList " + opt.relatedList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relatedList: " + opt.relatedList, - "List not found"); - } - return; - }); - - var outString; - // Output each row - switch(opt.displayFormat) { - // Only implementing the table format in the first iteration (v0.2.9) - case "table": - outString = ""; - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === "undefined" && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - } - outString += ""; - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - outString += ""; - } - outString += ""; - }); - outString += "
    " + relatedColumnsXML[i].attr("DisplayName") + "
    " + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
    "; - break; - // list format implemented in v0.5.0. Still table-based, but vertical orientation. - case "list": - outString = ""; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === "undefined" && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - outString += ""; - outString += ""; - outString += ""; - } - }); - outString += "
    " + relatedColumnsXML[i].attr("DisplayName") + "" + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
    "; - break; - default: - break; - } - // Write out the results - $("#" + divId).html(outString); - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - } // End showRelated - - // Function to filter a lookup based dropdown - $.fn.SPServices.SPFilterDropdown = function(options) { - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationshipList - relationshipList: "", // The name of the list which contains the lookup values - relationshipListColumn: "", // The internal name of the column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListColumn - relationshipListSortAscending: true, // [Optional] By default, the sort is ascending. If false, descending - columnName: "", // The display name of the column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of columnName. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - CAMLQuery: "", // This CAML fragment will be applied to the relationshipList - CAMLQueryOptions: "FALSE", // Need this to mirror SharePoint's behavior, but it can be overridden - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages; if false, run silent - }, options); - - var choices = ""; - var columnSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var columnColumnRequired; - var thisFunction = "SPServices.SPFilterDropdown"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return;} - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, true); - - // Get the relationshipList items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListColumn; - var sortOrder = (opt.relationshipListSortAscending === true) ? "" : "Ascending='FALSE'"; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery; - } - camlQuery += ""; - - // Get information about columnName from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName is Required - columnColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - // Stop looking; we're done - return false; - }); - }); - } - }); - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the specified CAML - CAMLQuery: camlQuery, - // Only get the columnName's data (plus columns we can't prevent) - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: opt.CAMLQueryOptions, - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListColumn: " + opt.relationshipListColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(columnSelect.Type) { - case "S": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!columnColumnRequired && (opt.promptText.length > 0)) { - columnSelect.Obj.append(""); - } else if(!columnColumnRequired){ - columnSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = columnColumnRequired ? "" : opt.noneText + "|0"; - columnSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - - // Add an option for each item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOption = {}; - - // If relationshipListColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListColumn); - - if(typeof thisValue !== "undefined" && thisValue.indexOf(";#") > 0) { - thisOption = new SplitIndex(thisValue); - } else { - thisOption.id = $(this).attr("ows_ID"); - thisOption.value = thisValue; - } - - // If the relationshipListColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOption.id should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOption.id)) { - thisOption.id = $(this).attr("ows_ID"); - } - - switch(columnSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === columnSelectSelected[0]) ? " selected='selected'" : ""; - columnSelect.Obj.append("" + thisOption.value + ""); - break; - case "C": - if(thisOption.id === columnSelectSelected[0]) { - columnSelect.Obj.attr("value", thisOption.value); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOption.value + "|" + thisOption.id; - break; - case "M": - columnSelect.Obj.append(""); - newMultiLookupPickerdata += thisOption.id + "|t" + thisOption.value + "|t |t |t"; - break; - default: - break; - } - }); - - switch(columnSelect.Type) { - case "S": - columnSelect.Obj.trigger("change"); - break; - case "C": - columnSelect.Obj.attr("choices", choices); - columnSelect.Obj.trigger("propertychange"); - break; - case "M": - // Find the important bits of the multi-select - MultiLookupPickerdata = columnSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[columnSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - var currentSelection = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - // Clear the master - master.data = ""; - - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - // Clear any prior selections that are no longer valid - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - $(this).attr("selected", "selected"); - $(columnSelect.Obj).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - // Hide any options in the candidate list which are already selected - $(columnSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - columnSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPFilterDropdown - - - // Utility function to show the results of a Web Service call formatted well in the browser. - $.fn.SPServices.SPDebugXMLHttpResult = function(options) { - - var opt = $.extend({}, { - node: null, // An XMLHttpResult object from an ajax call - indent: 0 // Number of indents - }, options); - - var i; - var NODE_TEXT = 3; - var NODE_CDATA_SECTION = 4; - - var outString = ""; - // For each new subnode, begin rendering a new TABLE - outString += ""; - // DisplayPatterns are a bit unique, so let's handle them differently - if(opt.node.nodeName === "DisplayPattern") { - outString += ""; - // A node which has no children - } else if (!opt.node.hasChildNodes()) { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // A CDATA_SECTION node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_CDATA_SECTION) { - outString += ""; - // A TEXT node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_TEXT) { - outString += ""; - // Handle child nodes - } else { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // Since the node has child nodes, recurse - outString += ""; - } - outString += "
    " + opt.node.nodeName + - "
    " + opt.node.nodeName + - "" + ((opt.node.nodeValue !== null) ? checkLink(opt.node.nodeValue) : " ") + "
    " + showAttrs(opt.node) + "
    " + opt.node.nodeName + - "
    " + opt.node.nodeName + - "" + checkLink(opt.node.firstChild.nodeValue) + "
    " + opt.node.nodeName + "
    " + showAttrs(opt.node) + "
    "; - for (i = 0;i < opt.node.childNodes.length; i++) { - outString += $().SPServices.SPDebugXMLHttpResult({ - node: opt.node.childNodes.item(i), - indent: opt.indent + 1 - }); - } - outString += "
    "; - // Return the HTML which we have built up - return outString; - }; // End $.fn.SPServices.SPDebugXMLHttpResult - - // Function which returns the account name for the current user in DOMAIN\username format - $.fn.SPServices.SPGetCurrentUser = function(options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Site Collection. If not specified, the current Web is used. - fieldName: "Name", // Specifies which field to return from the userdisp.aspx page - fieldNames: {}, // Specifies which fields to return from the userdisp.aspx page - added in v0.7.2 to allow multiple columns - debug: false // If true, show error messages; if false, run silent - }, options); - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldName === "ID" && typeof currentContext.thisUserId !== "undefined") { - return currentContext.thisUserId; - } - - var thisField = ""; - var theseFields = {}; - var fieldCount = opt.fieldNames.length > 0 ? opt.fieldNames.length : 1; - var thisUserDisp; - var thisWeb = opt.webURL.length > 0 ? opt.webURL : $().SPServices.SPGetCurrentSite(); - - // Get the UserDisp.aspx page using AJAX - $.ajax({ - // Need this to be synchronous so we're assured of a valid value - async: false, - // Force parameter forces redirection to a page that displays the information as stored in the UserInfo table rather than My Site. - // Adding the extra Query String parameter with the current date/time forces the server to view this as a new request. - url: thisWeb + "/_layouts/userdisp.aspx?Force=True&" + new Date().getTime(), - complete: function (xData, Status) { - thisUserDisp = xData; - } - }); - - for(i=0; i < fieldCount; i++) { - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldNames[i] === "ID") { - thisField = currentContext.thisUserId; - } else { - var thisTextValue; - if(fieldCount > 1) { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldNames[i] + "\"", "gi"); - } else { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldName + "\"", "gi"); - } - $(thisUserDisp.responseText).find("table.ms-formtable td[id^='SPField']").each(function() { - if(thisTextValue.test($(this).html())) { - // Each fieldtype contains a different data type, as indicated by the id - switch($(this).attr("id")) { - case "SPFieldText": - thisField = $(this).text(); - break; - case "SPFieldNote": - thisField = $(this).find("div").html(); - break; - case "SPFieldURL": - thisField = $(this).find("img").attr("src"); - break; - // Just in case - default: - thisField = $(this).text(); - break; - } - // Stop looking; we're done - return false; - } - }); - } - if(opt.fieldNames[i] !== "ID") { - thisField = (typeof thisField !== "undefined") ? thisField.replace(/(^[\s\xA0]+|[\s\xA0]+$)/g, '') : null; - } - if(fieldCount > 1) { - theseFields[opt.fieldNames[i]] = thisField; - } - } - - return (fieldCount > 1) ? theseFields : thisField; - - }; // End $.fn.SPServices.SPGetCurrentUser - - - // Function which provides a link on a Lookup column for the user to follow - // which allows them to add a new value to the Lookup list. - // Based on http://blog.mastykarz.nl/extending-lookup-fields-add-new-item-option/ - // by Waldek Mastykarz - $.fn.SPServices.SPLookupAddNew = function(options) { - - var opt = $.extend({}, { - lookupColumn: "", // The display name of the Lookup column - promptText: "Add new {0}", // Text to use as prompt + column name - newWindow: false, // If true, the link will open in a new window *without* passing the Source. - ContentTypeID: "", // [Optional] Pass the ContentTypeID if you'd like to specify it - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var thisFunction = "SPServices.SPLookupAddNew"; - - // Find the lookup column's select (dropdown) - var lookupSelect = new DropdownCtl(opt.lookupColumn); - if(lookupSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, TXTColumnNotFound);return;} - - var newUrl = ""; - var lookupListUrl = ""; - var lookupColumnStaticName = ""; - // Use GetList for the current list to determine the details for the Lookup column - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $().SPServices.SPListNameFromUrl(), - completefunc: function (xData, Status) { - $(xData.responseXML).find("Field[DisplayName='" + opt.lookupColumn + "']").each(function() { - lookupColumnStaticName = $(this).attr("StaticName"); - // Use GetList for the Lookup column's list to determine the list's URL - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $(this).attr("List"), - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - lookupListUrl = $(this).attr("WebFullUrl"); - // Need to handle when list is in the root site - lookupListUrl = lookupListUrl !== SLASH ? lookupListUrl + SLASH : lookupListUrl; - }); - } - }); - // Get the NewItem form for the Lookup column's list - newUrl = getListFormUrl($(this).attr("List"), "NewForm"); - // Stop looking;we're done - return false; - }); - } - }); - - if(lookupListUrl.length === 0 && opt.debug) { - errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, "This column does not appear to be a lookup column"); - return; - } - if(newUrl.length > 0) { - // Build the link to the Lookup column's list enclosed in a div with the id="SPLookupAddNew_" + lookupColumnStaticName - var newHref = lookupListUrl + newUrl; - // If requested, open the link in a new window and if requested, pass the ContentTypeID - newHref += opt.newWindow ? - ((opt.ContentTypeID.length > 0) ? "?ContentTypeID=" + opt.ContentTypeID : "") + "' target='_blank'" : - "?" + ((opt.ContentTypeID.length > 0) ? "ContentTypeID=" + opt.ContentTypeID + "&" : "") + "Source=" + escapeUrl(location.href) + "'"; - var newLink = "
    " + " 0) { - camlQuery += ""; - } - camlQuery += "" + userId + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: camlQuery, - CAMLViewFields: "", - CAMLRowLimit: 1, - CAMLQueryOptions: "", - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - lastId = $(this).attr("ows_ID"); - }); - } - }); - return lastId; - }; // End $.fn.SPServices.SPGetLastItemId - - // Function which checks to see if the value for a column on the form is unique in the list. - $.fn.SPServices.SPRequireUnique = function (options) { - - var opt = $.extend({}, { - columnStaticName: "Title", // Name of the column - duplicateAction: 0, // 0 = warn, 1 = prevent - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - initMsg: "This value must be unique.", // Initial message to display after setup - initMsgCSSClass: "ms-vb", // CSS class for initial message - errMsg: "This value is not unique.", // Error message to display if not unique - errMsgCSSClass: "ms-formvalidation", // CSS class for error message - showDupes: false, // If true, show links to the duplicate item(s) after the error message - completefunc: null // Function to call on completion of rendering the change. - }, options); - - // Get the current item's ID from the Query String - var queryStringVals = $().SPServices.SPGetQueryString(); - var thisID = queryStringVals.ID; - currentContext.thisList = $().SPServices.SPListNameFromUrl(); - - // Set the messages based on the options provided - var msg = "{1}
    "; - var firstMsg = msg.replace(/\{0\}/g, opt.initMsgCSSClass).replace(/\{1\}/g, opt.initMsg); - - // We need the DisplayName - var columnDisplayName = $().SPServices.SPGetDisplayFromStatic({ - listName: currentContext.thisList, - columnStaticName: opt.columnStaticName - }); - var columnObj = $("input[Title='" + columnDisplayName + "']"); - $(columnObj).parent().append(firstMsg); - - $(columnObj).blur(function () { - var columnValueIDs = []; - // Get the columnDisplayName's value - var columnValue = $(this).attr("value"); - if(columnValue.length === 0) { return false; } - - // Call the Lists Web Service (GetListItems) to see if the value already exists - $().SPServices({ - operation: "GetListItems", - async: false, - listName: currentContext.thisList, - // Make sure we get all the items, ignoring any filters on the default view. - CAMLQuery: "", - // Filter based on columnStaticName's value - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData) { - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = opt.ignoreCase ? $(this).attr("ows_" + opt.columnStaticName).toUpperCase() : $(this).attr("ows_" + opt.columnStaticName); - // If this value already exists in columnStaticName and it's not the current item, then save the ID in the array - if((testValue === thisValue) && ($(this).attr("ows_ID") !== thisID)) { - columnValueIDs.push([$(this).attr("ows_ID"), $(this).attr("ows_" + opt.columnStaticName)]); - } - }); - } - }); - var newMsg = opt.initMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.initMsgCSSClass); - - $("input[value='OK']:disabled, input[value='Save']:disabled").removeAttr("disabled"); - if(columnValueIDs.length > 0) { - newMsg = opt.errMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.errMsgCSSClass); - if(opt.duplicateAction === 1) { - $("input[Title='" + opt.columnDisplayName + "']").focus(); - $("input[value='OK'], input[value='Save']").attr("disabled", "disabled"); - } - if(opt.showDupes) { - var out = " " + columnValueIDs.length + " duplicate item" + (columnValueIDs.length > 1 ? "s" : "") + ": "; - for (i=0;i < columnValueIDs.length; i++) { - out += "
    " + columnValueIDs[i][1] + " "; - } - $("span#SPRequireUnique" + opt.columnStaticName).append(out); - } - } - - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPRequireUnique - - // This function returns the DisplayName for a column based on the StaticName. - $.fn.SPServices.SPGetDisplayFromStatic = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnStaticName: "", // StaticName of the column - columnStaticNames: {} // StaticName of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var displayName = ""; - var displayNames = {}; - var nameCount = opt.columnStaticNames.length > 0 ? opt.columnStaticNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - displayNames[opt.columnStaticNames[i]] = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticNames[i] + "']").attr("DisplayName"); - } - } else { - displayName = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticName + "']").attr("DisplayName"); - } - } - }); - - return (nameCount > 1) ? displayNames : displayName; - - }; // End $.fn.SPServices.SPGetDisplayFromStatic - - // This function returns the StaticName for a column based on the DisplayName. - $.fn.SPServices.SPGetStaticFromDisplay = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnDisplayName: "", // DisplayName of the column - columnDisplayNames: {} // DisplayNames of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var staticName = ""; - var staticNames = {}; - var nameCount = opt.columnDisplayNames.length > 0 ? opt.columnDisplayNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - staticNames[opt.columnDisplayNames[i]] = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayNames[i] + "']").attr("StaticName"); - } - } else { - staticName = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayName + "']").attr("StaticName"); - } - } - }); - - return (nameCount > 1) ? staticNames : staticName; - - }; // End $.fn.SPServices.SPGetStaticFromDisplay - - // This function allows you to redirect to a another page from a new item form with the new - // item's ID. This allows chaining of forms from item creation onward. - $.fn.SPServices.SPRedirectWithID = function (options) { - - var opt = $.extend({}, { - redirectUrl: "", // Page for the redirect - qsParamName: "ID" // In some cases, you may want to pass the newly created item's ID with a different - // parameter name than ID. Specify that name here, if needed. - }, options); - - currentContext.thisList = $().SPServices.SPListNameFromUrl(); - var queryStringVals = $().SPServices.SPGetQueryString(); - var lastID = queryStringVals.ID; - var QSList = queryStringVals.List; - var QSRootFolder = queryStringVals.RootFolder; - var QSContentTypeId = queryStringVals.ContentTypeId; - - // On first load, change the form actions to redirect back to this page with the current lastID for this user and the - // original Source. - if(typeof queryStringVals.ID === "undefined") { - lastID = $().SPServices.SPGetLastItemId({ - listName: currentContext.thisList - }); - $("form[name='aspnetForm']").each(function() { - // This page... - var thisUrl = (location.href.indexOf("?") > 0) ? location.href.substring(0, location.href.indexOf("?")) : location.href; - // ... plus the Source if it exists - var thisSource = (typeof queryStringVals.Source === "string") ? - "Source=" + queryStringVals.Source.replace(/\//g, "%2f").replace(/:/g, "%3a") : ""; - - var newQS = []; - if(typeof QSList !== "undefined") { - newQS.push("List=" + QSList); - } - if(typeof QSRootFolder !== "undefined") { - newQS.push("RootFolder=" + QSRootFolder); - } - if(typeof QSContentTypeId !== "undefined") { - newQS.push("ContentTypeId=" + QSContentTypeId); - } - - var newAction = thisUrl + - ((newQS.length > 0) ? ("?" + newQS.join("&") + "&") : "?") + - // Set the Source to point back to this page with the lastID this user has added - "Source=" + thisUrl + - "?ID=" + lastID + - // Pass the original source as RealSource, if present - ((thisSource.length > 0) ? ("%26RealSource=" + queryStringVals.Source) : "") + - // Pass the override RedirectURL, if present - ((typeof queryStringVals.RedirectURL === "string") ? ("%26RedirectURL=" + queryStringVals.RedirectURL) : ""); - $(this).attr("action", newAction); - }); - // If this is the load after the item is saved, wait until the new item has been saved (commits are asynchronous), - // then do the redirect to redirectUrl with the new lastID, passing along the original Source. - } else { - while(queryStringVals.ID === lastID) { - lastID = $().SPServices.SPGetLastItemId({ - listName: currentContext.thisList - }); - } - // If there is a RedirectURL parameter on the Query String, then redirect there instead of the value - // specified in the options (opt.redirectUrl) - var thisRedirectUrl = (typeof queryStringVals.RedirectURL === "string") ? queryStringVals.RedirectURL : opt.redirectUrl; - location.href = thisRedirectUrl + "?" + opt.qsParamName + "=" + lastID + - ((typeof queryStringVals.RealSource === "string") ? ("&Source=" + queryStringVals.RealSource) : ""); - } - }; // End $.fn.SPServices.SPRedirectWithID - - // The SPSetMultiSelectSizes function sets the sizes of the multi-select boxes for a column on a form automagically - // based on the values they contain. The function takes into account the fontSize, fontFamily, fontWeight, etc., in its algorithm. - $.fn.SPServices.SPSetMultiSelectSizes = function (options) { - - var opt = $.extend({}, { - multiSelectColumn: "", - minWidth: 0, - maxWidth: 0, - debug: false - }, options); - - var thisFunction = "SPServices.SPSetMultiSelectSizes"; - - // Find the multi-select column - var thisMultiSelect = new DropdownCtl(opt.multiSelectColumn); - if(thisMultiSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, TXTColumnNotFound);return;} - if(thisMultiSelect.Type !== "M" && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, "Column is not multi-select.");return;} - - var possibleValues = thisMultiSelect.Obj; - var selectedValues = possibleValues.closest("span").find("select[ID$='SelectResult']"); - - // Create a temporary clone of the select to use to determine the appropriate width settings. - // We'll append it to the end of the enclosing span. - var cloneId = genContainerId("SPSetMultiSelectSizes", opt.multiSelectColumn); - possibleValues.clone().appendTo(possibleValues.closest("span")).css({ - "width": "auto", // We want the clone to resize its width based on the contents - "height": 0, // Just to keep the page clean while we are using the clone - "visibility": "hidden" // And let's keep it hidden - }).attr({ - id: cloneId, // We don't want the clone to have the same id as its source - length: 0 // And let's start with no options - }); - var cloneObj = $("#" + cloneId); - - // Add all the values to the cloned select. First the left (possible values) select... - possibleValues.find("option").each(function() { - cloneObj.append(""); - }); - // ...then the right (selected values) select (in case some values have already been selected) - selectedValues.find("option").each(function() { - cloneObj.append(""); - }); - - // We'll add 5px for a little padding on the right. - var divWidth = $("#" + cloneId).width() + 5; - var newDivWidth = divWidth; - if(opt.minWidth > 0 || opt.maxWidth > 0) { - if(divWidth < opt.minWidth) { - divWidth = opt.minWidth; - } - if(newDivWidth < opt.minWidth) { - newDivWidth = opt.minWidth; - } - if(newDivWidth > opt.maxWidth) { - newDivWidth = opt.maxWidth; - } - } - var selectWidth = divWidth; - - // Set the new widths - possibleValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - selectedValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - - // Remove the select's clone, since we're done with it - $("#" + cloneId).remove(); - }; // End $.fn.SPServices.SPSetMultiSelectSizes - - // Does an audit of a site's list forms to show where script is in use. - $.fn.SPServices.SPScriptAudit = function (options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] The name of the Web (site) to audit - listName: "", // [Optional] The name of a specific list to audit. If not present, all lists in the site are audited. - outputId: "", // The id of the DOM object for output - auditForms: true, // Audit the form pages - auditViews: true, // Audit the view pages - auditPages: true, // Audit the Pages Document Library - auditPagesListName: "Pages", // The Pages Document Library(ies), if desired. Either a single string or an array of strings. - showHiddenLists: false, // Show output for hidden lists - showNoScript: false, // Show output for lists with no scripts (effectively "verbose") - showSrc: true // Show the source location for included scripts - }, options); - - var formTypes = [["New", "NewForm.aspx", false], ["Display", "DispForm.aspx", false], ["Edit", "EditForm.aspx", false]]; - var listXml; - - // Build the table to contain the results - $("#" + opt.outputId) - .append("" + - "" + - "" + - "" + - "" + - "" + - "" + - (opt.showSrc ? "" : "") + - "" + - "
    ListPage ClassPage TypePageScript References
    "); - // Apply the CSS class to the headers - $("#SPScriptAudit th").attr("class", "ms-vh2-nofilter"); - - // Don't bother with the lists if the options don't require them - if(opt.auditForms || opt.auditViews) { - // First, get all of the lists within the site - $().SPServices({ - operation: "GetListCollection", - webURL: opt.webURL, - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - - // If listName has been specified, then only return results for that list - if((opt.listName.length === 0) || (listXml.attr("Title") === opt.listName)) { - // Don't work with hidden lists unless we're asked to - if((opt.showHiddenLists && listXml.attr("Hidden") === "False") || !opt.showHiddenLists) { - - // Audit the list's forms - if(opt.auditForms) { - // Get the list's Content Types, therefore the form pages - $().SPServices({ - operation: "GetListContentTypes", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("ContentType").each(function() { - // Don't deal with folders - if($(this).attr("ID").substring(0,6) !== "0x0120") { - var formUrls = $(this).find("FormUrls"); - for(i=0; i < formTypes.length; i++) { - // Look for a customized form... - $(formUrls).find(formTypes[i][0]).each(function() { - SPScriptAuditPage(opt, listXml, "Form", this.nodeName, - ((opt.webURL.length > 0) ? opt.webURL : $().SPServices.SPGetCurrentSite()) + SLASH + $(this).text()); - formTypes[i][2] = true; - }); - // ...else the uncustomized form - if(!formTypes[i][2]) { - var defaultViewUrl = listXml.attr("DefaultViewUrl"); - SPScriptAuditPage(opt, listXml, "Form", formTypes[i][0], - defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH)+1) + formTypes[i][1]); - } - } - // Reset the form types - for(i=0; i < formTypes.length; i++) { - formTypes[i][2] = false; - } - } - }); - } - }); - } - - // Audit the list's views - if(opt.auditViews) { - // Get the list's Views - $().SPServices({ - operation: "GetViewCollection", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("View").each(function() { - SPScriptAuditPage(opt, listXml, "View", $(this).attr("DisplayName"), $(this).attr("Url")); - }); - } - }); - } - - } - } - }); - } - }); - } - - // Don't bother with auditing pages if the options don't require it - var numLists = 0; - var listsArray = []; - if(typeof opt.auditPagesListName === "string") { - numLists = 1; - listsArray.push(opt.auditPagesListName); - } else { - numLists = opt.auditPagesListName.length; - listsArray = opt.auditPagesListName; - } - - if(opt.auditPages) { - for(i=0; i < numLists; i++) { - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: listsArray[i], - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - }); - } - }); - // Get all of the items from the Document Library - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: listsArray[i], - CAMLQuery: "Folder", - CAMLViewFields: "", - CAMLRowLimit: 0, - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisPageUrl = $(this).attr("ows_FileRef").split(";#")[1]; - var thisTitle = $(this).attr("ows_Title"); - var thisPageType = (typeof thisTitle !== "undefined") ? thisTitle : ""; - if(thisPageUrl.indexOf(".aspx") > 0) { - SPScriptAuditPage(opt, listXml, "Page", thisPageType, SLASH + thisPageUrl); - } - }); - } - }); - } - } - // Remove progress indicator and make the output pretty by cleaning up the ms-alternating CSS class - $("#SPScriptAudit tr[class='ms-alternating']:even").removeAttr("class"); - }; // End $.fn.SPServices.SPScriptAudit - - // Displays the usage of scripts in a site - function SPScriptAuditPage(opt, listXml, pageClass, pageType, pageUrl) { - - var i = 0; - var jQueryPage = 0; - var pageScriptSrc = {}; - pageScriptSrc.type = []; - pageScriptSrc.src = []; - pageScriptSrc.script = []; - var scriptRegex = RegExp("", "gi"); - - // Fetch the page - $.ajax({ - type: "GET", - url: pageUrl, - dataType: "text", - async: false, - success: function(xData) { - - var scriptMatch; - - while (scriptMatch = scriptRegex.exec(xData)) { - var scriptLanguage = getScriptAttribute(scriptMatch, "language"); - var scriptType = getScriptAttribute(scriptMatch, "type"); - var scriptSrc = getScriptAttribute(scriptMatch, "src"); - if(scriptSrc !== null && scriptSrc.length > 0 && !coreScript(scriptSrc)) { - pageScriptSrc.type.push((scriptLanguage !== null && scriptLanguage.length > 0) ? scriptLanguage : scriptType); - pageScriptSrc.src.push(scriptSrc); - jQueryPage++; - } - } - - // Only show pages without script if we've been asked to do so. - if((!opt.showNoScript && (pageScriptSrc.type.length > 0)) || opt.showNoScript) { - var pagePath = pageUrl.substring(0, pageUrl.lastIndexOf(SLASH)+1); - var out = "" + - "" + - "" + listXml.attr("Title") + ((listXml.attr("Hidden") === "True") ? '(Hidden)' : '')+ "" + - "" + pageClass + "" + - "" + pageType + "" + - "" + fileName(pageUrl) + ""; - if(opt.showSrc) { - var thisSrcPath; - out += ""; - for(i=0; i < pageScriptSrc.type.length; i++) { - thisSrcPath = (pageScriptSrc.src[i].substr(0,1) !== SLASH) ? pagePath + pageScriptSrc.src[i] : pageScriptSrc.src[i]; - out += ""; - out += ""; - } - out += "
    " + pageScriptSrc.type[i] + "" + fileName(pageScriptSrc.src[i]) + "
    "; - } - $("#SPScriptAudit").append(out); - } - } - }); - } // End of function SPScriptAuditPage - - function getScriptAttribute(source, attribute) { - var matches; - var regex = RegExp(attribute + "=(\"([^\"]*)\")|('([^']*)')", "gi"); - if(matches = regex.exec(source)) { - return matches[2]; - } - return null; - } // End of function getScriptAttribute - - // Check to see if the script reference is part of SharePoint core so that we can ignore it - function coreScript(src) { - var i; - var coreScriptLocations = ["WebResource.axd", "_layouts"]; - for(i=0; i < coreScriptLocations.length; i++) { - if(src.indexOf(coreScriptLocations[i]) > -1) { - return true; - } - } - return false; - } // End of function coreScript - - // Rearrange radio buttons or checkboxes in a form from vertical to horizontal display to save page real estate - $.fn.SPServices.SPArrangeChoices = function (options) { - - var opt = $.extend({}, { - listName: $().SPServices.SPListNameFromUrl(), // The list name for the current form - columnName: "", // The display name of the column in the form - perRow: 99, // Maximum number of choices desired per row. - randomize: false // If true, randomize the order of the options - }, options); - - var columnFillInChoice = false; - var columnOptions = []; - var out; - - // Get information about columnName from the list to determine if we're allowing fill-in choices - var thisGetList = $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName - }); - - // when the promise is available... - thisGetList.done(function() { - $(thisGetList.responseXML).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName allows a fill-in choice - columnFillInChoice = ($(this).attr("FillInChoice") === "TRUE") ? true : false; - // Stop looking;we're done - return false; - }); - - var thisFormField = findFormField(opt.columnName); - - var totalChoices = $(thisFormField).find("tr").length; - var choiceNumber = 0; - var fillinPrompt; - var fillinInput; - // Collect all of the choices - $(thisFormField).find("tr").each(function() { - choiceNumber++; - // If this is the fill-in prompt, save it... - if(columnFillInChoice && choiceNumber === (totalChoices - 1)) { - fillinPrompt = $(this).find("td").html(); - // ...or if it is the fill-in input box, save it... - } else if(columnFillInChoice && choiceNumber === totalChoices) { - fillinInput = $(this).find("td").html(); - // ...else push into the columnOptions array. - } else { - columnOptions.push($(this).html()); - } - }); - out = ""; - - // If randomize is true, randomly sort the options - if(opt.randomize) { - columnOptions.sort(randOrd); - } - - // Add all of the options to the out string - for(i=0; i < columnOptions.length; i++) { - out += columnOptions[i]; - // If we've already got perRow columnOptions in the row, close off the row - if((i+1) % opt.perRow === 0) { - out += ""; - } - } - out += ""; - - // If we are allowing a fill-in choice, add that option in a separate row at the bottom - if(columnFillInChoice) { - out += "" + fillinPrompt + fillinInput + ""; - } - - // Remove the existing rows... - $(thisFormField).find("tr").remove(); - // ...and append the out string - $(thisFormField).find("table").append(out); - - }); - - }; // End $.fn.SPServices.SPArrangeChoices - - // Provide suggested values from a list for in input column based on characters typed - $.fn.SPServices.SPAutocomplete = function (options) { - - var opt = $.extend({}, { - WebURL: "", // [Optional] The name of the Web (site) which contains the sourceList - sourceList: "", // The name of the list which contains the values - sourceColumn: "", // The static name of the column which contains the values - columnName: "", // The display name of the column in the form - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relatedList - CAMLQueryOptions: "", // [Optional] For power users, allows specifying the CAMLQueryOptions for the GetListItems call - CAMLRowLimit: 0, // [Optional] Override the default view rowlimit and get all appropriate rows - filterType: "BeginsWith", // Type of filtering: [BeginsWith, Contains] - numChars: 0, // Wait until this number of characters has been typed before attempting any actions - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - highlightClass: "", // If a class is supplied, highlight the matched characters in the values by applying that class to a wrapping span - uniqueVals: false, // If set to true, the function only adds unique values to the list (no duplicates) - maxHeight: 99999, // Sets the maximum number of values to display before scrolling occurs - slideDownSpeed: "fast", // Speed at which the div should slide down when values match (milliseconds or ["fast" | "slow"]) - processingIndicator: "_layouts/images/REFRESH.GIF", // If present, show this while processing - debug: false // If true, show error messages;if false, run silent - }, options); - - var matchNum; - - // Find the input control for the column and save some of its attributes - var columnObj = $("input[Title='" + opt.columnName + "']"); - $("input[Title='" + opt.columnName + "']").css("position", ""); - var columnObjId = columnObj.attr("ID"); - var columnObjColor = columnObj.css("color"); - var columnObjWidth = columnObj.css("width"); - - if(columnObj.html() === null && opt.debug) { - errBox("SPServices.SPAutocomplete", - "columnName: " + opt.columnName, - "Column is not an input control or is not found on page"); - return; - } - - // Remove the
    which isn't needed and messes up the formatting - columnObj.closest("span").find("br").remove(); - columnObj.wrap("
    "); - - // Create a div to contain the matching values and add it to the DOM - var containerId = genContainerId("SPAutocomplete", opt.columnName); - columnObj.after("
    "); - - // Set the width to match the width of the input control - $("#" + containerId).css("width", columnObjWidth); - - // Handle keypresses - $(columnObj).keyup(function () { - - // Get the column's value - var columnValue = $(this).val(); - - // Hide the container while we're working on it - $("#" + containerId).hide(); - - // Have enough characters been typed yet? - if(columnValue.length < opt.numChars) { - return false; - } - - // Show the the processingIndicator as a background image in the input element - columnObj.css({ - "background-image": "url(" + opt.processingIndicator + ")", - "background-position": "right", - "background-repeat": "no-repeat" - }); - - // Array to hold the matched values - var matchArray = []; - - // Build the appropriate CAMLQuery - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - camlQuery += "<" + opt.filterType + ">" + columnValue + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - // Call GetListItems to find all of the potential values - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.WebURL, - listName: opt.sourceList, - CAMLQuery: camlQuery, - CAMLQueryOptions: opt.CAMLQueryOptions, - CAMLViewFields: "", - CAMLRowLimit: opt.CAMLRowLimit, - completefunc: function(xData) { - // Handle upper/lower case if ignoreCase = true - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - // See which values match and add the ones that do to matchArray - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = $(this).attr("ows_" + opt.sourceColumn); - var thisValueTest = opt.ignoreCase ? $(this).attr("ows_" + opt.sourceColumn).toUpperCase() : $(this).attr("ows_" + opt.sourceColumn); - // Make sure we have a match... - if(opt.filterType === "Contains") { - var firstMatch = thisValueTest.indexOf(testValue); - if((firstMatch >= 0) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } else { - // Handles normal case, which is BeginsWith and and other unknown values - if(testValue === thisValueTest.substr(0,testValue.length) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } - }); - } - }); - - // Build out the set of list elements to contain the available values - var out = ""; - for (i=0; i < matchArray.length; i++) { - // If a highlightClass has been supplied, wrap a span around each match - if(opt.highlightClass.length > 0) { - // Set up Regex based on whether we want to ignore case - var thisRegex = RegExp(columnValue, opt.ignoreCase ? "gi" : "g"); - // Look for all occurrences - var matches = matchArray[i].match(thisRegex); - var startLoc = 0; - // Loop for each occurrence, wrapping each in a span with the highlightClass CSS class - for (matchNum=0; matchNum < matches.length; matchNum++) { - var thisPos = matchArray[i].indexOf(matches[matchNum], startLoc); - var endPos = thisPos + matches[matchNum].length; - var thisSpan = "" + matches[matchNum] + ""; - matchArray[i] = matchArray[i].substr(0, thisPos) + thisSpan + matchArray[i].substr(endPos); - startLoc = thisPos + thisSpan.length; - } - } - // Add the value to the markup for the container - out += "
  • " + matchArray[i] + "
  • "; - } - - // Add all the list elements to the containerId container - $("#" + containerId).html(out); - // Set up hehavior for the available values in the list element - $("#" + containerId + " li").click(function () { - $("#" + containerId).fadeOut(opt.slideUpSpeed); - $("#" + columnObjId).val($(this).text()); - }).mouseover(function () { - var mouseoverCss = { - "cursor": "hand", - "color": "#ffffff", - "background": "#3399ff" - }; - $(this).css(mouseoverCss); - }).mouseout(function () { - var mouseoutCss = { - "cursor": "inherit", - "color": columnObjColor, - "background": "transparent" - }; - $(this).css(mouseoutCss); - }); - - // If we've got some values to show, then show 'em! - if(matchArray.length > 0) { - $("#" + containerId).slideDown(opt.slideDownSpeed); - } - // Remove the processing indicator - columnObj.css("background-image", ""); - }); - - }; // End $.fn.SPServices.SPAutocomplete - - // Get the Query String parameters and their values and return in an array - $.fn.SPServices.SPGetQueryString = function () { - - var queryStringVals = {}; - var matches; - var qs = location.search.substring(1, location.search.length); - var args = qs.split("&"); - var rxQS = /^([^=]+)=(.*)/i; - - for(var i=0; i < args.length; i++) { - matches = rxQS.exec(args[i]); - if(rxQS.test(location.href)) { - if(matches !== null && matches.length > 2) { - queryStringVals[matches[1]] = unescape(matches[2]).replace(/\+/g,' '); - } - } - } - return queryStringVals; - - }; // End $.fn.SPServices.SPGetQueryString - - // Get the current list's GUID (ID) from the current URL. Use of this function only makes sense if we're in a list's context, - // and we assume that we are calling it from an aspx page which is a form or view for the list. - $.fn.SPServices.SPListNameFromUrl = function (options) { - - var opt = $.extend({}, { - listName: "" // [Optional] Pass in the name or GUID of a list if you are not in its context. e.g., on a Web Part pages in the Pages library - }, options); - - // Has the list name or GUID been passed in? - if(opt.listName.length > 0) { - currentContext.thisList = opt.listName; - return currentContext.thisList; - // Do we already know the current list? - } else if(currentContext.thisList.length > 0) { - return currentContext.thisList; - } - - // Parse out the list's root URL from the current location or the passed url - var thisPage = location.href; - var thisPageBaseName = thisPage.substring(0, thisPage.indexOf(".aspx")); - var listPath = decodeURIComponent(thisPageBaseName.substring(0, thisPageBaseName.lastIndexOf(SLASH) + 1)).toUpperCase(); - - // Call GetListCollection and loop through the results to find a match with the list's URL to get the list's GUID - $().SPServices({ - operation: "GetListCollection", - async: false, - completefunc: function(xData, Status) { - $(xData.responseXML).find("List").each(function() { - var defaultViewUrl = $(this).attr("DefaultViewUrl"); - var listCollList = defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH) + 1).toUpperCase(); - if(listPath.indexOf(listCollList) > 0) { - currentContext.thisList = $(this).attr("ID"); - return false; - } - }); - } - }); - - // Return the list GUID (ID) - return currentContext.thisList; - - }; // End $.fn.SPServices.SPListNameFromUrl - - // SPUpdateMultipleListItems allows you to update multiple items in a list based upon some common characteristic or metadata criteria. - $.fn.SPServices.SPUpdateMultipleListItems = function(options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] URL of the target Web. If not specified, the current Web is used. - listName: "", // The list to operate on. - CAMLQuery: "", // A CAML fragment specifying which items in the list will be selected and updated - batchCmd: "Update", // The operation to perform. By default, Update. - valuepairs: [], // Valuepairs for the update in the form [[fieldname1, fieldvalue1], [fieldname2, fieldvalue2]...] - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var i; - var itemsToUpdate = []; - var documentsToUpdate = []; - - // Call GetListItems to find all of the items matching the CAMLQuery - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: opt.CAMLQuery, - CAMLQueryOptions: "", - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - itemsToUpdate.push($(this).attr("ows_ID")); - var fileRef = $(this).attr("ows_FileRef"); - fileRef = "/" + fileRef.substring(fileRef.indexOf(";#")+2); - documentsToUpdate.push(fileRef); - }); - } - }); - - var fieldNum; - var batch = ""; - for(i=0; i < itemsToUpdate.length; i++) { - batch += ""; - for (fieldNum=0; fieldNum < opt.valuepairs.length; fieldNum++) { - batch += "" + escapeColumnValue(opt.valuepairs[fieldNum][1]) + ""; - } - batch += "" + itemsToUpdate[i] + ""; - if(documentsToUpdate[i].length > 0) { - batch += "" + documentsToUpdate[i] + ""; - } - batch += ""; - } - batch += ""; - - // Call UpdateListItems to update all of the items matching the CAMLQuery - $().SPServices({ - operation: "UpdateListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - updates: batch, - completefunc: function(xData) { - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(xData, Status); - } - } - }); - - }; // End $.fn.SPServices.SPUpdateMultipleListItems - - // This method for finding specific nodes in the returned XML was developed by Steve Workman. See his blog post - // http://www.steveworkman.com/html5-2/javascript/2011/improving-javascript-xml-node-finding-performance-by-2000/ - // for performance details. - $.fn.SPFilterNode = function(name) { - return this.find('*').filter(function() { - return this.nodeName === name; - }); - }; // End $.fn.SPFilterNode - - - // This function converts an XML node set to JSON - // Initial implementation focuses only on GetListItems - $.fn.SPXmlToJson = function(options) { - - var opt = $.extend({}, { - mapping: {}, // columnName: mappedName: "mappedName", objectType: "objectType" - includeAllAttrs: false, // If true, return all attributes, regardless whether they are in the mapping - removeOws: true // Specifically for GetListItems, if true, the leading ows_ will be stripped off the field name - }, options); - - var attrNum; - var jsonObject = []; - - this.each(function() { - var row = {}; - var rowAttrs = this.attributes; - - // Bring back all mapped columns, even those with no value - $.each(opt.mapping, function() { - row[this.mappedName] = ""; - }); - - // Parse through the element's attributes - for(attrNum = 0; attrNum < rowAttrs.length; attrNum++) { - var thisAttrName = rowAttrs[attrNum].name; - var thisMapping = opt.mapping[thisAttrName]; - var thisObjectName = typeof thisMapping !== "undefined" ? thisMapping.mappedName : opt.removeOws ? thisAttrName.split("ows_")[1] : thisAttrName; - var thisObjectType = typeof thisMapping !== "undefined" ? thisMapping.objectType : undefined; - if(opt.includeAllAttrs || thisMapping !== undefined) { - row[thisObjectName] = attrToJson(rowAttrs[attrNum].value, thisObjectType); - } - } - // Push this item into the JSON Object - jsonObject.push(row); - - }); - - // Return the JSON object - return jsonObject; - - }; // End $.fn.SPServices.SPXmlToJson - - - function attrToJson(v, objectType) { - - var colValue; - - switch (objectType) { - case "DateTime": - case "datetime": // For calculated columns, stored as datetime;#value - // Dates have dashes instead of slashes: ows_Created="2009-08-25 14:24:48" - colValue = dateToJsonObject(v); - break; - case "User": - colValue = userToJsonObject(v); - break; - case "UserMulti": - colValue = userMultiToJsonObject(v); - break; - case "Lookup": - colValue = lookupToJsonObject(v); - break; - case "LookupMulti": - colValue = lookupMultiToJsonObject(v); - break; - case "Boolean": - colValue = booleanToJsonObject(v); - break; - case "Integer": - colValue = intToJsonObject(v); - break; - case "Counter": - colValue = intToJsonObject(v); - break; - case "MultiChoice": - colValue = choiceMultiToJsonObject(v); - break; - case "Currency": - case "float": // For calculated columns, stored as float;#value - colValue = floatToJsonObject(v); - break; - case "Calc": - colValue = calcToJsonObject(v); - break; - default: - // All other objectTypes will be simple strings - colValue = stringToJsonObject(v); - break; - } - return colValue; - } - - function stringToJsonObject(s) { - return s; - } - function intToJsonObject(s) { - return parseInt(s, 10); - } - function floatToJsonObject(s) { - return parseFloat(s); - } - function booleanToJsonObject(s) { - var out = s === "0" ? false : true; - return out; - } - function dateToJsonObject(s) { - return new Date(s.replace(/-/g, "/")); - } - function userToJsonObject(s) { - if (s.length === 0) { - return null; - } else { - var thisUser = new SplitIndex(s); - var thisUserExpanded = thisUser.value.split(",#"); - if(thisUserExpanded.length === 1) { - return {userId: thisUser.Id, userName: thisUser.value}; - } else { - return { - userId: thisUser.Id, - userName: thisUserExpanded[0].replace( /(,,)/g, ","), - loginName: thisUserExpanded[1].replace( /(,,)/g, ","), - email: thisUserExpanded[2].replace( /(,,)/g, ","), - sipAddress: thisUserExpanded[3].replace( /(,,)/g, ","), - title: thisUserExpanded[4].replace( /(,,)/g, ",") - }; - } - } - } - function userMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisUserMultiObject = []; - var thisUserMulti = s.split(";#"); - for(i=0; i < thisUserMulti.length; i=i+2) { - var thisUser = userToJsonObject(thisUserMulti[i] + ";#" + thisUserMulti[i+1]); - thisUserMultiObject.push(thisUser); - } - return thisUserMultiObject; - } - } - function lookupToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookup = new SplitIndex(s); - return {lookupId: thisLookup.id, lookupValue: thisLookup.value}; - } - } - function lookupMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookupMultiObject = []; - var thisLookupMulti = s.split(";#"); - for(i=0; i < thisLookupMulti.length; i=i+2) { - var thisLookup = lookupToJsonObject(thisLookupMulti[i] + ";#" + thisLookupMulti[i+1]); - thisLookupMultiObject.push(thisLookup); - } - return thisLookupMultiObject; - } - } - function choiceMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisChoiceMultiObject = []; - var thisChoiceMulti = s.split(";#"); - for(i=0; i < thisChoiceMulti.length; i++) { - if(thisChoiceMulti[i].length !== 0) { - thisChoiceMultiObject.push(thisChoiceMulti[i]); - } - } - return thisChoiceMultiObject; - } - } - function calcToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisCalc = s.split(";#"); - // The first value will be the calculated column value type, the second will be the value - return attrToJson(thisCalc[1], thisCalc[0]); - } - } - - // Find a People Picker in the page - // Returns references to: - // row - The TR which contains the People Picker (useful if you'd like to hide it at some point) - // contents - The element which contains the current value - // currentValue - The current value if it is set - // checkNames - The Check Names image (in case you'd like to click it at some point) - $.fn.SPFindPeoplePicker = function(options) { - - var opt = $.extend({}, { - peoplePickerDisplayName: "", // The displayName of the People Picker on the form - valueToSet: "", // The value to set the People Picker to. Should be a string containing each username or groupname separated by semi-colons. - checkNames: true // If set to true, the Check Names image will be clicked to resolve the names - }, options); - - var thisRow = $("nobr").filter(function() { - // Ensures we get a match whether or not the People Picker is required (if required, the nobr contains a span also) - return $(this).contents().eq(0).text() === opt.peoplePickerDisplayName; - }).closest("tr"); - - var thisContents = thisRow.find("div[name='upLevelDiv']"); - var thisCheckNames = thisRow.find("img[Title='Check Names']:first"); - - // If a value was provided, set the value - if(opt.valueToSet.length > 0) { - thisContents.html(opt.valueToSet); - } - - // If checkName is true, click the check names icon - if(opt.checkNames) { - thisCheckNames.click(); - } - var thisCurrentValue = $.trim(thisContents.text()); - - // Parse the entity data - var dictionaryEntries = []; - - // IE - thisContents.children("span").each(function() { - - // Grab the entity data - var thisData = $(this).find("div[data]").attr("data"); - - var dictionaryEntry = {}; - - // Entity data is only available in IE - if(typeof thisData !== "undefined") { - var arrayOfDictionaryEntry = $.parseXML(thisData); - var $xml = $(arrayOfDictionaryEntry); - - $xml.find("DictionaryEntry").each(function() { - var key = $(this).find("Key").text(); - var value = $(this).find("Value").text(); - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - // For other browsers, we'll call GetUserInfo to get the data - } else { - $().SPServices({ - operation: "GetUserInfo", - async: false, - cacheXML: true, - userLoginName: $(this).attr("title"), - completefunc: function(xData) { - - $(xData.responseXML).find("User").each(function() { - - $.each(this.attributes, function(i, attrib){ - var key = attrib.name; - var value = attrib.value; - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - }); - } - }); - } - }); - - return {row: thisRow, contents: thisContents, currentValue: thisCurrentValue, checkNames: thisCheckNames, dictionaryEntries: dictionaryEntries}; - }; - - // Return the current version of SPServices as a string - $.fn.SPServices.Version = function () { - - return VERSION; - - }; // End $.fn.SPServices.Version - - -////// PRIVATE FUNCTIONS //////// - - // Get the current context (as much as we can) on startup - // See: http://johnliu.net/blog/2012/2/3/sharepoint-javascript-current-page-context-info.html - function SPServicesContext() { - - // SharePoint 2010 gives us a context variable - if(typeof _spPageContextInfo !== "undefined") { - this.thisSite = _spPageContextInfo.webServerRelativeUrl; - this.thisList = _spPageContextInfo.pageListId; - this.thisUserId = _spPageContextInfo.userId; - // In SharePoint 2007, we know the UserID only - } else { - this.thisSite = ""; - this.thisList = ""; - this.thisUserId = (typeof _spUserId !== "undefined") ? _spUserId : undefined; - } - - } // End of function SPServicesContext - - - // Display a column (field) formatted correctly based on its definition in the list. - // NOTE: Currently not dealing with locale differences. - // columnXML The XML node for the column from a GetList operation - // columnValue The text representation of the column's value - // opt The current set of options - function showColumn(listXML, columnXML, columnValue, opt) { - - if(typeof columnValue === "undefined") { - return ""; - } - - var i; - var outString = ""; - var dispUrl; - var numDecimals; - var outArray =[]; - var webUrl = opt.relatedWebURL.length > 0 ? opt.relatedWebURL : $().SPServices.SPGetCurrentSite(); - - switch(columnXML.attr("Type")) { - case "Text": - outString = columnValue; - break; - case "URL": - switch(columnXML.attr("Format")) { - // URL as hyperlink - case "Hyperlink": - outString = "
    " + - columnValue.substring(columnValue.search(",") + 1) + ""; - break; - // URL as image - case "Image": - outString = "" + columnValue.substring(columnValue.search(",") + 1) +
-							""; - break; - // Just in case - default: - outString = columnValue; - break; - } - break; - case "User": - case "UserMulti": - var userMultiValues = columnValue.split(";#"); - for(i=0; i < userMultiValues.length; i = i+2) { - outArray.push("" + - userMultiValues[i+1] + ""); - } - outString = outArray.join(", "); - break; - case "Calculated": - var calcColumn = columnValue.split(";#"); - outString = calcColumn[1]; - break; - case "Number": - numDecimals = columnXML.attr("Decimals"); - outString = typeof numDecimals === "undefined" ? - parseFloat(columnValue).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Currency": - numDecimals = columnXML.attr("Decimals"); - outString = typeof numDecimals === "undefined" ? - parseFloat(columnValue).toFixed(2).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Lookup": - switch(columnXML.attr("Name")) { - case "FileRef": - // Get the display form URL for the lookup source list - dispUrl = listXML.attr("BaseType") === "1" ? listXML.attr("RootFolder") + SLASH + "Forms/DispForm.aspx" : - listXML.attr("RootFolder") + SLASH + "DispForm.aspx"; - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - case "FileDirRef": - // Get the display form URL for the lookup source list - dispUrl = SLASH + columnValue.substring(columnValue.search(";#") + 2); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - // Any other lookup column - default: - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - } - break; - case "LookupMulti": - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - // Show all the values as links to the items, separated by commas - outString = ""; - if(columnValue.length > 0) { - var lookupMultiValues = columnValue.split(";#"); - for(i=0; i < lookupMultiValues.length / 2; i++) { - outArray.push("" + - lookupMultiValues[(i * 2) + 1] + ""); - } - } - outString = outArray.join(", "); - break; - case "File": - fileName = columnValue.substring(columnValue.search(";#") + 2); - outString = "" + fileName + ""; - break; - case "Counter": - outString = columnValue; - break; - case "DateTime": - outString = columnValue; - break; - default: - outString = columnValue; - break; - } - return outString; - } // End of function showColumn - - - // Show a single attribute of a node, enclosed in a table - // node The XML node - // opt The current set of options - function showAttrs(node) { - var i; - var out = ""; - for (i=0; i < node.attributes.length; i++) { - out += ""; - } - out += "
    " + i + "" + - node.attributes.item(i).nodeName + "" + checkLink(node.attributes.item(i).nodeValue) + "
    "; - return out; - } // End of function showAttrs - - - // Find a dropdown (or multi-select) in the DOM. Returns the dropdown onject and its type: - // S = Simple (select);C = Compound (input + select hybrid);M = Multi-select (select hybrid) - function DropdownCtl(colName) { - // Simple - if((this.Obj = $("select[Title='" + colName + "']")).length === 1) { - this.Type = "S"; - // Compound - } else if((this.Obj = $("input[Title='" + colName + "']")).length === 1) { - this.Type = "C"; - // Multi-select: This will find the multi-select column control in English and most other languages sites where the Title looks like 'Column Name possible values' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title^='" + colName + " ']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Russian site (and perhaps others) where the Title looks like 'Выбранных значений: Column Name' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=': " + colName + "']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a German site (and perhaps others) where the Title looks like 'Mögliche Werte für "Column name".' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$='\"" + colName + "\".']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Italian site (and perhaps others) where the Title looks like "Valori possibili Column name" - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=' " + colName + "']")).length === 1) { - this.Type = "M"; - } else { - this.Type = null; - } - } // End of function DropdownCtl - - - // Returns the selected value(s) for a dropdown in an array. Expects a dropdown object as returned by the DropdownCtl function. - // If matchOnId is true, returns the ids rather than the text values for the selection options(s). - function getDropdownSelected(columnSelect, matchOnId) { - - var columnSelectSelected = []; - - switch(columnSelect.Type) { - case "S": - if(matchOnId) { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").text() || []); - } - break; - case "C": - if(matchOnId) { - columnSelectSelected.push($("input[id='"+ columnSelect.Obj.attr("optHid") + "']").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.attr("value") || []); - } - break; - case "M": - var columnSelections = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - $(columnSelections).find("option").each(function() { - columnSelectSelected.push($(this).html()); - }); - break; - default: - break; - } - return columnSelectSelected; - - } // End of function getDropdownSelected - - // Build an error message based on passed parameters - function errBox(func, param, msg) { - var errMsg = "Error in function
    " + func + "
    " + - "Parameter
    " + param + "
    " + - "Message
    " + msg + "

    " + - "Click to continue
    "; - modalBox(errMsg); - } // End of function errBox - - // Call this function to pop up a branded modal msgBox - function modalBox(msg) { - var boxCSS = "position:absolute;width:300px;height:150px;padding:10px;background-color:#000000;color:#ffffff;z-index:30;font-family:'Arial';font-size:12px;display:none;"; - $("#aspnetForm").parent().append("
    " + msg); - var height = $("#SPServices_msgBox").height(); - var width = $("#SPServices_msgBox").width(); - var leftVal = ($(window).width() / 2) - (width / 2) + "px"; - var topVal = ($(window).height() / 2) - (height / 2) - 100 + "px"; - $("#SPServices_msgBox").css({border:'5px #C02000 solid', left:leftVal, top:topVal}).show().fadeTo("slow", 0.75).click(function () { - $(this).fadeOut("3000", function () { - $(this).remove(); - }); - }); - } // End of function modalBox - - // Generate a unique id for a containing div using the function name and the column display name - function genContainerId(funcname, columnName) { - return funcname + "_" + $().SPServices.SPGetStaticFromDisplay({ - listName: $().SPServices.SPListNameFromUrl(), - columnDisplayName: columnName - }); - } // End of function genContainerId - - // Get the URL for a specified form for a list - function getListFormUrl(l, f) { - - var u; - $().SPServices({ - operation: "GetFormCollection", - async: false, - listName: l, - completefunc: function (xData, Status) { - u = $(xData.responseXML).find("Form[Type='" + f + "']").attr("Url"); - } - }); - return u; - - } // End of function getListFormUrl - - // Add the option values to the SOAPEnvelope.payload for the operation - // opt = options for the call - // paramArray = an array of option names to add to the payload - // "paramName" if the parameter name and the option name match - // ["paramName", "optionName"] if the parameter name and the option name are different (this handles early "wrappings" with inconsistent naming) - function addToPayload(opt, paramArray) { - - var i; - - for (i=0; i < paramArray.length; i++) { - // the parameter name and the option name match - if(typeof paramArray[i] === "string") { - SOAPEnvelope.payload += wrapNode(paramArray[i], opt[paramArray[i]]); - // the parameter name and the option name are different - } else if(paramArray[i].length === 2) { - SOAPEnvelope.payload += wrapNode(paramArray[i][0], opt[paramArray[i][1]]); - // something isn't right, so report it - } else { - errBox(opt.operation, "paramArray[" + i + "]: " + paramArray[i], "Invalid paramArray element passed to addToPayload()"); - } - } - } // End of function addToPayload - - // Finds the td which contains a form field in default forms using the comment which contains: - // - // as the "anchor" to find it. Necessary because SharePoint doesn't give all field types ids or specific classes. - function findFormField(columnName) { - var thisFormBody; - // There's no easy way to find one of these columns; we'll look for the comment with the columnName - var searchText = RegExp("FieldName=\"" + columnName.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&") + "\"", "gi"); - // Loop through all of the ms-formbody table cells - $("td.ms-formbody, td.ms-formbodysurvey").each(function() { - // Check for the right comment - if(searchText.test($(this).html())) { - thisFormBody = $(this); - // Found it, so we're done - return false; - } - }); - return thisFormBody; - } // End of function findFormField - - // The SiteData operations have the same names as other Web Service operations. To make them easy to call and unique, I'm using - // the SiteData prefix on their names. This function replaces that name with the right name in the SOAPEnvelope. - function siteDataFixSOAPEnvelope(SOAPEnvelope, siteDataOperation) { - var siteDataOp = siteDataOperation.substring(8); - SOAPEnvelope.opheader = SOAPEnvelope.opheader.replace(siteDataOperation, siteDataOp); - SOAPEnvelope.opfooter = SOAPEnvelope.opfooter.replace(siteDataOperation, siteDataOp); - return SOAPEnvelope; - } // End of function siteDataFixSOAPEnvelope - - // Wrap an XML node (n) around a value (v) - function wrapNode(n, v) { - var thisValue = typeof v !== "undefined" ? v : ""; - return "<" + n + ">" + thisValue + ""; - } - - // Generate a random number for sorting arrays randomly - function randOrd() { - return (Math.round(Math.random())-0.5); - } - - // If a string is a URL, format it as a link, else return the string as-is - function checkLink(s) { - return ((s.indexOf("http") === 0) || (s.indexOf(SLASH) === 0)) ? "" + s + "" : s; - } - - // Get the filename from the full URL - function fileName(s) { - return s.substring(s.lastIndexOf(SLASH)+1,s.length); - } - -/* Taken from http://dracoblue.net/dev/encodedecode-special-xml-characters-in-javascript/155/ */ - var xml_special_to_escaped_one_map = { - '&': '&', - '"': '"', - '<': '<', - '>': '>'}; - var escaped_one_to_xml_special_map = { - '&': '&', - '"': '"', - '<': '<', - '>': '>'}; - - function encodeXml(string) { - return string.replace(/([\&"<>])/g, function(str, item) { - return xml_special_to_escaped_one_map[item]; - }); - } - function decodeXml(string) { - return string.replace(/("|<|>|&)/g, - function(str, item) { - return escaped_one_to_xml_special_map[item]; - }); - } -/* Taken from http://dracoblue.net/dev/encodedecode-special-xml-characters-in-javascript/155/ */ - - // Escape column values - function escapeColumnValue(s) { - if(typeof s === "string") { - return s.replace(/&(?![a-zA-Z]{1,8};)/g, "&"); - } else { - return s; - } - } - - // Escape Url - function escapeUrl(u) { - return u.replace(/&/g,'%26'); - } - - // Split values like 1;#value into id and value - function SplitIndex(s) { - var spl = s.split(";#"); - this.id = spl[0]; - this.value = spl[1]; - } - - -})(jQuery); \ No newline at end of file diff --git a/jquery.SPServices-2013.01ALPHA5.js b/jquery.SPServices-2013.01ALPHA5.js deleted file mode 100644 index 4c6e3db..0000000 --- a/jquery.SPServices-2013.01ALPHA5.js +++ /dev/null @@ -1,4070 +0,0 @@ -/* - * SPServices - Work with SharePoint's Web Services using jQuery - * Version 0.7.3 - * @requires jQuery v1.5 or greater - jQuery 1.7+ recommended - * - * Copyright (c) 2009-2013 Sympraxis Consulting LLC - * Examples and docs at: - * http://spservices.codeplex.com - * Licensed under the MIT license: - * http://www.opensource.org/licenses/mit-license.php - */ -/* - * @description Work with SharePoint's Web Services using jQuery - * @type jQuery - * @name SPServices - * @category Plugins/SPServices - * @author Sympraxis Consulting LLC/marc.anderson@sympraxisconsulting.com - */ -/* jshint undef: true */ -/* global _spUserId, _spPageContextInfo, GipAddSelectedItems, GipRemoveSelectedItems, GipGetGroupData */ - -(function ($) { - - "use strict"; - - // Version info - var VERSION = "0.7.3"; // TODO: Update version - - // String constants - // General - var SLASH = "/"; - var TXTColumnNotFound = "Column not found on page"; - var SCHEMASharePoint = "http://schemas.microsoft.com/sharepoint"; - - // Caching - var promisesCache = {}; - - // Web Service names - var ALERTS = "Alerts"; - var AUTHENTICATION = "Authentication"; - var COPY = "Copy"; - var FORMS = "Forms"; - var LISTS = "Lists"; - var MEETINGS = "Meetings"; - var PEOPLE = "People"; - var PERMISSIONS = "Permissions"; - var PUBLISHEDLINKSSERVICE = "PublishedLinksService"; - var SEARCH = "Search"; - var SHAREPOINTDIAGNOSTICS = "SharePointDiagnostics"; - var SITEDATA = "SiteData"; - var SITES = "Sites"; - var SOCIALDATASERVICE = "SocialDataService"; - var SPELLCHECK = "SpellCheck"; - var TAXONOMYSERVICE = "TaxonomyClientService"; - var USERGROUP = "usergroup"; - var USERPROFILESERVICE = "UserProfileService"; - var VERSIONS = "Versions"; - var VIEWS = "Views"; - var WEBPARTPAGES = "WebPartPages"; - var WEBS = "Webs"; - var WORKFLOW = "Workflow"; - - // Global variables - var currentContext = new SPServicesContext(); // Variable to hold the current context as we figure it out - var i = 0; // Generic loop counter - var encodeOptionList = ["listName", "description"]; // Used to encode options which may contain special characters - - - // Array to store Web Service information - // WSops.OpName = [WebService, needs_SOAPAction]; - // OpName The name of the Web Service operation -> These names are unique - // WebService The name of the WebService this operation belongs to - // needs_SOAPAction Boolean indicating whether the operatio needs to have the SOAPAction passed in the setRequestHeaderfunction. - // true if the operation does a write, else false - - var WSops = []; - - WSops.GetAlerts = [ALERTS, false]; - WSops.DeleteAlerts = [ALERTS, true]; - - WSops.Mode = [AUTHENTICATION, false]; - WSops.Login = [AUTHENTICATION, false]; - - WSops.CopyIntoItems = [COPY, true]; - WSops.CopyIntoItemsLocal = [COPY, true]; - WSops.GetItem = [COPY, false]; - - WSops.GetForm = [FORMS, false]; - WSops.GetFormCollection = [FORMS, false]; - - WSops.AddAttachment = [LISTS, true]; - WSops.AddDiscussionBoardItem = [LISTS, true]; - WSops.AddList = [LISTS, true]; - WSops.AddListFromFeature = [LISTS, true]; - WSops.ApplyContentTypeToList = [LISTS, true]; - WSops.CheckInFile = [LISTS, true]; - WSops.CheckOutFile = [LISTS, true]; - WSops.CreateContentType = [LISTS, true]; - WSops.DeleteAttachment = [LISTS, true]; - WSops.DeleteContentType = [LISTS, true]; - WSops.DeleteContentTypeXmlDocument = [LISTS, true]; - WSops.DeleteList = [LISTS, true]; - WSops.GetAttachmentCollection = [LISTS, false]; - WSops.GetList = [LISTS, false]; - WSops.GetListAndView = [LISTS, false]; - WSops.GetListCollection = [LISTS, false]; - WSops.GetListContentType = [LISTS, false]; - WSops.GetListContentTypes = [LISTS, false]; - WSops.GetListItemChanges = [LISTS, false]; - WSops.GetListItemChangesSinceToken = [LISTS, false]; - WSops.GetListItems = [LISTS, false]; - WSops.GetVersionCollection = [LISTS, false]; - WSops.UndoCheckOut = [LISTS, true]; - WSops.UpdateContentType = [LISTS, true]; - WSops.UpdateContentTypesXmlDocument = [LISTS, true]; - WSops.UpdateContentTypeXmlDocument = [LISTS, true]; - WSops.UpdateList = [LISTS, true]; - WSops.UpdateListItems = [LISTS, true]; - - WSops.AddMeeting = [MEETINGS, true]; - WSops.CreateWorkspace = [MEETINGS, true]; - WSops.RemoveMeeting = [MEETINGS, true]; - WSops.SetWorkSpaceTitle = [MEETINGS, true]; - - WSops.ResolvePrincipals = [PEOPLE, false]; - WSops.SearchPrincipals = [PEOPLE, false]; - - WSops.AddPermission = [PERMISSIONS, true]; - WSops.AddPermissionCollection = [PERMISSIONS, true]; - WSops.GetPermissionCollection = [PERMISSIONS, true]; - WSops.RemovePermission = [PERMISSIONS, true]; - WSops.RemovePermissionCollection = [PERMISSIONS, true]; - WSops.UpdatePermission = [PERMISSIONS, true]; - - WSops.GetLinks = [PUBLISHEDLINKSSERVICE, true]; - - WSops.GetPortalSearchInfo = [SEARCH, false]; - WSops.GetQuerySuggestions = [SEARCH, false]; - WSops.GetSearchMetadata = [SEARCH, false]; - WSops.Query = [SEARCH, false]; - WSops.QueryEx = [SEARCH, false]; - WSops.Registration = [SEARCH, false]; - WSops.Status = [SEARCH, false]; - - WSops.SendClientScriptErrorReport = [SHAREPOINTDIAGNOSTICS,true]; - - WSops.GetAttachments = [SITEDATA, false]; - WSops.EnumerateFolder = [SITEDATA, false]; - WSops.SiteDataGetList = [SITEDATA, false]; - WSops.SiteDataGetListCollection = [SITEDATA, false]; - WSops.SiteDataGetSite = [SITEDATA, false]; - WSops.SiteDataGetSiteUrl = [SITEDATA, false]; - WSops.SiteDataGetWeb = [SITEDATA, false]; - - WSops.CreateWeb = [SITES, true]; - WSops.DeleteWeb = [SITES, false]; - WSops.GetSite = [SITES, false]; - WSops.GetSiteTemplates = [SITES, false]; - - WSops.AddComment = [SOCIALDATASERVICE, true]; - WSops.AddTag = [SOCIALDATASERVICE, true]; - WSops.AddTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.CountCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.CountTagsOfUser = [SOCIALDATASERVICE, false]; - WSops.DeleteComment = [SOCIALDATASERVICE, true]; - WSops.DeleteRating = [SOCIALDATASERVICE, true]; - WSops.DeleteTag = [SOCIALDATASERVICE, true]; - WSops.DeleteTagByKeyword = [SOCIALDATASERVICE, true]; - WSops.DeleteTags = [SOCIALDATASERVICE, true]; - WSops.GetAllTagTerms = [SOCIALDATASERVICE, false]; - WSops.GetAllTagTermsForUrlFolder = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrls = [SOCIALDATASERVICE, false]; - WSops.GetAllTagUrlsByKeyword = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetCommentsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingAverageOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOfUserOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOfUser = [SOCIALDATASERVICE, false]; - WSops.GetRatingsOnUrl = [SOCIALDATASERVICE, false]; - WSops.GetSocialDataForFullReplication = [SOCIALDATASERVICE, false]; - WSops.GetTags = [SOCIALDATASERVICE, true]; - WSops.GetTagsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTerms = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagTermsOnUrl = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUser = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsOfUserByKeyword = [SOCIALDATASERVICE, true]; - WSops.GetTagUrls = [SOCIALDATASERVICE, true]; - WSops.GetTagUrlsByKeyword = [SOCIALDATASERVICE, true]; - WSops.SetRating = [SOCIALDATASERVICE, true]; - WSops.UpdateComment = [SOCIALDATASERVICE, true]; - - WSops.SpellCheck = [SPELLCHECK, false]; - - // Taxonomy Service Calls - // Updated 2011.01.27 by Thomas McMillan - WSops.AddTerms = [TAXONOMYSERVICE, true]; - WSops.GetChildTermsInTerm = [TAXONOMYSERVICE, false]; - WSops.GetChildTermsInTermSet = [TAXONOMYSERVICE, false]; - WSops.GetKeywordTermsByGuids = [TAXONOMYSERVICE, false]; - WSops.GetTermsByLabel = [TAXONOMYSERVICE, false]; - WSops.GetTermSets = [TAXONOMYSERVICE, false]; - - WSops.AddGroup = [USERGROUP, true]; - WSops.AddGroupToRole = [USERGROUP, true]; - WSops.AddRole = [USERGROUP, true]; - WSops.AddRoleDef = [USERGROUP, true]; - WSops.AddUserCollectionToGroup = [USERGROUP, true]; - WSops.AddUserCollectionToRole = [USERGROUP, true]; - WSops.AddUserToGroup = [USERGROUP, true]; - WSops.AddUserToRole = [USERGROUP, true]; - WSops.GetAllUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupCollection = [USERGROUP, false]; - WSops.GetGroupCollectionFromRole = [USERGROUP, false]; - WSops.GetGroupCollectionFromSite = [USERGROUP, false]; - WSops.GetGroupCollectionFromUser = [USERGROUP, false]; - WSops.GetGroupCollectionFromWeb = [USERGROUP, false]; - WSops.GetGroupInfo = [USERGROUP, false]; - WSops.GetRoleCollection = [USERGROUP, false]; - WSops.GetRoleCollectionFromGroup = [USERGROUP, false]; - WSops.GetRoleCollectionFromUser = [USERGROUP, false]; - WSops.GetRoleCollectionFromWeb = [USERGROUP, false]; - WSops.GetRoleInfo = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForCurrentUser = [USERGROUP, false]; - WSops.GetRolesAndPermissionsForSite = [USERGROUP, false]; - WSops.GetUserCollection = [USERGROUP, false]; - WSops.GetUserCollectionFromGroup = [USERGROUP, false]; - WSops.GetUserCollectionFromRole = [USERGROUP, false]; - WSops.GetUserCollectionFromSite = [USERGROUP, false]; - WSops.GetUserCollectionFromWeb = [USERGROUP, false]; - WSops.GetUserInfo = [USERGROUP, false]; - WSops.GetUserLoginFromEmail = [USERGROUP, false]; - WSops.RemoveGroup = [USERGROUP, true]; - WSops.RemoveGroupFromRole = [USERGROUP, true]; - WSops.RemoveRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromGroup = [USERGROUP, true]; - WSops.RemoveUserCollectionFromRole = [USERGROUP, true]; - WSops.RemoveUserCollectionFromSite = [USERGROUP, true]; - WSops.RemoveUserFromGroup = [USERGROUP, true]; - WSops.RemoveUserFromRole = [USERGROUP, true]; - WSops.RemoveUserFromSite = [USERGROUP, true]; - WSops.RemoveUserFromWeb = [USERGROUP, true]; - WSops.UpdateGroupInfo = [USERGROUP, true]; - WSops.UpdateRoleDefInfo = [USERGROUP, true]; - WSops.UpdateRoleInfo = [USERGROUP, true]; - WSops.UpdateUserInfo = [USERGROUP, true]; - - WSops.AddColleague = [USERPROFILESERVICE, true]; - WSops.AddLink = [USERPROFILESERVICE, true]; - WSops.AddMembership = [USERPROFILESERVICE, true]; - WSops.AddPinnedLink = [USERPROFILESERVICE, true]; - WSops.CreateMemberGroup = [USERPROFILESERVICE, true]; - WSops.CreateUserProfileByAccountName = [USERPROFILESERVICE, true]; - WSops.GetCommonColleagues = [USERPROFILESERVICE, false]; - WSops.GetCommonManager = [USERPROFILESERVICE, false]; - WSops.GetCommonMemberships = [USERPROFILESERVICE, false]; - WSops.GetInCommon = [USERPROFILESERVICE, false]; - WSops.GetPropertyChoiceList = [USERPROFILESERVICE, false]; - WSops.GetUserColleagues = [USERPROFILESERVICE, false]; - WSops.GetUserLinks = [USERPROFILESERVICE, false]; - WSops.GetUserMemberships = [USERPROFILESERVICE, false]; - WSops.GetUserPinnedLinks = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByGuid = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByIndex = [USERPROFILESERVICE, false]; - WSops.GetUserProfileByName = [USERPROFILESERVICE, false]; - WSops.GetUserProfileCount = [USERPROFILESERVICE, false]; - WSops.GetUserProfileSchema = [USERPROFILESERVICE, false]; - WSops.ModifyUserPropertyByAccountName = [USERPROFILESERVICE, true]; - WSops.RemoveAllColleagues = [USERPROFILESERVICE, true]; - WSops.RemoveAllLinks = [USERPROFILESERVICE, true]; - WSops.RemoveAllMemberships = [USERPROFILESERVICE, true]; - WSops.RemoveAllPinnedLinks = [USERPROFILESERVICE, true]; - WSops.RemoveColleague = [USERPROFILESERVICE, true]; - WSops.RemoveLink = [USERPROFILESERVICE, true]; - WSops.RemoveMembership = [USERPROFILESERVICE, true]; - WSops.RemovePinnedLink = [USERPROFILESERVICE, true]; - WSops.UpdateColleaguePrivacy = [USERPROFILESERVICE, true]; - WSops.UpdateLink = [USERPROFILESERVICE, true]; - WSops.UpdateMembershipPrivacy = [USERPROFILESERVICE, true]; - WSops.UpdatePinnedLink = [USERPROFILESERVICE, true]; - - WSops.DeleteAllVersions = [VERSIONS, true]; - WSops.DeleteVersion = [VERSIONS, true]; - WSops.GetVersions = [VERSIONS, false]; - WSops.RestoreVersion = [VERSIONS, true]; - - WSops.AddView = [VIEWS, true]; - WSops.DeleteView = [VIEWS, true]; - WSops.GetView = [VIEWS, false]; - WSops.GetViewHtml = [VIEWS, false]; - WSops.GetViewCollection = [VIEWS, false]; - WSops.UpdateView = [VIEWS, true]; - WSops.UpdateViewHtml = [VIEWS, true]; - - WSops.AddWebPart = [WEBPARTPAGES, true]; - WSops.AddWebPartToZone = [WEBPARTPAGES, true]; - WSops.GetWebPart2 = [WEBPARTPAGES, false]; - WSops.GetWebPartPage = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties = [WEBPARTPAGES, false]; - WSops.GetWebPartProperties2 = [WEBPARTPAGES, false]; - - WSops.CreateContentType = [WEBS, true]; - WSops.GetColumns = [WEBS, false]; - WSops.GetContentType = [WEBS, false]; - WSops.GetContentTypes = [WEBS, false]; - WSops.GetCustomizedPageStatus = [WEBS, false]; - WSops.GetListTemplates = [WEBS, false]; - WSops.GetObjectIdFromUrl = [WEBS, false]; // 2010 - WSops.GetWeb = [WEBS, false]; - WSops.GetWebCollection = [WEBS, false]; - WSops.GetAllSubWebCollection = [WEBS, false]; - WSops.UpdateColumns = [WEBS, true]; - WSops.UpdateContentType = [WEBS, true]; - WSops.WebUrlFromPageUrl = [WEBS, false]; - - WSops.AlterToDo = [WORKFLOW, true]; - WSops.GetTemplatesForItem = [WORKFLOW, false]; - WSops.GetToDosForItem = [WORKFLOW, false]; - WSops.GetWorkflowDataForItem = [WORKFLOW, false]; - WSops.GetWorkflowTaskData = [WORKFLOW, false]; - WSops.StartWorkflow = [WORKFLOW, true]; - - // Set up SOAP envelope - var SOAPEnvelope = {}; - SOAPEnvelope.header = ""; - SOAPEnvelope.footer = ""; - SOAPEnvelope.payload = ""; - var SOAPAction; - - - // Main function, which calls SharePoint's Web Services directly. - $.fn.SPServices = function(options) { - - // If there are no options passed in, use the defaults. Extend replaces each default with the passed option. - var opt = $.extend({}, $.fn.SPServices.defaults, options); - - // Encode options which may contain special character, esp. ampersand - for(var i=0; i < encodeOptionList.length; i++) { - if(typeof opt[encodeOptionList[i]] === "string") { - opt[encodeOptionList[i]] = encodeXml(opt[encodeOptionList[i]]); - } - } - - // Put together operation header and SOAPAction for the SOAP call based on which Web Service we're calling - SOAPEnvelope.opheader = "<" + opt.operation + " "; - switch(WSops[opt.operation][0]) { - case ALERTS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/2002/1/alerts/' >"; - SOAPAction = SCHEMASharePoint + "/soap/2002/1/alerts/"; - break; - case MEETINGS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/meetings/' >"; - SOAPAction = SCHEMASharePoint + "/soap/meetings/"; - break; - case PERMISSIONS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case PUBLISHEDLINKSSERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService/"; - break; - case SEARCH: - SOAPEnvelope.opheader += "xmlns='urn:Microsoft.Search' >"; - SOAPAction = "urn:Microsoft.Search/"; - break; - case SHAREPOINTDIAGNOSTICS: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/diagnostics/' >"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/diagnostics/"; - break; - case SOCIALDATASERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/SocialDataService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/SocialDataService/"; - break; - case SPELLCHECK: - SOAPEnvelope.opheader += "xmlns='http://schemas.microsoft.com/sharepoint/publishing/spelling/' >"; - SOAPAction = "http://schemas.microsoft.com/sharepoint/publishing/spelling/SpellCheck"; - break; - case TAXONOMYSERVICE: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/taxonomy/soap/' >"; - SOAPAction = SCHEMASharePoint + "/taxonomy/soap/"; - break; - case USERGROUP: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/directory/' >"; - SOAPAction = SCHEMASharePoint + "/soap/directory/"; - break; - case USERPROFILESERVICE: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/webservices/SharePointPortalServer/UserProfileService' >"; - SOAPAction = "http://microsoft.com/webservices/SharePointPortalServer/UserProfileService/"; - break; - case WEBPARTPAGES: - SOAPEnvelope.opheader += "xmlns='http://microsoft.com/sharepoint/webpartpages' >"; - SOAPAction = "http://microsoft.com/sharepoint/webpartpages/"; - break; - case WORKFLOW: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/workflow/' >"; - SOAPAction = SCHEMASharePoint + "/soap/workflow/"; - break; - default: - SOAPEnvelope.opheader += "xmlns='" + SCHEMASharePoint + "/soap/'>"; - SOAPAction = SCHEMASharePoint + "/soap/"; - break; - } - - // Add the operation to the SOAPAction and opfooter - SOAPAction += opt.operation; - SOAPEnvelope.opfooter = ""; - - // Build the URL for the Ajax call based on which operation we're calling - // If the webURL has been provided, then use it, else use the current site - var ajaxURL = "_vti_bin/" + WSops[opt.operation][0] + ".asmx"; - if(opt.webURL.charAt(opt.webURL.length - 1) === SLASH) { - ajaxURL = opt.webURL + ajaxURL; - } else if(opt.webURL.length > 0) { - ajaxURL = opt.webURL + SLASH + ajaxURL; - } else { - ajaxURL = $().SPServices.SPGetCurrentSite() + SLASH + ajaxURL; - } - - SOAPEnvelope.payload = ""; - // Each operation requires a different set of values. This switch statement sets them up in the SOAPEnvelope.payload. - switch(opt.operation) { - // ALERT OPERATIONS - case "GetAlerts": - break; - case "DeleteAlerts": - SOAPEnvelope.payload += ""; - for (i=0; i < opt.IDs.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.IDs[i]); - } - SOAPEnvelope.payload += ""; - break; - - // AUTHENTICATION OPERATIONS - case "Mode": - break; - case "Login": - addToPayload(opt, ["username", "password"]); - break; - - // COPY OPERATIONS - case "CopyIntoItems": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - addToPayload(opt, ["Fields", "Stream", "Results"]); - break; - case "CopyIntoItemsLocal": - addToPayload(opt, ["SourceUrl"]); - SOAPEnvelope.payload += ""; - for (i=0; i < opt.DestinationUrls.length; i++) { - SOAPEnvelope.payload += wrapNode("string", opt.DestinationUrls[i]); - } - SOAPEnvelope.payload += ""; - break; - case "GetItem": - addToPayload(opt, ["Url", "Fields", "Stream"]); - break; - - // FORM OPERATIONS - case "GetForm": - addToPayload(opt, ["listName", "formUrl"]); - break; - case "GetFormCollection": - addToPayload(opt, ["listName"]); - break; - - // LIST OPERATIONS - case "AddAttachment": - addToPayload(opt, ["listName", "listItemID", "fileName", "attachment"]); - break; - case "AddDiscussionBoardItem": - addToPayload(opt, ["listName", "message"]); - break; - case "AddList": - addToPayload(opt, ["listName", "description", "templateID"]); - break; - case "AddListFromFeature": - addToPayload(opt, ["listName", "description", "featureID", "templateID"]); - break; - case "ApplyContentTypeToList": - addToPayload(opt, ["webUrl", "contentTypeId", "listName"]); - break; - case "CheckInFile": - addToPayload(opt, ["pageUrl", "comment", "CheckinType"]); - break; - case "CheckOutFile": - addToPayload(opt, ["pageUrl", "checkoutToLocal", "lastmodified"]); - break; - case "CreateContentType": - addToPayload(opt, ["listName", "displayName", "parentType", "fields", "contentTypeProperties", "addToView"]); - break; - case "DeleteAttachment": - addToPayload(opt, ["listName", "listItemID", "url"]); - break; - case "DeleteContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "DeleteContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "documentUri"]); - break; - case "DeleteList": - addToPayload(opt, ["listName"]); - break; - case "GetAttachmentCollection": - addToPayload(opt, ["listName", ["listItemID", "ID"]]); - break; - case "GetList": - addToPayload(opt, ["listName"]); - break; - case "GetListAndView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetListCollection": - break; - case "GetListContentType": - addToPayload(opt, ["listName", "contentTypeId"]); - break; - case "GetListContentTypes": - addToPayload(opt, ["listName"]); - break; - case "GetListItems": - addToPayload(opt, ["listName", "viewName", ["query", "CAMLQuery"], ["viewFields", "CAMLViewFields"], ["rowLimit", "CAMLRowLimit"], ["queryOptions", "CAMLQueryOptions"]]); - break; - case "GetListItemChanges": - addToPayload(opt, ["listName", "viewFields", "since", "contains"]); - break; - case "GetListItemChangesSinceToken": - addToPayload(opt, ["listName", "viewName", "query", "viewFields", "rowLimit", "queryOptions", "changeToken", "contains"]); - break; - case "GetVersionCollection": - addToPayload(opt, ["strlistID", "strlistItemID", "strFieldName"]); - break; - case "UndoCheckOut": - addToPayload(opt, ["pageUrl"]); - break; - case "UpdateContentType": - addToPayload(opt, ["listName", "contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields", "addToView"]); - break; - case "UpdateContentTypesXmlDocument": - addToPayload(opt, ["listName", "newDocument"]); - break; - case "UpdateContentTypeXmlDocument": - addToPayload(opt, ["listName", "contentTypeId", "newDocument"]); - break; - case "UpdateList": - addToPayload(opt, ["listName", "listProperties", "newFields", "updateFields", "deleteFields", "listVersion"]); - break; - case "UpdateListItems": - addToPayload(opt, ["listName"]); - if(typeof opt.updates !== "undefined" && opt.updates.length > 0) { - addToPayload(opt, ["updates"]); - } else { - SOAPEnvelope.payload += ""; - for (i=0; i < opt.valuepairs.length; i++) { - SOAPEnvelope.payload += "" + escapeColumnValue(opt.valuepairs[i][1]) + ""; - } - if(opt.batchCmd !== "New") { - SOAPEnvelope.payload += "" + opt.ID + ""; - } - SOAPEnvelope.payload += ""; - } - break; - - // MEETINGS OPERATIONS - case "AddMeeting": - addToPayload(opt, ["organizerEmail", "uid", "sequence", "utcDateStamp", "title", "location", "utcDateStart", "utcDateEnd", "nonGregorian"]); - break; - case "CreateWorkspace": - addToPayload(opt, ["title", "templateName", "lcid", "timeZoneInformation"]); - break; - case "RemoveMeeting": - addToPayload(opt, ["recurrenceId", "uid", "sequence", "utcDateStamp", "cancelMeeting"]); - break; - case "SetWorkspaceTitle": - addToPayload(opt, ["title"]); - break; - - // PEOPLE OPERATIONS - case "ResolvePrincipals": - addToPayload(opt, ["principalKeys", "principalType", "addToUserInfoList"]); - break; - case "SearchPrincipals": - addToPayload(opt, ["searchText", "maxResults", "principalType"]); - break; - - // PERMISSION OPERATIONS - case "AddPermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - case "AddPermissionCollection": - addToPayload(opt, ["objectName", "objectType", "permissionsInfoXml"]); - break; - case "GetPermissionCollection": - addToPayload(opt, ["objectName", "objectType"]); - break; - case "RemovePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType"]); - break; - case "RemovePermissionCollection": - addToPayload(opt, ["objectName", "objectType", "memberIdsXml"]); - break; - case "UpdatePermission": - addToPayload(opt, ["objectName", "objectType", "permissionIdentifier", "permissionType", "permissionMask"]); - break; - - // PUBLISHEDLINKSSERVICE OPERATIONS - case "GetLinks": - break; - - // SEARCH OPERATIONS - case "GetPortalSearchInfo": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "GetQuerySuggestions": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "GetSearchMetadata": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - break; - case "Query": - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "QueryEx": - SOAPEnvelope.opheader = "<" + opt.operation + " xmlns='http://microsoft.com/webservices/OfficeServer/QueryService'>"; - SOAPAction = "http://microsoft.com/webservices/OfficeServer/QueryService/" + opt.operation; - SOAPEnvelope.payload += wrapNode("queryXml", encodeXml(opt.queryXml)); - break; - case "Registration": - SOAPEnvelope.payload += wrapNode("registrationXml", encodeXml(opt.registrationXml)); - break; - case "Status": - break; - - // SHAREPOINTDIAGNOSTICS OPERATIONS - case "SendClientScriptErrorReport": - addToPayload(opt, ["message", "file", "line", "client", "stack", "team", "originalFile"]); - break; - - // SITEDATA OPERATIONS - case "EnumerateFolder": - addToPayload(opt, ["strFolderUrl"]); - break; - case "GetAttachments": - addToPayload(opt, ["strListName", "strItemId"]); - break; - case "SiteDataGetList": - addToPayload(opt, ["strListName"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetListCollection": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSite": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetSiteUrl": - addToPayload(opt, ["Url"]); - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - case "SiteDataGetWeb": - // Because this operation has a name which duplicates the Lists WS, need to handle - SOAPEnvelope = siteDataFixSOAPEnvelope(SOAPEnvelope, opt.operation); - break; - - // SITES OPERATIONS - case "CreateWeb": - addToPayload(opt, ["url", "title", "description", "templateName", "language", "languageSpecified", - "locale", "localeSpecified", "collationLocale", "collationLocaleSpecified", "uniquePermissions", - "uniquePermissionsSpecified", "anonymous", "anonymousSpecified", "presence", "presenceSpecified"]); - break; - case "DeleteWeb": - addToPayload(opt, ["url"]); - break; - case "GetSite": - addToPayload(opt, ["SiteUrl"]); - break; - case "GetSiteTemplates": - addToPayload(opt, ["LCID", "TemplateList"]); - break; - - // SOCIALDATASERVICE OPERATIONS - case "AddComment": - addToPayload(opt, ["url", "comment", "isHighPriority", "title"]); - break; - case "AddTag": - addToPayload(opt, ["url", "termID", "title", "isPrivate"]); - break; - case "AddTagByKeyword": - addToPayload(opt, ["url", "keyword", "title", "isPrivate"]); - break; - case "CountCommentsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "CountCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "CountCommentsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "CountTagsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "DeleteComment": - addToPayload(opt, ["url", "lastModifiedTime"]); - break; - case "DeleteRating": - addToPayload(opt, ["url"]); - break; - case "DeleteTag": - addToPayload(opt, ["url", "termID"]); - break; - case "DeleteTagByKeyword": - addToPayload(opt, ["url", "keyword"]); - break; - case "DeleteTags": - addToPayload(opt, ["url"]); - break; - case "GetAllTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetAllTagTermsForUrlFolder": - addToPayload(opt, ["urlFolder", "maximumItemsToReturn"]); - break; - case "GetAllTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetAllTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetCommentsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetCommentsOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetCommentsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn", "startIndex"]); - if(typeof opt.excludeItemsTime !== "undefined" && opt.excludeItemsTime.length > 0) { - SOAPEnvelope.payload += wrapNode("excludeItemsTime", opt.excludeItemsTime); - } - break; - case "GetRatingAverageOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingOfUserOnUrl": - addToPayload(opt, ["userAccountName", "url"]); - break; - case "GetRatingOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetRatingsOfUser": - addToPayload(opt, ["userAccountName"]); - break; - case "GetRatingsOnUrl": - addToPayload(opt, ["url"]); - break; - case "GetSocialDataForFullReplication": - addToPayload(opt, ["userAccountName"]); - break; - case "GetTags": - addToPayload(opt, ["url"]); - break; - case "GetTagsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn", "startIndex"]); - break; - case "GetTagTerms": - addToPayload(opt, ["maximumItemsToReturn"]); - break; - case "GetTagTermsOfUser": - addToPayload(opt, ["userAccountName", "maximumItemsToReturn"]); - break; - case "GetTagTermsOnUrl": - addToPayload(opt, ["url", "maximumItemsToReturn"]); - break; - case "GetTagUrls": - addToPayload(opt, ["termID"]); - break; - case "GetTagUrlsByKeyword": - addToPayload(opt, ["keyword"]); - break; - case "GetTagUrlsOfUser": - addToPayload(opt, ["termID", "userAccountName"]); - break; - case "GetTagUrlsOfUserByKeyword": - addToPayload(opt, ["keyword", "userAccountName"]); - break; - case "SetRating": - addToPayload(opt, ["url", "rating", "title", "analysisDataEntry"]); - break; - case "UpdateComment": - addToPayload(opt, ["url", "lastModifiedTime", "comment", "isHighPriority"]); - break; - - // SPELLCHECK OPERATIONS - case "SpellCheck": - addToPayload(opt, ["chunksToSpell", "declaredLanguage", "useLad"]); - break; - - // TAXONOMY OPERATIONS - case "AddTerms": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "newTerms"]); - break; - case "GetChildTermsInTerm": - addToPayload(opt, ["sspId", "lcid", "termId", "termSetId"]); - break; - case "GetChildTermsInTermSet": - addToPayload(opt, ["sspId", "lcid", "termSetId"]); - break; - case "GetKeywordTermsByGuids": - addToPayload(opt, ["termIds", "lcid"]); - break; - case "GetTermsByLabel": - addToPayload(opt, ["label", "lcid", "matchOption", "resultCollectionSize", "termIds", "addIfNotFound"]); - break; - case "GetTermSets": - addToPayload(opt, ["sharedServiceId", "termSetId", "lcid", "clientTimeStamps", "clientVersions"]); - break; - - // USERS AND GROUPS OPERATIONS - case "AddGroup": - addToPayload(opt, ["groupName", "ownerIdentifier", "ownerType", "defaultUserLoginName", "description"]); - break; - case "AddGroupToRole": - addToPayload(opt, ["groupName", "roleName"]); - break; - case "AddRole": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddRoleDef": - addToPayload(opt, ["roleName", "description", "permissionMask"]); - break; - case "AddUserCollectionToGroup": - addToPayload(opt, ["groupName", "usersInfoXml"]); - break; - case "AddUserCollectionToRole": - addToPayload(opt, ["roleName", "usersInfoXml"]); - break; - case "AddUserToGroup": - addToPayload(opt, ["groupName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "AddUserToRole": - addToPayload(opt, ["roleName", "userName", "userLoginName", "userEmail", "userNotes"]); - break; - case "GetAllUserCollectionFromWeb": - break; - case "GetGroupCollection": - addToPayload(opt, ["groupNamesXml"]); - break; - case "GetGroupCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetGroupCollectionFromSite": - break; - case "GetGroupCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetGroupCollectionFromWeb": - break; - case "GetGroupInfo": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollection": - addToPayload(opt, ["roleNamesXml"]); - break; - case "GetRoleCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetRoleCollectionFromUser": - addToPayload(opt, ["userLoginName"]); - break; - case "GetRoleCollectionFromWeb": - break; - case "GetRoleInfo": - addToPayload(opt, ["roleName"]); - break; - case "GetRolesAndPermissionsForCurrentUser": - break; - case "GetRolesAndPermissionsForSite": - break; - case "GetUserCollection": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "GetUserCollectionFromGroup": - addToPayload(opt, ["groupName"]); - break; - case "GetUserCollectionFromRole": - addToPayload(opt, ["roleName"]); - break; - case "GetUserCollectionFromSite": - break; - case "GetUserCollectionFromWeb": - break; - case "GetUserInfo": - addToPayload(opt, ["userLoginName"]); - break; - case "GetUserLoginFromEmail": - addToPayload(opt, ["emailXml"]); - break; - case "RemoveGroup": - addToPayload(opt, ["groupName"]); - break; - case "RemoveGroupFromRole": - addToPayload(opt, ["roleName", "groupName"]); - break; - case "RemoveRole": - addToPayload(opt, ["roleName"]); - break; - case "RemoveUserCollectionFromGroup": - addToPayload(opt, ["groupName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromRole": - addToPayload(opt, ["roleName", "userLoginNamesXml"]); - break; - case "RemoveUserCollectionFromSite": - addToPayload(opt, ["userLoginNamesXml"]); - break; - case "RemoveUserFromGroup": - addToPayload(opt, ["groupName", "userLoginName"]); - break; - case "RemoveUserFromRole": - addToPayload(opt, ["roleName", "userLoginName"]); - break; - case "RemoveUserFromSite": - addToPayload(opt, ["userLoginName"]); - break; - case "RemoveUserFromWeb": - addToPayload(opt, ["userLoginName"]); - break; - case "UpdateGroupInfo": - addToPayload(opt, ["oldGroupName", "groupName", "ownerIdentifier", "ownerType", "description"]); - break; - case "UpdateRoleDefInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateRoleInfo": - addToPayload(opt, ["oldRoleName", "roleName", "description", "permissionMask"]); - break; - case "UpdateUserInfo": - addToPayload(opt, ["userLoginName", "userName", "userEmail", "userNotes"]); - break; - - // USERPROFILESERVICE OPERATIONS - case "AddColleague": - addToPayload(opt, ["accountName", "colleagueAccountName", "group", "privacy", "isInWorkGroup"]); - break; - case "AddLink": - addToPayload(opt, ["accountName", "name", "url", "group", "privacy"]); - break; - case "AddMembership": - addToPayload(opt, ["accountName", "membershipInfo", "group", "privacy"]); - break; - case "AddPinnedLink": - addToPayload(opt, ["accountName", "name", "url"]); - break; - case "CreateMemberGroup": - addToPayload(opt, ["membershipInfo"]); - break; - case "CreateUserProfileByAccountName": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonManager": - addToPayload(opt, ["accountName"]); - break; - case "GetCommonMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetInCommon": - addToPayload(opt, ["accountName"]); - break; - case "GetPropertyChoiceList": - addToPayload(opt, ["propertyName"]); - break; - case "GetUserColleagues": - addToPayload(opt, ["accountName"]); - break; - case "GetUserLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserMemberships": - addToPayload(opt, ["accountName"]); - break; - case "GetUserPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "GetUserProfileByGuid": - addToPayload(opt, ["guid"]); - break; - case "GetUserProfileByIndex": - addToPayload(opt, ["index"]); - break; - case "GetUserProfileByName": - // Note that this operation is inconsistent with the others, using AccountName rather than accountName - if(typeof opt.accountName !== "undefined" && opt.accountName.length > 0) { - addToPayload(opt, [["AccountName", "accountName"]]); - } else { - addToPayload(opt, ["AccountName"]); - } - break; - case "GetUserProfileCount": - break; - case "GetUserProfileSchema": - break; - case "ModifyUserPropertyByAccountName": - addToPayload(opt, ["accountName", "newData"]); - break; - case "RemoveAllColleagues": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllMemberships": - addToPayload(opt, ["accountName"]); - break; - case "RemoveAllPinnedLinks": - addToPayload(opt, ["accountName"]); - break; - case "RemoveColleague": - addToPayload(opt, ["accountName", "colleagueAccountName"]); - break; - case "RemoveLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "RemoveMembership": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference"]); - break; - case "RemovePinnedLink": - addToPayload(opt, ["accountName", "id"]); - break; - case "UpdateColleaguePrivacy": - addToPayload(opt, ["accountName", "colleagueAccountName", "newPrivacy"]); - break; - case "UpdateLink": - addToPayload(opt, ["accountName", "data"]); - break; - case "UpdateMembershipPrivacy": - addToPayload(opt, ["accountName", "sourceInternal", "sourceReference", "newPrivacy"]); - break; - case "UpdatePinnedLink ": - addToPayload(opt, ["accountName", "data"]); - break; - - // VERSIONS OPERATIONS - case "DeleteAllVersions": - addToPayload(opt, ["fileName"]); - break; - case "DeleteVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - case "GetVersions": - addToPayload(opt, ["fileName"]); - break; - case "RestoreVersion": - addToPayload(opt, ["fileName", "fileVersion"]); - break; - - // VIEW OPERATIONS - case "AddView": - addToPayload(opt, ["listName", "viewName", "viewFields", "query", "rowLimit", "rowLimit", "type", "makeViewDefault"]); - break; - case "DeleteView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetView": - addToPayload(opt, ["listName", "viewName"]); - break; - case "GetViewCollection": - addToPayload(opt, ["listName"]); - break; - case "GetViewHtml": - addToPayload(opt, ["listName", "viewName"]); - break; - case "UpdateView": - addToPayload(opt, ["listName", "viewName", "viewProperties", "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - case "UpdateViewHtml": - addToPayload(opt, ["listName", "viewName", "viewProperties", "toolbar", "viewHeader", "viewBody", "viewFooter", "viewEmpty", "rowLimitExceeded", - "query", "viewFields", "aggregations", "formats", "rowLimit"]); - break; - - // WEBPARTPAGES OPERATIONS - case "AddWebPart": - addToPayload(opt, ["pageUrl", "webPartXml", "storage"]); - break; - case "AddWebPartToZone": - addToPayload(opt, ["pageUrl", "webPartXml", "storage", "zoneId", "zoneIndex"]); - break; - case "GetWebPart2": - addToPayload(opt, ["pageUrl", "storageKey", "storage", "behavior"]); - break; - case "GetWebPartPage": - addToPayload(opt, ["documentName", "behavior"]); - break; - case "GetWebPartProperties": - addToPayload(opt, ["pageUrl", "storage"]); - break; - case "GetWebPartProperties2": - addToPayload(opt, ["pageUrl", "storage", "behavior"]); - break; - - // WEBS OPERATIONS - case "Webs.CreateContentType": - addToPayload(opt, ["displayName", "parentType", "newFields", "contentTypeProperties"]); - break; - case "GetColumns": - addToPayload(opt, ["webUrl"]); - break; - case "GetContentType": - addToPayload(opt, ["contentTypeId"]); - break; - case "GetContentTypes": - break; - case "GetCustomizedPageStatus": - addToPayload(opt, ["fileUrl"]); - break; - case "GetListTemplates": - break; - case "GetObjectIdFromUrl": - addToPayload(opt, ["objectUrl"]); - break; - case "GetWeb": - addToPayload(opt, [["webUrl", "webURL"]]); - break; - case "GetWebCollection": - break; - case "GetAllSubWebCollection": - break; - case "UpdateColumns": - addToPayload(opt, ["newFields", "updateFields", "deleteFields"]); - break; - case "Webs.UpdateContentType": - addToPayload(opt, ["contentTypeId", "contentTypeProperties", "newFields", "updateFields", "deleteFields"]); - break; - case "WebUrlFromPageUrl": - addToPayload(opt, [["pageUrl", "pageURL"]]); - break; - - // WORKFLOW OPERATIONS - case "AlterToDo": - addToPayload(opt, ["item", "todoId", "todoListId", "taskData"]); - break; - case "GetTemplatesForItem": - addToPayload(opt, ["item"]); - break; - case "GetToDosForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowDataForItem": - addToPayload(opt, ["item"]); - break; - case "GetWorkflowTaskData": - addToPayload(opt, ["item", "listId", "taskId"]); - break; - case "StartWorkflow": - addToPayload(opt, ["item", "templateId", "workflowParameters"]); - break; - - default: - break; - } - - // Glue together the pieces of the SOAP message - var msg = SOAPEnvelope.header + SOAPEnvelope.opheader + SOAPEnvelope.payload + SOAPEnvelope.opfooter + SOAPEnvelope.footer; - - // Check to see if we've already cached the results - var cachedPromise; - if(opt.cacheXML) { - cachedPromise = promisesCache[msg]; - } - - if(typeof cachedPromise === "undefined") { - - // Finally, make the Ajax call - promisesCache[msg] = $.ajax({ - // The relative URL for the AJAX call - url: ajaxURL, - // By default, the AJAX calls are asynchronous. You can specify false to require a synchronous call. - async: opt.async, - // Before sending the msg, need to send the request header - beforeSend: function (xhr) { - // If we need to pass the SOAPAction, do so - if(WSops[opt.operation][1]) { - xhr.setRequestHeader("SOAPAction", SOAPAction); - } - }, - // Always a POST - type: "POST", - // Here is the SOAP request we've built above - data: msg, - // We're getting XML; tell jQuery so that it doesn't need to do a best guess - dataType: "xml", - // and this is its content type - contentType: "text/xml;charset='utf-8'", - complete: function(xData, Status) { - // When the call is complete, call the completefunc if there is one - if($.isFunction(opt.completefunc)) { - opt.completefunc(xData, Status); - - } - } - }); - -/* spservicesPromise.then( - function() { - // Cache the promise if requested - if(opt.cacheXML) { - promisesCache[msg] = spservicesPromise; - } - }, - function() { - // TODO: Allow for fail function - } - ); -*/ - // Return the promise -// return spservicesPromise; - return promisesCache[msg]; - - } else { - // Call the completefunc if there is one - if($.isFunction(opt.completefunc)) { - opt.completefunc(cachedPromise, null); - } - // Return the cached promise - return cachedPromise; - } - - }; // End $.fn.SPServices - - // Defaults added as a function in our library means that the caller can override the defaults - // for their session by calling this function. Each operation requires a different set of options; - // we allow for all in a standardized way. - $.fn.SPServices.defaults = { - - cacheXML: false, // If true, we'll cache the XML results with jQuery's .data() function - operation: "", // The Web Service operation - webURL: "", // URL of the target Web - makeViewDefault: false, // true to make the view the default view for the list - - // For operations requiring CAML, these options will override any abstractions - CAMLViewName: "", // View name in CAML format. - CAMLQuery: "", // Query in CAML format - CAMLViewFields: "", // View fields in CAML format - CAMLRowLimit: 0, // Row limit as a string representation of an integer - CAMLQueryOptions: "", // Query options in CAML format - - // Abstractions for CAML syntax - batchCmd: "Update", // Method Cmd for UpdateListItems - valuepairs: [], // Fieldname / Fieldvalue pairs for UpdateListItems - - // As of v0.7.1, removed all options which were assigned an empty string ("") - DestinationUrls: [], // Array of destination URLs for copy operations - behavior: "Version3", // An SPWebServiceBehavior indicating whether the client supports Windows SharePoint Services 2.0 or Windows SharePoint Services 3.0: {Version2 | Version3 } - storage: "Shared", // A Storage value indicating how the Web Part is stored: {None | Personal | Shared} - objectType: "List", // objectType for operations which require it - cancelMeeting: true, // true to delete a meeting;false to remove its association with a Meeting Workspace site - nonGregorian: false, // true if the calendar is set to a format other than Gregorian;otherwise, false. - fClaim: false, // Specifies if the action is a claim or a release. Specifies true for a claim and false for a release. - recurrenceId: 0, // The recurrence ID for the meeting that needs its association removed. This parameter can be set to 0 for single-instance meetings. - sequence: 0, // An integer that is used to determine the ordering of updates in case they arrive out of sequence. Updates with a lower-than-current sequence are discarded. If the sequence is equal to the current sequence, the latest update are applied. - maximumItemsToReturn: 0, // SocialDataService maximumItemsToReturn - startIndex: 0, // SocialDataService startIndex - isHighPriority: false, // SocialDataService isHighPriority - isPrivate: false, // SocialDataService isPrivate - rating: 1, // SocialDataService rating - maxResults: 10, // Unless otherwise specified, the maximum number of principals that can be returned from a provider is 10. - principalType: "User", // Specifies user scope and other information: [None | User | DistributionList | SecurityGroup | SharePointGroup | All] - - async: true, // Allow the user to force async - completefunc: null // Function to call on completion - - }; // End $.fn.SPServices.defaults - - // Function to determine the current Web's URL. We need this for successful Ajax calls. - // The function is also available as a public function. - $.fn.SPServices.SPGetCurrentSite = function() { - - // We've already determined the current site... - if(currentContext.thisSite.length > 0) { - return currentContext.thisSite; - } - - // If we still don't know the current site, we call WebUrlFromPageUrlResult. - var msg = SOAPEnvelope.header + - "" + - ((location.href.indexOf("?") > 0) ? location.href.substr(0, location.href.indexOf("?")) : location.href) + - "" + - SOAPEnvelope.footer; - $.ajax({ - async: false, // Need this to be synchronous so we're assured of a valid value - url: "/_vti_bin/Webs.asmx", - type: "POST", - data: msg, - dataType: "xml", - contentType: "text/xml;charset=\"utf-8\"", - complete: function (xData, Status) { - currentContext.thisSite = $(xData.responseXML).find("WebUrlFromPageUrlResult").text(); - } - }); - - return currentContext.thisSite; // Return the URL - - }; // End $.fn.SPServices.SPGetCurrentSite - - // Function to set up cascading dropdowns on a SharePoint form - // (Newform.aspx, EditForm.aspx, or any other customized form.) - $.fn.SPServices.SPCascadeDropdowns = function(options) { - - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationships list - relationshipList: "", // The name of the list which contains the parent/child relationships - relationshipListParentColumn: "", // The internal name of the parent column in the relationship list - relationshipListChildColumn: "", // The internal name of the child column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListChildColumn - parentColumn: "", // The display name of the parent column in the form - childColumn: "", // The display name of the child column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relationshipList - CAMLQueryOptions: "FALSE", // [Optional] For power users, ability to specify Query Options - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of childColumn. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - simpleChild: false, // [Optional] If set to true and childColumn is a complex dropdown, convert it to a simple dropdown - selectSingleOption: false, // [Optional] If set to true and there is only a single child option, select it - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - - var thisParentSetUp = false; - var thisFunction = "SPServices.SPCascadeDropdowns"; - - // Find the parent column's select (dropdown) - var parentSelect = new DropdownCtl(opt.parentColumn); - if(parentSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "parentColumn: " + opt.parentColumn , TXTColumnNotFound);return;} - - // Find the child column's select (dropdown) - var childSelect = new DropdownCtl(opt.childColumn); - if(childSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "childColumn: " + opt.childColumn, TXTColumnNotFound);return;} - - // If requested and the childColumn is a complex dropdown, convert to a simple dropdown - if(opt.simpleChild === true && childSelect.Type === "C") { - $().SPServices.SPComplexToSimpleDropdown({ - columnName: opt.childColumn - }); - // Set the childSelect to reference the new simple dropdown - childSelect = new DropdownCtl(opt.childColumn); - } - - var childColumnRequired, childColumnStatic; - - // Get information about the childColumn from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.childColumn + "']").each(function() { - // Determine whether childColumn is Required - childColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - childColumnStatic = $(this).attr("StaticName"); - // Stop looking; we're done - return false; - }); - }); - } - }); - - // Save data about each child column on the parent - var childColumn = {opt: opt, childSelect: childSelect, childColumnStatic: childColumnStatic, childColumnRequired: childColumnRequired}; - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - - // If this is the first child for this parent, then create the data object to hold the settings - if(typeof childColumns === "undefined") { - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", [childColumn]); - // If we already have a data object for this parent, then add the setting for this child to it - } else { - childColumns.push(childColumn); - parentSelect.Obj.data("SPCascadeDropdownsChildColumns", childColumns); - thisParentSetUp = true; - } - - // We only need to bind to the event(s) if we haven't already done so - if(!thisParentSetUp) { - switch(parentSelect.Type) { - // Plain old select - case "S": - parentSelect.Obj.bind("change", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='"+ parentSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - break; - // Multi-select hybrid - case "M": - // Handle the dblclick on the candidate select - parentSelect.Obj.bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle the dblclick on the selected values - parentSelect.Obj.closest("span").find("select[id$='SelectResult']").bind("dblclick", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - // Handle a button click - parentSelect.Obj.closest("span").find("button").each(function() { - $(this).bind("click", function() { - cascadeDropdown(opt.parentColumn, parentSelect); - }); - }); - break; - default: - break; - } - } - // Fire the change to set the initially allowable values - cascadeDropdown(opt.parentColumn, parentSelect); - - }; // End $.fn.SPServices.SPCascadeDropdowns - - function cascadeDropdown(parentColumn, parentSelect) { - var choices = ""; - var parentSelectSelected; - var childSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var numChildOptions; - var firstChildOptionId; - var firstChildOptionValue; - - // Filter each child column - var childColumns = parentSelect.Obj.data("SPCascadeDropdownsChildColumns"); - $(childColumns).each(function() { - - // Break out the data objects for this child column - var opt = this.opt; - var childSelect = this.childSelect; - var childColumnStatic = this.childColumnStatic; - var childColumnRequired = this.childColumnRequired; - var currentSelection; - - // Get the parent column selection(s) - parentSelectSelected = getDropdownSelected(parentSelect, opt.matchOnId); - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C" or "M", as there are multiple propertychanges - // which don't require any action. The attribute will be unique per child column in case there are - // multiple children for a given parent. - var allParentSelections = parentSelectSelected.join(";#"); - if(parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic) === allParentSelections) { - return; - } - parentSelect.Obj.data("SPCascadeDropdown_Selected_" + childColumnStatic, allParentSelections); - - // Get the current child column selection(s) - childSelectSelected = getDropdownSelected(childSelect, true); - - // Find the important bits of the multi-select - if(childSelect.Type === "M") { - MultiLookupPickerdata = childSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[childSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - currentSelection = childSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - } - - // When the parent column's selected option changes, get the matching items from the relationship list - // Get the list items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListChildColumn; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - // Build up the criteria for inclusion - if(parentSelectSelected.length === 0) { - // Handle the case where no values are selected in multi-selects - camlQuery += ""; - } else if(parentSelectSelected.length === 1) { - // Only one value is selected - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[0]) + ""; - } else { - var compound = (parentSelectSelected.length > 2) ? true : false; - for(i=0; i < (parentSelectSelected.length - 1); i++) { - camlQuery += ""; - } - for(i=0; i < parentSelectSelected.length; i++) { - camlQuery += "" : "'/>") + - escapeColumnValue(parentSelectSelected[i]) + ""; - if(i>0 && (i < (parentSelectSelected.length - 1)) && compound) { - camlQuery += ""; - } - } - camlQuery += ""; - } - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - - // Make sure we don't get any items which don't have the child value - camlQuery += ""; - - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the child column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the currently selected parent column's value - CAMLQuery: camlQuery, - // Only get the parent and child columns - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: opt.CAMLQueryOptions, - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var thisFunction = "SPServices.SPCascadeDropdowns"; - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListParentColumn: " + opt.relationshipListParentColumn + " or " + - "relationshipListChildColumn: " + opt.relationshipListChildColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(childSelect.Type) { - case "S": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!childColumnRequired && (opt.promptText.length > 0)) { - childSelect.Obj.append(""); - } else if(!childColumnRequired){ - childSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = childColumnRequired ? "" : opt.noneText + "|0"; - childSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(childSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - // Get the count of items returned and save it so that we can select if it's a single option - // The item count is stored thus: - numChildOptions = parseFloat($(xData.responseXML).SPFilterNode("rs:data").attr("ItemCount")); - - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOption = {}; - - // If relationshipListChildColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListChildColumn); - - if(typeof thisValue !== "undefined" && thisValue.indexOf(";#") > 0) { - thisOption = new SplitIndex(thisValue); - } else { - thisOption.id = $(this).attr("ows_ID"); - thisOption.value = thisValue; - } - - // If the relationshipListChildColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOption.id should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOption.id)) { - thisOption.id = $(this).attr("ows_ID"); - } - - // Save the id and value for the first child option in case we need to select it (selectSingleOption option is true) - firstChildOptionId = thisOption.id; - firstChildOptionValue = thisOption.value; - - switch(childSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === childSelectSelected[0]) ? " selected='selected'" : ""; - childSelect.Obj.append("" + thisOption.value + ""); - break; - case "C": - if(thisOption.id === childSelectSelected[0]) { - childSelect.Obj.attr("value", thisOption.value); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOption.value + "|" + thisOption.id; - break; - case "M": - childSelect.Obj.append(""); - newMultiLookupPickerdata += thisOption.id + "|t" + thisOption.value + "|t |t |t"; - break; - default: - break; - } - }); - - switch(childSelect.Type) { - case "S": - childSelect.Obj.trigger("change"); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - $(childSelect.Obj).find("option[value!='0']:first").attr("selected", "selected"); - } - break; - case "C": - // Set the allowable choices - childSelect.Obj.attr("choices", choices); - // If there is only one option and the selectSingleOption option is true, then select it - if(numChildOptions === 1 && opt.selectSingleOption === true) { - // Set the input element value - $(childSelect.Obj).attr("value", firstChildOptionValue); - // Set the value of the optHid input element - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(firstChildOptionId); - } - // If there's no selection, then remove the value in the associated hidden input element (optHid) - if(childSelect.Obj.val() === "") { - $("input[id='" + childSelect.Obj.attr("optHid") + "']").val(""); - } - break; - case "M": - // Clear the master - master.data = ""; - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - - // Clear any prior selections that are no longer valid or aren't selected - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - var thisValue = $(this).html(); - $(this).attr("selected", "selected"); - $(childSelect.Obj).find("option").filter(function() { - return $(this).text() === thisValue.replace(/&/, "&"); - }).each(function() { - if($(this).html() === thisValue) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - - // Hide any options in the candidate list which are already selected - $(childSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - childSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }); // $(childColumns).each(function() - - } // End cascadeDropdown - - - // function to convert complex dropdowns to simple dropdowns - $.fn.SPServices.SPComplexToSimpleDropdown = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox("SPServices.SPComplexToSimpleDropdown", "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // If we don't have a complex dropdown, then there is nothing to do - if(columnSelect.Type !== "C") { return; } - - // The available options are stored in the choices attribute of the complex dropdowns's input element... - var choices = $(columnSelect.Obj).attr("choices").split("|"); - // The optHid attribute contains the id of a hidden input element which stores the selected value for the commit - var columnOptHid = $(columnSelect.Obj).attr("optHid"); - var columnOptHidInput = $("input[id='" + columnOptHid + "']"); - // We need to know which option is selected already, if any - var complexSelectSelectedId = $("input[id='" + columnOptHid + "']").val(); - - // Build up the simple dropdown, giving it an easy to select id - var simpleSelectId = genContainerId("SPComplexToSimpleDropdown", opt.columnName); - - var simpleSelect = ""; - - // Append the new simple select to the form - $(columnSelect.Obj).closest("td").prepend(simpleSelect); - - // Remove the complex dropdown functionality since we don't need it anymore... - $(columnSelect.Obj).closest("span").find("img").remove(); - // ...and hide the input element - $(columnSelect.Obj).closest("span").find("input").hide(); - - // When the simple select changes... - $("#" + simpleSelectId).change(function() { - var thisVal = $(this).val(); - // ...set the optHid input element's value to the valus of the selected option... - columnOptHidInput.val(thisVal); - // ...and save the selected value as the hidden input's value only if the value is not equal to "0" (None) - $(columnSelect.Obj).val($(this).find("option[value='" + (thisVal !== "0" ? thisVal : "") + "']").html()); - }); - // Trigger a change to ensure that the selected value registers in the complex dropdown - $("#" + simpleSelectId).trigger("change"); - - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - - }; // End $.fn.SPServices.SPConvertToSimpleDropdown - - - // Function to display related information when an option is selected on a form. - $.fn.SPServices.SPDisplayRelatedInfo = function(options) { - - var opt = $.extend({}, { - columnName: "", // The display name of the column in the form - relatedWebURL: "", // [Optional] The name of the Web (site) which contains the related list - relatedList: "", // The name of the list which contains the additional information - relatedListColumn: "", // The internal name of the related column in the related list - relatedColumns: [], // An array of related columns to display - displayFormat: "table", // The format to use in displaying the related information. Possible values are: [table, list] - headerCSSClass: "ms-vh2", // CSS class for the table headers - rowCSSClass: "ms-vb", // CSS class for the table rows - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be ed with the default query on the relatedList - numChars: 0, // If used on an input column (not a dropdown), no matching will occur until at least this number of characters has been entered - matchType: "Eq", // If used on an input column (not a dropdown), type of match. Can be any valid CAML comparison operator, most often "Eq" or "BeginsWith" - matchOnId: false, // By default, we match on the lookup's text value. If matchOnId is true, we'll match on the lookup id instead. - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var divId; - var relatedColumnsXML = []; - var relatedListXML; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return; } - - // Generate a unique id for the container - divId = genContainerId("SPDisplayRelatedInfo", opt.columnName); - - // Get information about the related list and its columns - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - completefunc: function(xData) { - // If debug is on, notify about an error - $(xData.responseXML).find("faultcode").each(function() { - if(opt.debug) {errBox(thisFunction, "relatedList: " + opt.relatedList, "List not found"); return; } - }); - // Get info about the related list - relatedListXML = $(xData.responseXML).find("List"); - // Save the information about each column requested - for (i=0; i < opt.relatedColumns.length; i++) { - relatedColumnsXML[i] = $(xData.responseXML).find("Fields > Field[Name='" + opt.relatedColumns[i] + "']"); - } - } - }); - - switch(columnSelect.Type) { - // Plain old select - case "S": - columnSelect.Obj.bind("change", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Input / Select hybrid - case "C": - // Bind to any change on the hidden input element - $("input[id='" + columnSelect.Obj.attr("optHid") + "']").bind("propertychange", function() { - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - }); - break; - // Multi-select hybrid - case "M": - if(opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, "Multi-select columns not supported by this function"); } - break; - default: - break; - } - // Fire the change to set the initially allowable values - showRelated(opt, divId, relatedListXML, relatedColumnsXML); - - }; // End $.fn.SPServices.SPDisplayRelatedInfo - - function showRelated(opt, divId, relatedListXML, relatedColumnsXML) { - - var columnSelectSelected = null; - var thisFunction = "SPServices.SPDisplayRelatedInfo"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, opt.matchOnId); - if(columnSelect.Type === "C" && opt.numChars > 0 && columnSelectSelected[0].length < opt.numChars) { - return; - } - - // If the selection hasn't changed, then there's nothing to do right now. This is useful to reduce - // the number of Web Service calls when the parentSelect.Type = "C", as there are multiple propertychanges - // which don't require any action. - if(columnSelect.Obj.attr("showRelatedSelected") === columnSelectSelected[0]) { - return; - } - columnSelect.Obj.attr("showRelatedSelected", columnSelectSelected[0]); - - // Remove the old container... - $("#" + divId).remove(); - // ...and append a new, empty one - columnSelect.Obj.parent().append("
    "); - - // Get the list items which match the current selection - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - - camlQuery += "" : "'/>") + - escapeColumnValue(columnSelectSelected[0]) + ""; - - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - var viewFields = " "; - for (i=0; i < opt.relatedColumns.length; i++) { - viewFields += ""; - } - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.relatedWebURL, - listName: opt.relatedList, - // Filter based on the column's currently selected value - CAMLQuery: camlQuery, - CAMLViewFields: "" + viewFields + "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relatedListColumn: " + opt.relatedListColumn, - "Column not found in relatedList " + opt.relatedList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relatedList: " + opt.relatedList, - "List not found"); - } - return; - }); - - var outString; - // Output each row - switch(opt.displayFormat) { - // Only implementing the table format in the first iteration (v0.2.9) - case "table": - outString = ""; - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === "undefined" && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - } - outString += ""; - // Add an option for each child item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - outString += ""; - for (i=0; i < opt.relatedColumns.length; i++) { - outString += ""; - } - outString += ""; - }); - outString += "
    " + relatedColumnsXML[i].attr("DisplayName") + "
    " + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
    "; - break; - // list format implemented in v0.5.0. Still table-based, but vertical orientation. - case "list": - outString = ""; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - for (i=0; i < opt.relatedColumns.length; i++) { - if(typeof relatedColumnsXML[i] === "undefined" && opt.debug) {errBox(thisFunction, "columnName: " + opt.relatedColumns[i], "Column not found in relatedList"); return; } - outString += ""; - outString += ""; - outString += ""; - outString += ""; - } - }); - outString += "
    " + relatedColumnsXML[i].attr("DisplayName") + "" + showColumn(relatedListXML, relatedColumnsXML[i], $(this).attr("ows_" + opt.relatedColumns[i]), opt) + "
    "; - break; - default: - break; - } - // Write out the results - $("#" + divId).html(outString); - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - } // End showRelated - - // Function to filter a lookup based dropdown - $.fn.SPServices.SPFilterDropdown = function(options) { - var opt = $.extend({}, { - relationshipWebURL: "", // [Optional] The name of the Web (site) which contains the relationshipList - relationshipList: "", // The name of the list which contains the lookup values - relationshipListColumn: "", // The internal name of the column in the relationship list - relationshipListSortColumn: "", // [Optional] If specified, sort the options in the dropdown by this column, - // otherwise the options are sorted by relationshipListColumn - relationshipListSortAscending: true, // [Optional] By default, the sort is ascending. If false, descending - columnName: "", // The display name of the column in the form - listName: $().SPServices.SPListNameFromUrl(), // The list the form is working with. This is useful if the form is not in the list context. - promptText: "", // [DEPRECATED] Text to use as prompt. If included, {0} will be replaced with the value of columnName. IOrignal value "Choose {0}..." - noneText: "(None)", // [Optional] Text to use for the (None) selection. Provided for non-English language support. - CAMLQuery: "", // This CAML fragment will be applied to the relationshipList - CAMLQueryOptions: "FALSE", // Need this to mirror SharePoint's behavior, but it can be overridden - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages; if false, run silent - }, options); - - var choices = ""; - var columnSelectSelected = null; - var master; - var MultiLookupPickerdata; - var newMultiLookupPickerdata; - var columnColumnRequired; - var thisFunction = "SPServices.SPFilterDropdown"; - - // Find the column's select (dropdown) - var columnSelect = new DropdownCtl(opt.columnName); - if(columnSelect.Obj.html() === null && opt.debug) {errBox(thisFunction, "columnName: " + opt.columnName, TXTColumnNotFound); return;} - - // Get the current column selection(s) - columnSelectSelected = getDropdownSelected(columnSelect, true); - - // Get the relationshipList items which match the current selection - var sortColumn = (opt.relationshipListSortColumn.length > 0) ? opt.relationshipListSortColumn : opt.relationshipListColumn; - var sortOrder = (opt.relationshipListSortAscending === true) ? "" : "Ascending='FALSE'"; - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery; - } - camlQuery += ""; - - // Get information about columnName from the current list - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName, - completefunc: function(xData) { - $(xData.responseXML).find("Fields").each(function() { - $(this).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName is Required - columnColumnRequired = ($(this).attr("Required") === "TRUE") ? true : false; - // Stop looking; we're done - return false; - }); - }); - } - }); - - $().SPServices({ - operation: "GetListItems", - // Force sync so that we have the right values for the column onchange trigger - async: false, - webURL: opt.relationshipWebURL, - listName: opt.relationshipList, - // Filter based on the specified CAML - CAMLQuery: camlQuery, - // Only get the columnName's data (plus columns we can't prevent) - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - // Even though setting IncludeMandatoryColumns to FALSE doesn't work as the docs describe, it fixes a bug in GetListItems with mandatory multi-selects - CAMLQueryOptions: opt.CAMLQueryOptions, - completefunc: function(xData) { - - // Handle errors - $(xData.responseXML).find("errorstring").each(function() { - var errorText = $(this).text(); - if(opt.debug && errorText === "One or more field types are not installed properly. Go to the list settings page to delete these fields.") { - errBox(thisFunction, - "relationshipListColumn: " + opt.relationshipListColumn, - "Not found in relationshipList " + opt.relationshipList); - } else if (opt.debug && errorText === "Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).") { - errBox(thisFunction, - "relationshipList: " + opt.relationshipList, - "List not found"); - } - return; - }); - - // Add an explanatory prompt - switch(columnSelect.Type) { - case "S": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - // If the column is required or the promptText option is empty, don't add the prompt text - if(!columnColumnRequired && (opt.promptText.length > 0)) { - columnSelect.Obj.append(""); - } else if(!columnColumnRequired){ - columnSelect.Obj.append(""); - } - break; - case "C": - // If the column is required, don't add the "(None)" option - choices = columnColumnRequired ? "" : opt.noneText + "|0"; - columnSelect.Obj.attr("value", ""); - break; - case "M": - // Remove all of the existing options - $(columnSelect.Obj).find("option").remove(); - newMultiLookupPickerdata = ""; - break; - default: - break; - } - - // Add an option for each item - $(xData.responseXML).SPFilterNode("z:row").each(function() { - - var thisOption = {}; - - // If relationshipListColumn is a Lookup column, then the ID should be for the Lookup value, - // else the ID of the relationshipList item - var thisValue = $(this).attr("ows_" + opt.relationshipListColumn); - - if(typeof thisValue !== "undefined" && thisValue.indexOf(";#") > 0) { - thisOption = new SplitIndex(thisValue); - } else { - thisOption.id = $(this).attr("ows_ID"); - thisOption.value = thisValue; - } - - // If the relationshipListColumn is a calculated column, then the value isn't preceded by the ID, - // but by the datatype. In this case, thisOption.id should be the ID of the relationshipList item. - // e.g., float;#12345.67 - if(isNaN(thisOption.id)) { - thisOption.id = $(this).attr("ows_ID"); - } - - switch(columnSelect.Type) { - case "S": - var selected = ($(this).attr("ows_ID") === columnSelectSelected[0]) ? " selected='selected'" : ""; - columnSelect.Obj.append("" + thisOption.value + ""); - break; - case "C": - if(thisOption.id === columnSelectSelected[0]) { - columnSelect.Obj.attr("value", thisOption.value); - } - choices = choices + ((choices.length > 0) ? "|" : "") + thisOption.value + "|" + thisOption.id; - break; - case "M": - columnSelect.Obj.append(""); - newMultiLookupPickerdata += thisOption.id + "|t" + thisOption.value + "|t |t |t"; - break; - default: - break; - } - }); - - switch(columnSelect.Type) { - case "S": - columnSelect.Obj.trigger("change"); - break; - case "C": - columnSelect.Obj.attr("choices", choices); - columnSelect.Obj.trigger("propertychange"); - break; - case "M": - // Find the important bits of the multi-select - MultiLookupPickerdata = columnSelect.Obj.closest("span").find("input[name$='MultiLookupPicker$data']"); - master = window[columnSelect.Obj.closest("tr").find("button[id$='AddButton']").attr("id").replace(/AddButton/,'MultiLookupPicker_m')]; - var currentSelection = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - // Clear the master - master.data = ""; - - MultiLookupPickerdata.attr("value", newMultiLookupPickerdata); - // Clear any prior selections that are no longer valid - $(currentSelection).find("option").each(function() { - var thisSelected = $(this); - $(this).attr("selected", "selected"); - $(columnSelect.Obj).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.removeAttr("selected"); - } - }); - }); - GipRemoveSelectedItems(master); - // Hide any options in the candidate list which are already selected - $(columnSelect.Obj).find("option").each(function() { - var thisSelected = $(this); - $(currentSelection).find("option").each(function() { - if($(this).html() === thisSelected.html()) { - thisSelected.remove(); - } - }); - }); - GipAddSelectedItems(master); - // Set master.data to the newly allowable values - master.data = GipGetGroupData(newMultiLookupPickerdata); - - // Trigger a dblclick so that the child will be cascaded if it is a multiselect. - columnSelect.Obj.trigger("dblclick"); - - break; - default: - break; - } - } - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPFilterDropdown - - - // Utility function to show the results of a Web Service call formatted well in the browser. - $.fn.SPServices.SPDebugXMLHttpResult = function(options) { - - var opt = $.extend({}, { - node: null, // An XMLHttpResult object from an ajax call - indent: 0 // Number of indents - }, options); - - var i; - var NODE_TEXT = 3; - var NODE_CDATA_SECTION = 4; - - var outString = ""; - // For each new subnode, begin rendering a new TABLE - outString += ""; - // DisplayPatterns are a bit unique, so let's handle them differently - if(opt.node.nodeName === "DisplayPattern") { - outString += ""; - // A node which has no children - } else if (!opt.node.hasChildNodes()) { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // A CDATA_SECTION node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_CDATA_SECTION) { - outString += ""; - // A TEXT node - } else if (opt.node.hasChildNodes() && opt.node.firstChild.nodeType === NODE_TEXT) { - outString += ""; - // Handle child nodes - } else { - outString += ""; - if (opt.node.attributes) { - outString += ""; - } - // Since the node has child nodes, recurse - outString += ""; - } - outString += "
    " + opt.node.nodeName + - "
    " + opt.node.nodeName + - "" + ((opt.node.nodeValue !== null) ? checkLink(opt.node.nodeValue) : " ") + "
    " + showAttrs(opt.node) + "
    " + opt.node.nodeName + - "
    " + opt.node.nodeName + - "" + checkLink(opt.node.firstChild.nodeValue) + "
    " + opt.node.nodeName + "
    " + showAttrs(opt.node) + "
    "; - for (i = 0;i < opt.node.childNodes.length; i++) { - outString += $().SPServices.SPDebugXMLHttpResult({ - node: opt.node.childNodes.item(i), - indent: opt.indent + 1 - }); - } - outString += "
    "; - // Return the HTML which we have built up - return outString; - }; // End $.fn.SPServices.SPDebugXMLHttpResult - - // Function which returns the account name for the current user in DOMAIN\username format - $.fn.SPServices.SPGetCurrentUser = function(options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Site Collection. If not specified, the current Web is used. - fieldName: "Name", // Specifies which field to return from the userdisp.aspx page - fieldNames: {}, // Specifies which fields to return from the userdisp.aspx page - added in v0.7.2 to allow multiple columns - debug: false // If true, show error messages; if false, run silent - }, options); - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldName === "ID" && typeof currentContext.thisUserId !== "undefined") { - return currentContext.thisUserId; - } - - var thisField = ""; - var theseFields = {}; - var fieldCount = opt.fieldNames.length > 0 ? opt.fieldNames.length : 1; - var thisUserDisp; - var thisWeb = opt.webURL.length > 0 ? opt.webURL : $().SPServices.SPGetCurrentSite(); - - // Get the UserDisp.aspx page using AJAX - $.ajax({ - // Need this to be synchronous so we're assured of a valid value - async: false, - // Force parameter forces redirection to a page that displays the information as stored in the UserInfo table rather than My Site. - // Adding the extra Query String parameter with the current date/time forces the server to view this as a new request. - url: thisWeb + "/_layouts/userdisp.aspx?Force=True&" + new Date().getTime(), - complete: function (xData, Status) { - thisUserDisp = xData; - } - }); - - for(i=0; i < fieldCount; i++) { - - // The current user's ID is reliably available in an existing JavaScript variable - if(opt.fieldNames[i] === "ID") { - thisField = currentContext.thisUserId; - } else { - var thisTextValue; - if(fieldCount > 1) { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldNames[i] + "\"", "gi"); - } else { - thisTextValue = RegExp("FieldInternalName=\"" + opt.fieldName + "\"", "gi"); - } - $(thisUserDisp.responseText).find("table.ms-formtable td[id^='SPField']").each(function() { - if(thisTextValue.test($(this).html())) { - // Each fieldtype contains a different data type, as indicated by the id - switch($(this).attr("id")) { - case "SPFieldText": - thisField = $(this).text(); - break; - case "SPFieldNote": - thisField = $(this).find("div").html(); - break; - case "SPFieldURL": - thisField = $(this).find("img").attr("src"); - break; - // Just in case - default: - thisField = $(this).text(); - break; - } - // Stop looking; we're done - return false; - } - }); - } - if(opt.fieldNames[i] !== "ID") { - thisField = (typeof thisField !== "undefined") ? thisField.replace(/(^[\s\xA0]+|[\s\xA0]+$)/g, '') : null; - } - if(fieldCount > 1) { - theseFields[opt.fieldNames[i]] = thisField; - } - } - - return (fieldCount > 1) ? theseFields : thisField; - - }; // End $.fn.SPServices.SPGetCurrentUser - - - // Function which provides a link on a Lookup column for the user to follow - // which allows them to add a new value to the Lookup list. - // Based on http://blog.mastykarz.nl/extending-lookup-fields-add-new-item-option/ - // by Waldek Mastykarz - $.fn.SPServices.SPLookupAddNew = function(options) { - - var opt = $.extend({}, { - lookupColumn: "", // The display name of the Lookup column - promptText: "Add new {0}", // Text to use as prompt + column name - newWindow: false, // If true, the link will open in a new window *without* passing the Source. - ContentTypeID: "", // [Optional] Pass the ContentTypeID if you'd like to specify it - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var thisFunction = "SPServices.SPLookupAddNew"; - - // Find the lookup column's select (dropdown) - var lookupSelect = new DropdownCtl(opt.lookupColumn); - if(lookupSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, TXTColumnNotFound);return;} - - var newUrl = ""; - var lookupListUrl = ""; - var lookupColumnStaticName = ""; - // Use GetList for the current list to determine the details for the Lookup column - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $().SPServices.SPListNameFromUrl(), - completefunc: function (xData, Status) { - $(xData.responseXML).find("Field[DisplayName='" + opt.lookupColumn + "']").each(function() { - lookupColumnStaticName = $(this).attr("StaticName"); - // Use GetList for the Lookup column's list to determine the list's URL - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: $(this).attr("List"), - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - lookupListUrl = $(this).attr("WebFullUrl"); - // Need to handle when list is in the root site - lookupListUrl = lookupListUrl !== SLASH ? lookupListUrl + SLASH : lookupListUrl; - }); - } - }); - // Get the NewItem form for the Lookup column's list - newUrl = getListFormUrl($(this).attr("List"), "NewForm"); - // Stop looking;we're done - return false; - }); - } - }); - - if(lookupListUrl.length === 0 && opt.debug) { - errBox(thisFunction, "lookupColumn: " + opt.lookupColumn, "This column does not appear to be a lookup column"); - return; - } - if(newUrl.length > 0) { - // Build the link to the Lookup column's list enclosed in a div with the id="SPLookupAddNew_" + lookupColumnStaticName - var newHref = lookupListUrl + newUrl; - // If requested, open the link in a new window and if requested, pass the ContentTypeID - newHref += opt.newWindow ? - ((opt.ContentTypeID.length > 0) ? "?ContentTypeID=" + opt.ContentTypeID : "") + "' target='_blank'" : - "?" + ((opt.ContentTypeID.length > 0) ? "ContentTypeID=" + opt.ContentTypeID + "&" : "") + "Source=" + escapeUrl(location.href) + "'"; - var newLink = "
    " + " 0) { - camlQuery += ""; - } - camlQuery += "" + userId + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: camlQuery, - CAMLViewFields: "", - CAMLRowLimit: 1, - CAMLQueryOptions: "", - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - lastId = $(this).attr("ows_ID"); - }); - } - }); - return lastId; - }; // End $.fn.SPServices.SPGetLastItemId - - // Function which checks to see if the value for a column on the form is unique in the list. - $.fn.SPServices.SPRequireUnique = function (options) { - - var opt = $.extend({}, { - columnStaticName: "Title", // Name of the column - duplicateAction: 0, // 0 = warn, 1 = prevent - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - initMsg: "This value must be unique.", // Initial message to display after setup - initMsgCSSClass: "ms-vb", // CSS class for initial message - errMsg: "This value is not unique.", // Error message to display if not unique - errMsgCSSClass: "ms-formvalidation", // CSS class for error message - showDupes: false, // If true, show links to the duplicate item(s) after the error message - completefunc: null // Function to call on completion of rendering the change. - }, options); - - // Get the current item's ID from the Query String - var queryStringVals = $().SPServices.SPGetQueryString(); - var thisID = queryStringVals.ID; - currentContext.thisList = $().SPServices.SPListNameFromUrl(); - - // Set the messages based on the options provided - var msg = "{1}
    "; - var firstMsg = msg.replace(/\{0\}/g, opt.initMsgCSSClass).replace(/\{1\}/g, opt.initMsg); - - // We need the DisplayName - var columnDisplayName = $().SPServices.SPGetDisplayFromStatic({ - listName: currentContext.thisList, - columnStaticName: opt.columnStaticName - }); - var columnObj = $("input[Title='" + columnDisplayName + "']"); - $(columnObj).parent().append(firstMsg); - - $(columnObj).blur(function () { - var columnValueIDs = []; - // Get the columnDisplayName's value - var columnValue = $(this).attr("value"); - if(columnValue.length === 0) { return false; } - - // Call the Lists Web Service (GetListItems) to see if the value already exists - $().SPServices({ - operation: "GetListItems", - async: false, - listName: currentContext.thisList, - // Make sure we get all the items, ignoring any filters on the default view. - CAMLQuery: "", - // Filter based on columnStaticName's value - CAMLViewFields: "", - // Override the default view rowlimit and get all appropriate rows - CAMLRowLimit: 0, - completefunc: function(xData) { - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = opt.ignoreCase ? $(this).attr("ows_" + opt.columnStaticName).toUpperCase() : $(this).attr("ows_" + opt.columnStaticName); - // If this value already exists in columnStaticName and it's not the current item, then save the ID in the array - if((testValue === thisValue) && ($(this).attr("ows_ID") !== thisID)) { - columnValueIDs.push([$(this).attr("ows_ID"), $(this).attr("ows_" + opt.columnStaticName)]); - } - }); - } - }); - var newMsg = opt.initMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.initMsgCSSClass); - - $("input[value='OK']:disabled, input[value='Save']:disabled").removeAttr("disabled"); - if(columnValueIDs.length > 0) { - newMsg = opt.errMsg; - $("span#SPRequireUnique" + opt.columnStaticName).html(newMsg).attr("class", opt.errMsgCSSClass); - if(opt.duplicateAction === 1) { - $("input[Title='" + opt.columnDisplayName + "']").focus(); - $("input[value='OK'], input[value='Save']").attr("disabled", "disabled"); - } - if(opt.showDupes) { - var out = " " + columnValueIDs.length + " duplicate item" + (columnValueIDs.length > 1 ? "s" : "") + ": "; - for (i=0;i < columnValueIDs.length; i++) { - out += "
    " + columnValueIDs[i][1] + " "; - } - $("span#SPRequireUnique" + opt.columnStaticName).append(out); - } - } - - }); - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(); - } - }; // End $.fn.SPServices.SPRequireUnique - - // This function returns the DisplayName for a column based on the StaticName. - $.fn.SPServices.SPGetDisplayFromStatic = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnStaticName: "", // StaticName of the column - columnStaticNames: {} // StaticName of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var displayName = ""; - var displayNames = {}; - var nameCount = opt.columnStaticNames.length > 0 ? opt.columnStaticNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - displayNames[opt.columnStaticNames[i]] = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticNames[i] + "']").attr("DisplayName"); - } - } else { - displayName = $(xData.responseXML).find("Field[StaticName='" + opt.columnStaticName + "']").attr("DisplayName"); - } - } - }); - - return (nameCount > 1) ? displayNames : displayName; - - }; // End $.fn.SPServices.SPGetDisplayFromStatic - - // This function returns the StaticName for a column based on the DisplayName. - $.fn.SPServices.SPGetStaticFromDisplay = function (options) { - - var opt = $.extend({}, { - webURL: "", // URL of the target Web. If not specified, the current Web is used. - listName: "", // The name or GUID of the list - columnDisplayName: "", // DisplayName of the column - columnDisplayNames: {} // DisplayNames of the columns - added in v0.7.2 to allow multiple columns - }, options); - - var staticName = ""; - var staticNames = {}; - var nameCount = opt.columnDisplayNames.length > 0 ? opt.columnDisplayNames.length : 1; - - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: opt.listName, - completefunc: function(xData) { - if(nameCount > 1) { - for(i=0; i < nameCount; i++) { - staticNames[opt.columnDisplayNames[i]] = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayNames[i] + "']").attr("StaticName"); - } - } else { - staticName = $(xData.responseXML).find("Field[DisplayName='" + opt.columnDisplayName + "']").attr("StaticName"); - } - } - }); - - return (nameCount > 1) ? staticNames : staticName; - - }; // End $.fn.SPServices.SPGetStaticFromDisplay - - // This function allows you to redirect to a another page from a new item form with the new - // item's ID. This allows chaining of forms from item creation onward. - $.fn.SPServices.SPRedirectWithID = function (options) { - - var opt = $.extend({}, { - redirectUrl: "", // Page for the redirect - qsParamName: "ID" // In some cases, you may want to pass the newly created item's ID with a different - // parameter name than ID. Specify that name here, if needed. - }, options); - - currentContext.thisList = $().SPServices.SPListNameFromUrl(); - var queryStringVals = $().SPServices.SPGetQueryString(); - var lastID = queryStringVals.ID; - var QSList = queryStringVals.List; - var QSRootFolder = queryStringVals.RootFolder; - var QSContentTypeId = queryStringVals.ContentTypeId; - - // On first load, change the form actions to redirect back to this page with the current lastID for this user and the - // original Source. - if(typeof queryStringVals.ID === "undefined") { - lastID = $().SPServices.SPGetLastItemId({ - listName: currentContext.thisList - }); - $("form[name='aspnetForm']").each(function() { - // This page... - var thisUrl = (location.href.indexOf("?") > 0) ? location.href.substring(0, location.href.indexOf("?")) : location.href; - // ... plus the Source if it exists - var thisSource = (typeof queryStringVals.Source === "string") ? - "Source=" + queryStringVals.Source.replace(/\//g, "%2f").replace(/:/g, "%3a") : ""; - - var newQS = []; - if(typeof QSList !== "undefined") { - newQS.push("List=" + QSList); - } - if(typeof QSRootFolder !== "undefined") { - newQS.push("RootFolder=" + QSRootFolder); - } - if(typeof QSContentTypeId !== "undefined") { - newQS.push("ContentTypeId=" + QSContentTypeId); - } - - var newAction = thisUrl + - ((newQS.length > 0) ? ("?" + newQS.join("&") + "&") : "?") + - // Set the Source to point back to this page with the lastID this user has added - "Source=" + thisUrl + - "?ID=" + lastID + - // Pass the original source as RealSource, if present - ((thisSource.length > 0) ? ("%26RealSource=" + queryStringVals.Source) : "") + - // Pass the override RedirectURL, if present - ((typeof queryStringVals.RedirectURL === "string") ? ("%26RedirectURL=" + queryStringVals.RedirectURL) : ""); - $(this).attr("action", newAction); - }); - // If this is the load after the item is saved, wait until the new item has been saved (commits are asynchronous), - // then do the redirect to redirectUrl with the new lastID, passing along the original Source. - } else { - while(queryStringVals.ID === lastID) { - lastID = $().SPServices.SPGetLastItemId({ - listName: currentContext.thisList - }); - } - // If there is a RedirectURL parameter on the Query String, then redirect there instead of the value - // specified in the options (opt.redirectUrl) - var thisRedirectUrl = (typeof queryStringVals.RedirectURL === "string") ? queryStringVals.RedirectURL : opt.redirectUrl; - location.href = thisRedirectUrl + "?" + opt.qsParamName + "=" + lastID + - ((typeof queryStringVals.RealSource === "string") ? ("&Source=" + queryStringVals.RealSource) : ""); - } - }; // End $.fn.SPServices.SPRedirectWithID - - // The SPSetMultiSelectSizes function sets the sizes of the multi-select boxes for a column on a form automagically - // based on the values they contain. The function takes into account the fontSize, fontFamily, fontWeight, etc., in its algorithm. - $.fn.SPServices.SPSetMultiSelectSizes = function (options) { - - var opt = $.extend({}, { - multiSelectColumn: "", - minWidth: 0, - maxWidth: 0, - debug: false - }, options); - - var thisFunction = "SPServices.SPSetMultiSelectSizes"; - - // Find the multi-select column - var thisMultiSelect = new DropdownCtl(opt.multiSelectColumn); - if(thisMultiSelect.Obj.html() === null && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, TXTColumnNotFound);return;} - if(thisMultiSelect.Type !== "M" && opt.debug) { errBox(thisFunction, "multiSelectColumn: " + opt.multiSelectColumn, "Column is not multi-select.");return;} - - var possibleValues = thisMultiSelect.Obj; - var selectedValues = possibleValues.closest("span").find("select[ID$='SelectResult']"); - - // Create a temporary clone of the select to use to determine the appropriate width settings. - // We'll append it to the end of the enclosing span. - var cloneId = genContainerId("SPSetMultiSelectSizes", opt.multiSelectColumn); - var enclosingSpan = possibleValues.closest("span"); - enclosingSpan.append(""); - var cloneObj = enclosingSpan.find("> select"); - cloneObj.css({ - "width": "auto", // We want the clone to resize its width based on the contents - "height": 0, // Just to keep the page clean while we are using the clone - "visibility": "hidden" // And let's keep it hidden - }) - - // Add all the values to the cloned select. First the left (possible values) select... - possibleValues.find("option").each(function() { - cloneObj.append(""); - }); - // ...then the right (selected values) select (in case some values have already been selected) - selectedValues.find("option").each(function() { - cloneObj.append(""); - }); - - // We'll add 5px for a little padding on the right. - var divWidth = cloneObj.width() + 5; - var newDivWidth = divWidth; - if(opt.minWidth > 0 || opt.maxWidth > 0) { - if(divWidth < opt.minWidth) { - divWidth = opt.minWidth; - } - if(newDivWidth < opt.minWidth) { - newDivWidth = opt.minWidth; - } - if(newDivWidth > opt.maxWidth) { - newDivWidth = opt.maxWidth; - } - } - var selectWidth = divWidth; - - // Set the new widths - possibleValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - selectedValues.css("width", selectWidth + "px").parent().css("width", newDivWidth + "px"); - - // Remove the select's clone, since we're done with it - cloneObj.remove(); - - }; // End $.fn.SPServices.SPSetMultiSelectSizes - - // Does an audit of a site's list forms to show where script is in use. - $.fn.SPServices.SPScriptAudit = function (options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] The name of the Web (site) to audit - listName: "", // [Optional] The name of a specific list to audit. If not present, all lists in the site are audited. - outputId: "", // The id of the DOM object for output - auditForms: true, // Audit the form pages - auditViews: true, // Audit the view pages - auditPages: true, // Audit the Pages Document Library - auditPagesListName: "Pages", // The Pages Document Library(ies), if desired. Either a single string or an array of strings. - showHiddenLists: false, // Show output for hidden lists - showNoScript: false, // Show output for lists with no scripts (effectively "verbose") - showSrc: true // Show the source location for included scripts - }, options); - - var formTypes = [["New", "NewForm.aspx", false], ["Display", "DispForm.aspx", false], ["Edit", "EditForm.aspx", false]]; - var listXml; - - // Build the table to contain the results - $("#" + opt.outputId) - .append("" + - "" + - "" + - "" + - "" + - "" + - "" + - (opt.showSrc ? "" : "") + - "" + - "
    ListPage ClassPage TypePageScript References
    "); - // Apply the CSS class to the headers - $("#SPScriptAudit th").attr("class", "ms-vh2-nofilter"); - - // Don't bother with the lists if the options don't require them - if(opt.auditForms || opt.auditViews) { - // First, get all of the lists within the site - $().SPServices({ - operation: "GetListCollection", - webURL: opt.webURL, - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - - // If listName has been specified, then only return results for that list - if((opt.listName.length === 0) || (listXml.attr("Title") === opt.listName)) { - // Don't work with hidden lists unless we're asked to - if((opt.showHiddenLists && listXml.attr("Hidden") === "False") || !opt.showHiddenLists) { - - // Audit the list's forms - if(opt.auditForms) { - // Get the list's Content Types, therefore the form pages - $().SPServices({ - operation: "GetListContentTypes", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("ContentType").each(function() { - // Don't deal with folders - if($(this).attr("ID").substring(0,6) !== "0x0120") { - var formUrls = $(this).find("FormUrls"); - for(i=0; i < formTypes.length; i++) { - // Look for a customized form... - $(formUrls).find(formTypes[i][0]).each(function() { - SPScriptAuditPage(opt, listXml, "Form", this.nodeName, - ((opt.webURL.length > 0) ? opt.webURL : $().SPServices.SPGetCurrentSite()) + SLASH + $(this).text()); - formTypes[i][2] = true; - }); - // ...else the uncustomized form - if(!formTypes[i][2]) { - var defaultViewUrl = listXml.attr("DefaultViewUrl"); - SPScriptAuditPage(opt, listXml, "Form", formTypes[i][0], - defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH)+1) + formTypes[i][1]); - } - } - // Reset the form types - for(i=0; i < formTypes.length; i++) { - formTypes[i][2] = false; - } - } - }); - } - }); - } - - // Audit the list's views - if(opt.auditViews) { - // Get the list's Views - $().SPServices({ - operation: "GetViewCollection", - webURL: opt.webURL, - listName: listXml.attr("ID"), - async: false, // Need this to be synchronous so we're assured of a valid value - completefunc: function (xData, Status) { - $(xData.responseXML).find("View").each(function() { - SPScriptAuditPage(opt, listXml, "View", $(this).attr("DisplayName"), $(this).attr("Url")); - }); - } - }); - } - - } - } - }); - } - }); - } - - // Don't bother with auditing pages if the options don't require it - var numLists = 0; - var listsArray = []; - if(typeof opt.auditPagesListName === "string") { - numLists = 1; - listsArray.push(opt.auditPagesListName); - } else { - numLists = opt.auditPagesListName.length; - listsArray = opt.auditPagesListName; - } - - if(opt.auditPages) { - for(i=0; i < numLists; i++) { - $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - webURL: opt.webURL, - listName: listsArray[i], - completefunc: function (xData, Status) { - $(xData.responseXML).find("List").each(function() { - listXml = $(this); - }); - } - }); - // Get all of the items from the Document Library - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: listsArray[i], - CAMLQuery: "Folder", - CAMLViewFields: "", - CAMLRowLimit: 0, - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisPageUrl = $(this).attr("ows_FileRef").split(";#")[1]; - var thisTitle = $(this).attr("ows_Title"); - var thisPageType = (typeof thisTitle !== "undefined") ? thisTitle : ""; - if(thisPageUrl.indexOf(".aspx") > 0) { - SPScriptAuditPage(opt, listXml, "Page", thisPageType, SLASH + thisPageUrl); - } - }); - } - }); - } - } - // Remove progress indicator and make the output pretty by cleaning up the ms-alternating CSS class - $("#SPScriptAudit tr[class='ms-alternating']:even").removeAttr("class"); - }; // End $.fn.SPServices.SPScriptAudit - - // Displays the usage of scripts in a site - function SPScriptAuditPage(opt, listXml, pageClass, pageType, pageUrl) { - - var i = 0; - var jQueryPage = 0; - var pageScriptSrc = {}; - pageScriptSrc.type = []; - pageScriptSrc.src = []; - pageScriptSrc.script = []; - var scriptRegex = RegExp("", "gi"); - - // Fetch the page - $.ajax({ - type: "GET", - url: pageUrl, - dataType: "text", - async: false, - success: function(xData) { - - var scriptMatch; - - while (scriptMatch = scriptRegex.exec(xData)) { - var scriptLanguage = getScriptAttribute(scriptMatch, "language"); - var scriptType = getScriptAttribute(scriptMatch, "type"); - var scriptSrc = getScriptAttribute(scriptMatch, "src"); - if(scriptSrc !== null && scriptSrc.length > 0 && !coreScript(scriptSrc)) { - pageScriptSrc.type.push((scriptLanguage !== null && scriptLanguage.length > 0) ? scriptLanguage : scriptType); - pageScriptSrc.src.push(scriptSrc); - jQueryPage++; - } - } - - // Only show pages without script if we've been asked to do so. - if((!opt.showNoScript && (pageScriptSrc.type.length > 0)) || opt.showNoScript) { - var pagePath = pageUrl.substring(0, pageUrl.lastIndexOf(SLASH)+1); - var out = "" + - "" + - "" + listXml.attr("Title") + ((listXml.attr("Hidden") === "True") ? '(Hidden)' : '')+ "" + - "" + pageClass + "" + - "" + pageType + "" + - "" + fileName(pageUrl) + ""; - if(opt.showSrc) { - var thisSrcPath; - out += ""; - for(i=0; i < pageScriptSrc.type.length; i++) { - thisSrcPath = (pageScriptSrc.src[i].substr(0,1) !== SLASH) ? pagePath + pageScriptSrc.src[i] : pageScriptSrc.src[i]; - out += ""; - out += ""; - } - out += "
    " + pageScriptSrc.type[i] + "" + fileName(pageScriptSrc.src[i]) + "
    "; - } - $("#SPScriptAudit").append(out); - } - } - }); - } // End of function SPScriptAuditPage - - function getScriptAttribute(source, attribute) { - var matches; - var regex = RegExp(attribute + "=(\"([^\"]*)\")|('([^']*)')", "gi"); - if(matches = regex.exec(source)) { - return matches[2]; - } - return null; - } // End of function getScriptAttribute - - // Check to see if the script reference is part of SharePoint core so that we can ignore it - function coreScript(src) { - var i; - var coreScriptLocations = ["WebResource.axd", "_layouts"]; - for(i=0; i < coreScriptLocations.length; i++) { - if(src.indexOf(coreScriptLocations[i]) > -1) { - return true; - } - } - return false; - } // End of function coreScript - - // Rearrange radio buttons or checkboxes in a form from vertical to horizontal display to save page real estate - $.fn.SPServices.SPArrangeChoices = function (options) { - - var opt = $.extend({}, { - listName: $().SPServices.SPListNameFromUrl(), // The list name for the current form - columnName: "", // The display name of the column in the form - perRow: 99, // Maximum number of choices desired per row. - randomize: false // If true, randomize the order of the options - }, options); - - var columnFillInChoice = false; - var columnOptions = []; - var out; - - // Get information about columnName from the list to determine if we're allowing fill-in choices - var thisGetList = $().SPServices({ - operation: "GetList", - async: false, - cacheXML: true, - listName: opt.listName - }); - - // when the promise is available... - thisGetList.done(function() { - $(thisGetList.responseXML).find("Field[DisplayName='" + opt.columnName + "']").each(function() { - // Determine whether columnName allows a fill-in choice - columnFillInChoice = ($(this).attr("FillInChoice") === "TRUE") ? true : false; - // Stop looking;we're done - return false; - }); - - var thisFormField = findFormField(opt.columnName); - - var totalChoices = $(thisFormField).find("tr").length; - var choiceNumber = 0; - var fillinPrompt; - var fillinInput; - // Collect all of the choices - $(thisFormField).find("tr").each(function() { - choiceNumber++; - // If this is the fill-in prompt, save it... - if(columnFillInChoice && choiceNumber === (totalChoices - 1)) { - fillinPrompt = $(this).find("td").html(); - // ...or if it is the fill-in input box, save it... - } else if(columnFillInChoice && choiceNumber === totalChoices) { - fillinInput = $(this).find("td").html(); - // ...else push into the columnOptions array. - } else { - columnOptions.push($(this).html()); - } - }); - out = ""; - - // If randomize is true, randomly sort the options - if(opt.randomize) { - columnOptions.sort(randOrd); - } - - // Add all of the options to the out string - for(i=0; i < columnOptions.length; i++) { - out += columnOptions[i]; - // If we've already got perRow columnOptions in the row, close off the row - if((i+1) % opt.perRow === 0) { - out += ""; - } - } - out += ""; - - // If we are allowing a fill-in choice, add that option in a separate row at the bottom - if(columnFillInChoice) { - out += "" + fillinPrompt + fillinInput + ""; - } - - // Remove the existing rows... - $(thisFormField).find("tr").remove(); - // ...and append the out string - $(thisFormField).find("table").append(out); - - }); - - }; // End $.fn.SPServices.SPArrangeChoices - - // Provide suggested values from a list for in input column based on characters typed - $.fn.SPServices.SPAutocomplete = function (options) { - - var opt = $.extend({}, { - WebURL: "", // [Optional] The name of the Web (site) which contains the sourceList - sourceList: "", // The name of the list which contains the values - sourceColumn: "", // The static name of the column which contains the values - columnName: "", // The display name of the column in the form - CAMLQuery: "", // [Optional] For power users, this CAML fragment will be Anded with the default query on the relatedList - CAMLQueryOptions: "", // [Optional] For power users, allows specifying the CAMLQueryOptions for the GetListItems call - CAMLRowLimit: 0, // [Optional] Override the default view rowlimit and get all appropriate rows - filterType: "BeginsWith", // Type of filtering: [BeginsWith, Contains] - numChars: 0, // Wait until this number of characters has been typed before attempting any actions - ignoreCase: false, // If set to true, the function ignores case, if false it looks for an exact match - highlightClass: "", // If a class is supplied, highlight the matched characters in the values by applying that class to a wrapping span - uniqueVals: false, // If set to true, the function only adds unique values to the list (no duplicates) - maxHeight: 99999, // Sets the maximum number of values to display before scrolling occurs - slideDownSpeed: "fast", // Speed at which the div should slide down when values match (milliseconds or ["fast" | "slow"]) - processingIndicator: "_layouts/images/REFRESH.GIF", // If present, show this while processing - debug: false // If true, show error messages;if false, run silent - }, options); - - var matchNum; - - // Find the input control for the column and save some of its attributes - var columnObj = $("input[Title='" + opt.columnName + "']"); - $("input[Title='" + opt.columnName + "']").css("position", ""); - var columnObjId = columnObj.attr("ID"); - var columnObjColor = columnObj.css("color"); - var columnObjWidth = columnObj.css("width"); - - if(columnObj.html() === null && opt.debug) { - errBox("SPServices.SPAutocomplete", - "columnName: " + opt.columnName, - "Column is not an input control or is not found on page"); - return; - } - - // Remove the
    which isn't needed and messes up the formatting - columnObj.closest("span").find("br").remove(); - columnObj.wrap("
    "); - - // Create a div to contain the matching values and add it to the DOM - var containerId = genContainerId("SPAutocomplete", opt.columnName); - columnObj.after("
    "); - - // Set the width to match the width of the input control - $("#" + containerId).css("width", columnObjWidth); - - // Handle keypresses - $(columnObj).keyup(function () { - - // Get the column's value - var columnValue = $(this).val(); - - // Hide the container while we're working on it - $("#" + containerId).hide(); - - // Have enough characters been typed yet? - if(columnValue.length < opt.numChars) { - return false; - } - - // Show the the processingIndicator as a background image in the input element - columnObj.css({ - "background-image": "url(" + opt.processingIndicator + ")", - "background-position": "right", - "background-repeat": "no-repeat" - }); - - // Array to hold the matched values - var matchArray = []; - - // Build the appropriate CAMLQuery - var camlQuery = ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += ""; - } - camlQuery += "<" + opt.filterType + ">" + columnValue + ""; - if(opt.CAMLQuery.length > 0) { - camlQuery += opt.CAMLQuery + ""; - } - camlQuery += ""; - - // Call GetListItems to find all of the potential values - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.WebURL, - listName: opt.sourceList, - CAMLQuery: camlQuery, - CAMLQueryOptions: opt.CAMLQueryOptions, - CAMLViewFields: "", - CAMLRowLimit: opt.CAMLRowLimit, - completefunc: function(xData) { - // Handle upper/lower case if ignoreCase = true - var testValue = opt.ignoreCase ? columnValue.toUpperCase() : columnValue; - // See which values match and add the ones that do to matchArray - $(xData.responseXML).SPFilterNode("z:row").each(function() { - var thisValue = $(this).attr("ows_" + opt.sourceColumn); - var thisValueTest = opt.ignoreCase ? $(this).attr("ows_" + opt.sourceColumn).toUpperCase() : $(this).attr("ows_" + opt.sourceColumn); - // Make sure we have a match... - if(opt.filterType === "Contains") { - var firstMatch = thisValueTest.indexOf(testValue); - if((firstMatch >= 0) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } else { - // Handles normal case, which is BeginsWith and and other unknown values - if(testValue === thisValueTest.substr(0,testValue.length) && - // ...and that the match is not already in the array if we want uniqueness - (!opt.uniqueVals || ($.inArray(thisValue, matchArray) === -1))) { - matchArray.push($(this).attr("ows_" + opt.sourceColumn)); - } - } - }); - } - }); - - // Build out the set of list elements to contain the available values - var out = ""; - for (i=0; i < matchArray.length; i++) { - // If a highlightClass has been supplied, wrap a span around each match - if(opt.highlightClass.length > 0) { - // Set up Regex based on whether we want to ignore case - var thisRegex = RegExp(columnValue, opt.ignoreCase ? "gi" : "g"); - // Look for all occurrences - var matches = matchArray[i].match(thisRegex); - var startLoc = 0; - // Loop for each occurrence, wrapping each in a span with the highlightClass CSS class - for (matchNum=0; matchNum < matches.length; matchNum++) { - var thisPos = matchArray[i].indexOf(matches[matchNum], startLoc); - var endPos = thisPos + matches[matchNum].length; - var thisSpan = "" + matches[matchNum] + ""; - matchArray[i] = matchArray[i].substr(0, thisPos) + thisSpan + matchArray[i].substr(endPos); - startLoc = thisPos + thisSpan.length; - } - } - // Add the value to the markup for the container - out += "
  • " + matchArray[i] + "
  • "; - } - - // Add all the list elements to the containerId container - $("#" + containerId).html(out); - // Set up hehavior for the available values in the list element - $("#" + containerId + " li").click(function () { - $("#" + containerId).fadeOut(opt.slideUpSpeed); - $("#" + columnObjId).val($(this).text()); - }).mouseover(function () { - var mouseoverCss = { - "cursor": "hand", - "color": "#ffffff", - "background": "#3399ff" - }; - $(this).css(mouseoverCss); - }).mouseout(function () { - var mouseoutCss = { - "cursor": "inherit", - "color": columnObjColor, - "background": "transparent" - }; - $(this).css(mouseoutCss); - }); - - // If we've got some values to show, then show 'em! - if(matchArray.length > 0) { - $("#" + containerId).slideDown(opt.slideDownSpeed); - } - // Remove the processing indicator - columnObj.css("background-image", ""); - }); - - }; // End $.fn.SPServices.SPAutocomplete - - // Get the Query String parameters and their values and return in an array - $.fn.SPServices.SPGetQueryString = function () { - - var queryStringVals = {}; - var matches; - var qs = location.search.substring(1, location.search.length); - var args = qs.split("&"); - var rxQS = /^([^=]+)=(.*)/i; - - for(var i=0; i < args.length; i++) { - matches = rxQS.exec(args[i]); - if(rxQS.test(location.href)) { - if(matches !== null && matches.length > 2) { - queryStringVals[matches[1]] = unescape(matches[2]).replace(/\+/g,' '); - } - } - } - return queryStringVals; - - }; // End $.fn.SPServices.SPGetQueryString - - // Get the current list's GUID (ID) from the current URL. Use of this function only makes sense if we're in a list's context, - // and we assume that we are calling it from an aspx page which is a form or view for the list. - $.fn.SPServices.SPListNameFromUrl = function (options) { - - var opt = $.extend({}, { - listName: "" // [Optional] Pass in the name or GUID of a list if you are not in its context. e.g., on a Web Part pages in the Pages library - }, options); - - // Has the list name or GUID been passed in? - if(opt.listName.length > 0) { - currentContext.thisList = opt.listName; - return currentContext.thisList; - // Do we already know the current list? - } else if(currentContext.thisList.length > 0) { - return currentContext.thisList; - } - - // Parse out the list's root URL from the current location or the passed url - var thisPage = location.href; - var thisPageBaseName = thisPage.substring(0, thisPage.indexOf(".aspx")); - var listPath = decodeURIComponent(thisPageBaseName.substring(0, thisPageBaseName.lastIndexOf(SLASH) + 1)).toUpperCase(); - - // Call GetListCollection and loop through the results to find a match with the list's URL to get the list's GUID - $().SPServices({ - operation: "GetListCollection", - async: false, - completefunc: function(xData, Status) { - $(xData.responseXML).find("List").each(function() { - var defaultViewUrl = $(this).attr("DefaultViewUrl"); - var listCollList = defaultViewUrl.substring(0, defaultViewUrl.lastIndexOf(SLASH) + 1).toUpperCase(); - if(listPath.indexOf(listCollList) > 0) { - currentContext.thisList = $(this).attr("ID"); - return false; - } - }); - } - }); - - // Return the list GUID (ID) - return currentContext.thisList; - - }; // End $.fn.SPServices.SPListNameFromUrl - - // SPUpdateMultipleListItems allows you to update multiple items in a list based upon some common characteristic or metadata criteria. - $.fn.SPServices.SPUpdateMultipleListItems = function(options) { - - var opt = $.extend({}, { - webURL: "", // [Optional] URL of the target Web. If not specified, the current Web is used. - listName: "", // The list to operate on. - CAMLQuery: "", // A CAML fragment specifying which items in the list will be selected and updated - batchCmd: "Update", // The operation to perform. By default, Update. - valuepairs: [], // Valuepairs for the update in the form [[fieldname1, fieldvalue1], [fieldname2, fieldvalue2]...] - completefunc: null, // Function to call on completion of rendering the change. - debug: false // If true, show error messages;if false, run silent - }, options); - - var i; - var itemsToUpdate = []; - var documentsToUpdate = []; - - // Call GetListItems to find all of the items matching the CAMLQuery - $().SPServices({ - operation: "GetListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - CAMLQuery: opt.CAMLQuery, - CAMLQueryOptions: "", - completefunc: function(xData) { - $(xData.responseXML).SPFilterNode("z:row").each(function() { - itemsToUpdate.push($(this).attr("ows_ID")); - var fileRef = $(this).attr("ows_FileRef"); - fileRef = "/" + fileRef.substring(fileRef.indexOf(";#")+2); - documentsToUpdate.push(fileRef); - }); - } - }); - - var fieldNum; - var batch = ""; - for(i=0; i < itemsToUpdate.length; i++) { - batch += ""; - for (fieldNum=0; fieldNum < opt.valuepairs.length; fieldNum++) { - batch += "" + escapeColumnValue(opt.valuepairs[fieldNum][1]) + ""; - } - batch += "" + itemsToUpdate[i] + ""; - if(documentsToUpdate[i].length > 0) { - batch += "" + documentsToUpdate[i] + ""; - } - batch += ""; - } - batch += ""; - - // Call UpdateListItems to update all of the items matching the CAMLQuery - $().SPServices({ - operation: "UpdateListItems", - async: false, - webURL: opt.webURL, - listName: opt.listName, - updates: batch, - completefunc: function(xData) { - // If present, call completefunc when all else is done - if(opt.completefunc !== null) { - opt.completefunc(xData, Status); - } - } - }); - - }; // End $.fn.SPServices.SPUpdateMultipleListItems - - // This method for finding specific nodes in the returned XML was developed by Steve Workman. See his blog post - // http://www.steveworkman.com/html5-2/javascript/2011/improving-javascript-xml-node-finding-performance-by-2000/ - // for performance details. - $.fn.SPFilterNode = function(name) { - return this.find('*').filter(function() { - return this.nodeName === name; - }); - }; // End $.fn.SPFilterNode - - - // This function converts an XML node set to JSON - // Initial implementation focuses only on GetListItems - $.fn.SPXmlToJson = function(options) { - - var opt = $.extend({}, { - mapping: {}, // columnName: mappedName: "mappedName", objectType: "objectType" - includeAllAttrs: false, // If true, return all attributes, regardless whether they are in the mapping - removeOws: true // Specifically for GetListItems, if true, the leading ows_ will be stripped off the field name - }, options); - - var attrNum; - var jsonObject = []; - - this.each(function() { - var row = {}; - var rowAttrs = this.attributes; - - // Bring back all mapped columns, even those with no value - $.each(opt.mapping, function() { - row[this.mappedName] = ""; - }); - - // Parse through the element's attributes - for(attrNum = 0; attrNum < rowAttrs.length; attrNum++) { - var thisAttrName = rowAttrs[attrNum].name; - var thisMapping = opt.mapping[thisAttrName]; - var thisObjectName = typeof thisMapping !== "undefined" ? thisMapping.mappedName : opt.removeOws ? thisAttrName.split("ows_")[1] : thisAttrName; - var thisObjectType = typeof thisMapping !== "undefined" ? thisMapping.objectType : undefined; - if(opt.includeAllAttrs || thisMapping !== undefined) { - row[thisObjectName] = attrToJson(rowAttrs[attrNum].value, thisObjectType); - } - } - // Push this item into the JSON Object - jsonObject.push(row); - - }); - - // Return the JSON object - return jsonObject; - - }; // End $.fn.SPServices.SPXmlToJson - - - function attrToJson(v, objectType) { - - var colValue; - - switch (objectType) { - case "DateTime": - case "datetime": // For calculated columns, stored as datetime;#value - // Dates have dashes instead of slashes: ows_Created="2009-08-25 14:24:48" - colValue = dateToJsonObject(v); - break; - case "User": - colValue = userToJsonObject(v); - break; - case "UserMulti": - colValue = userMultiToJsonObject(v); - break; - case "Lookup": - colValue = lookupToJsonObject(v); - break; - case "LookupMulti": - colValue = lookupMultiToJsonObject(v); - break; - case "Boolean": - colValue = booleanToJsonObject(v); - break; - case "Integer": - colValue = intToJsonObject(v); - break; - case "Counter": - colValue = intToJsonObject(v); - break; - case "MultiChoice": - colValue = choiceMultiToJsonObject(v); - break; - case "Currency": - case "float": // For calculated columns, stored as float;#value - colValue = floatToJsonObject(v); - break; - case "Calc": - colValue = calcToJsonObject(v); - break; - default: - // All other objectTypes will be simple strings - colValue = stringToJsonObject(v); - break; - } - return colValue; - } - - function stringToJsonObject(s) { - return s; - } - function intToJsonObject(s) { - return parseInt(s, 10); - } - function floatToJsonObject(s) { - return parseFloat(s); - } - function booleanToJsonObject(s) { - var out = s === "0" ? false : true; - return out; - } - function dateToJsonObject(s) { - return new Date(s.replace(/-/g, "/")); - } - function userToJsonObject(s) { - if (s.length === 0) { - return null; - } else { - var thisUser = new SplitIndex(s); - var thisUserExpanded = thisUser.value.split(",#"); - if(thisUserExpanded.length === 1) { - return {userId: thisUser.Id, userName: thisUser.value}; - } else { - return { - userId: thisUser.Id, - userName: thisUserExpanded[0].replace( /(,,)/g, ","), - loginName: thisUserExpanded[1].replace( /(,,)/g, ","), - email: thisUserExpanded[2].replace( /(,,)/g, ","), - sipAddress: thisUserExpanded[3].replace( /(,,)/g, ","), - title: thisUserExpanded[4].replace( /(,,)/g, ",") - }; - } - } - } - function userMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisUserMultiObject = []; - var thisUserMulti = s.split(";#"); - for(i=0; i < thisUserMulti.length; i=i+2) { - var thisUser = userToJsonObject(thisUserMulti[i] + ";#" + thisUserMulti[i+1]); - thisUserMultiObject.push(thisUser); - } - return thisUserMultiObject; - } - } - function lookupToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookup = new SplitIndex(s); - return {lookupId: thisLookup.id, lookupValue: thisLookup.value}; - } - } - function lookupMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisLookupMultiObject = []; - var thisLookupMulti = s.split(";#"); - for(i=0; i < thisLookupMulti.length; i=i+2) { - var thisLookup = lookupToJsonObject(thisLookupMulti[i] + ";#" + thisLookupMulti[i+1]); - thisLookupMultiObject.push(thisLookup); - } - return thisLookupMultiObject; - } - } - function choiceMultiToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisChoiceMultiObject = []; - var thisChoiceMulti = s.split(";#"); - for(i=0; i < thisChoiceMulti.length; i++) { - if(thisChoiceMulti[i].length !== 0) { - thisChoiceMultiObject.push(thisChoiceMulti[i]); - } - } - return thisChoiceMultiObject; - } - } - function calcToJsonObject(s) { - if(s.length === 0) { - return null; - } else { - var thisCalc = s.split(";#"); - // The first value will be the calculated column value type, the second will be the value - return attrToJson(thisCalc[1], thisCalc[0]); - } - } - - // Find a People Picker in the page - // Returns references to: - // row - The TR which contains the People Picker (useful if you'd like to hide it at some point) - // contents - The element which contains the current value - // currentValue - The current value if it is set - // checkNames - The Check Names image (in case you'd like to click it at some point) - $.fn.SPFindPeoplePicker = function(options) { - - var opt = $.extend({}, { - peoplePickerDisplayName: "", // The displayName of the People Picker on the form - valueToSet: "", // The value to set the People Picker to. Should be a string containing each username or groupname separated by semi-colons. - checkNames: true // If set to true, the Check Names image will be clicked to resolve the names - }, options); - - var thisRow = $("nobr").filter(function() { - // Ensures we get a match whether or not the People Picker is required (if required, the nobr contains a span also) - return $(this).contents().eq(0).text() === opt.peoplePickerDisplayName; - }).closest("tr"); - - var thisContents = thisRow.find("div[name='upLevelDiv']"); - var thisCheckNames = thisRow.find("img[Title='Check Names']:first"); - - // If a value was provided, set the value - if(opt.valueToSet.length > 0) { - thisContents.html(opt.valueToSet); - } - - // If checkName is true, click the check names icon - if(opt.checkNames) { - thisCheckNames.click(); - } - var thisCurrentValue = $.trim(thisContents.text()); - - // Parse the entity data - var dictionaryEntries = []; - - // IE - thisContents.children("span").each(function() { - - // Grab the entity data - var thisData = $(this).find("div[data]").attr("data"); - - var dictionaryEntry = {}; - - // Entity data is only available in IE - if(typeof thisData !== "undefined") { - var arrayOfDictionaryEntry = $.parseXML(thisData); - var $xml = $(arrayOfDictionaryEntry); - - $xml.find("DictionaryEntry").each(function() { - var key = $(this).find("Key").text(); - var value = $(this).find("Value").text(); - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - // For other browsers, we'll call GetUserInfo to get the data - } else { - $().SPServices({ - operation: "GetUserInfo", - async: false, - cacheXML: true, - userLoginName: $(this).attr("title"), - completefunc: function(xData) { - - $(xData.responseXML).find("User").each(function() { - - $.each(this.attributes, function(i, attrib){ - var key = attrib.name; - var value = attrib.value; - dictionaryEntry[key] = value; - }); - dictionaryEntries.push(dictionaryEntry); - }); - } - }); - } - }); - - return {row: thisRow, contents: thisContents, currentValue: thisCurrentValue, checkNames: thisCheckNames, dictionaryEntries: dictionaryEntries}; - }; - - // Return the current version of SPServices as a string - $.fn.SPServices.Version = function () { - - return VERSION; - - }; // End $.fn.SPServices.Version - - -////// PRIVATE FUNCTIONS //////// - - // Get the current context (as much as we can) on startup - // See: http://johnliu.net/blog/2012/2/3/sharepoint-javascript-current-page-context-info.html - function SPServicesContext() { - - // SharePoint 2010 gives us a context variable - if(typeof _spPageContextInfo !== "undefined") { - this.thisSite = _spPageContextInfo.webServerRelativeUrl; - this.thisList = _spPageContextInfo.pageListId; - this.thisUserId = _spPageContextInfo.userId; - // In SharePoint 2007, we know the UserID only - } else { - this.thisSite = ""; - this.thisList = ""; - this.thisUserId = (typeof _spUserId !== "undefined") ? _spUserId : undefined; - } - - } // End of function SPServicesContext - - - // Display a column (field) formatted correctly based on its definition in the list. - // NOTE: Currently not dealing with locale differences. - // columnXML The XML node for the column from a GetList operation - // columnValue The text representation of the column's value - // opt The current set of options - function showColumn(listXML, columnXML, columnValue, opt) { - - if(typeof columnValue === "undefined") { - return ""; - } - - var i; - var outString = ""; - var dispUrl; - var numDecimals; - var outArray =[]; - var webUrl = opt.relatedWebURL.length > 0 ? opt.relatedWebURL : $().SPServices.SPGetCurrentSite(); - - switch(columnXML.attr("Type")) { - case "Text": - outString = columnValue; - break; - case "URL": - switch(columnXML.attr("Format")) { - // URL as hyperlink - case "Hyperlink": - outString = "
    " + - columnValue.substring(columnValue.search(",") + 1) + ""; - break; - // URL as image - case "Image": - outString = "" + columnValue.substring(columnValue.search(",") + 1) +
-							""; - break; - // Just in case - default: - outString = columnValue; - break; - } - break; - case "User": - case "UserMulti": - var userMultiValues = columnValue.split(";#"); - for(i=0; i < userMultiValues.length; i = i+2) { - outArray.push("" + - userMultiValues[i+1] + ""); - } - outString = outArray.join(", "); - break; - case "Calculated": - var calcColumn = columnValue.split(";#"); - outString = calcColumn[1]; - break; - case "Number": - numDecimals = columnXML.attr("Decimals"); - outString = typeof numDecimals === "undefined" ? - parseFloat(columnValue).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Currency": - numDecimals = columnXML.attr("Decimals"); - outString = typeof numDecimals === "undefined" ? - parseFloat(columnValue).toFixed(2).toString() : - parseFloat(columnValue).toFixed(numDecimals).toString(); - break; - case "Lookup": - switch(columnXML.attr("Name")) { - case "FileRef": - // Get the display form URL for the lookup source list - dispUrl = listXML.attr("BaseType") === "1" ? listXML.attr("RootFolder") + SLASH + "Forms/DispForm.aspx" : - listXML.attr("RootFolder") + SLASH + "DispForm.aspx"; - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - case "FileDirRef": - // Get the display form URL for the lookup source list - dispUrl = SLASH + columnValue.substring(columnValue.search(";#") + 2); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - // Any other lookup column - default: - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - outString = "" + - columnValue.substring(columnValue.search(";#") + 2) + ""; - break; - } - break; - case "LookupMulti": - // Get the display form URL for the lookup source list - dispUrl = getListFormUrl(columnXML.attr("List"), "DisplayForm"); - // Show all the values as links to the items, separated by commas - outString = ""; - if(columnValue.length > 0) { - var lookupMultiValues = columnValue.split(";#"); - for(i=0; i < lookupMultiValues.length / 2; i++) { - outArray.push("" + - lookupMultiValues[(i * 2) + 1] + ""); - } - } - outString = outArray.join(", "); - break; - case "File": - fileName = columnValue.substring(columnValue.search(";#") + 2); - outString = "" + fileName + ""; - break; - case "Counter": - outString = columnValue; - break; - case "DateTime": - outString = columnValue; - break; - default: - outString = columnValue; - break; - } - return outString; - } // End of function showColumn - - - // Show a single attribute of a node, enclosed in a table - // node The XML node - // opt The current set of options - function showAttrs(node) { - var i; - var out = ""; - for (i=0; i < node.attributes.length; i++) { - out += ""; - } - out += "
    " + i + "" + - node.attributes.item(i).nodeName + "" + checkLink(node.attributes.item(i).nodeValue) + "
    "; - return out; - } // End of function showAttrs - - - // Find a dropdown (or multi-select) in the DOM. Returns the dropdown onject and its type: - // S = Simple (select);C = Compound (input + select hybrid);M = Multi-select (select hybrid) - function DropdownCtl(colName) { - // Simple - if((this.Obj = $("select[Title='" + colName + "']")).length === 1) { - this.Type = "S"; - // Compound - } else if((this.Obj = $("input[Title='" + colName + "']")).length === 1) { - this.Type = "C"; - // Multi-select: This will find the multi-select column control in English and most other languages sites where the Title looks like 'Column Name possible values' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title^='" + colName + " ']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Russian site (and perhaps others) where the Title looks like 'Выбранных значений: Column Name' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=': " + colName + "']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a German site (and perhaps others) where the Title looks like 'Mögliche Werte für "Column name".' - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$='\"" + colName + "\".']")).length === 1) { - this.Type = "M"; - // Multi-select: This will find the multi-select column control on a Italian site (and perhaps others) where the Title looks like "Valori possibili Column name" - } else if((this.Obj = $("select[ID$='SelectCandidate'][Title$=' " + colName + "']")).length === 1) { - this.Type = "M"; - } else { - this.Type = null; - } - } // End of function DropdownCtl - - - // Returns the selected value(s) for a dropdown in an array. Expects a dropdown object as returned by the DropdownCtl function. - // If matchOnId is true, returns the ids rather than the text values for the selection options(s). - function getDropdownSelected(columnSelect, matchOnId) { - - var columnSelectSelected = []; - - switch(columnSelect.Type) { - case "S": - if(matchOnId) { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.find("option:selected").text() || []); - } - break; - case "C": - if(matchOnId) { - columnSelectSelected.push($("input[id='"+ columnSelect.Obj.attr("optHid") + "']").val() || []); - } else { - columnSelectSelected.push(columnSelect.Obj.attr("value") || []); - } - break; - case "M": - var columnSelections = columnSelect.Obj.closest("span").find("select[ID$='SelectResult']"); - $(columnSelections).find("option").each(function() { - columnSelectSelected.push($(this).html()); - }); - break; - default: - break; - } - return columnSelectSelected; - - } // End of function getDropdownSelected - - // Build an error message based on passed parameters - function errBox(func, param, msg) { - var errMsg = "Error in function
    " + func + "
    " + - "Parameter
    " + param + "
    " + - "Message
    " + msg + "

    " + - "Click to continue
    "; - modalBox(errMsg); - } // End of function errBox - - // Call this function to pop up a branded modal msgBox - function modalBox(msg) { - var boxCSS = "position:absolute;width:300px;height:150px;padding:10px;background-color:#000000;color:#ffffff;z-index:30;font-family:'Arial';font-size:12px;display:none;"; - $("#aspnetForm").parent().append("
    " + msg); - var height = $("#SPServices_msgBox").height(); - var width = $("#SPServices_msgBox").width(); - var leftVal = ($(window).width() / 2) - (width / 2) + "px"; - var topVal = ($(window).height() / 2) - (height / 2) - 100 + "px"; - $("#SPServices_msgBox").css({border:'5px #C02000 solid', left:leftVal, top:topVal}).show().fadeTo("slow", 0.75).click(function () { - $(this).fadeOut("3000", function () { - $(this).remove(); - }); - }); - } // End of function modalBox - - // Generate a unique id for a containing div using the function name and the column display name - function genContainerId(funcname, columnName) { - return funcname + "_" + $().SPServices.SPGetStaticFromDisplay({ - listName: $().SPServices.SPListNameFromUrl(), - columnDisplayName: columnName - }); - } // End of function genContainerId - - // Get the URL for a specified form for a list - function getListFormUrl(l, f) { - - var u; - $().SPServices({ - operation: "GetFormCollection", - async: false, - listName: l, - completefunc: function (xData, Status) { - u = $(xData.responseXML).find("Form[Type='" + f + "']").attr("Url"); - } - }); - return u; - - } // End of function getListFormUrl - - // Add the option values to the SOAPEnvelope.payload for the operation - // opt = options for the call - // paramArray = an array of option names to add to the payload - // "paramName" if the parameter name and the option name match - // ["paramName", "optionName"] if the parameter name and the option name are different (this handles early "wrappings" with inconsistent naming) - function addToPayload(opt, paramArray) { - - var i; - - for (i=0; i < paramArray.length; i++) { - // the parameter name and the option name match - if(typeof paramArray[i] === "string") { - SOAPEnvelope.payload += wrapNode(paramArray[i], opt[paramArray[i]]); - // the parameter name and the option name are different - } else if(paramArray[i].length === 2) { - SOAPEnvelope.payload += wrapNode(paramArray[i][0], opt[paramArray[i][1]]); - // something isn't right, so report it - } else { - errBox(opt.operation, "paramArray[" + i + "]: " + paramArray[i], "Invalid paramArray element passed to addToPayload()"); - } - } - } // End of function addToPayload - - // Finds the td which contains a form field in default forms using the comment which contains: - // - // as the "anchor" to find it. Necessary because SharePoint doesn't give all field types ids or specific classes. - function findFormField(columnName) { - var thisFormBody; - // There's no easy way to find one of these columns; we'll look for the comment with the columnName - var searchText = RegExp("FieldName=\"" + columnName.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&") + "\"", "gi"); - // Loop through all of the ms-formbody table cells - $("td.ms-formbody, td.ms-formbodysurvey").each(function() { - // Check for the right comment - if(searchText.test($(this).html())) { - thisFormBody = $(this); - // Found it, so we're done - return false; - } - }); - return thisFormBody; - } // End of function findFormField - - // The SiteData operations have the same names as other Web Service operations. To make them easy to call and unique, I'm using - // the SiteData prefix on their names. This function replaces that name with the right name in the SOAPEnvelope. - function siteDataFixSOAPEnvelope(SOAPEnvelope, siteDataOperation) { - var siteDataOp = siteDataOperation.substring(8); - SOAPEnvelope.opheader = SOAPEnvelope.opheader.replace(siteDataOperation, siteDataOp); - SOAPEnvelope.opfooter = SOAPEnvelope.opfooter.replace(siteDataOperation, siteDataOp); - return SOAPEnvelope; - } // End of function siteDataFixSOAPEnvelope - - // Wrap an XML node (n) around a value (v) - function wrapNode(n, v) { - var thisValue = typeof v !== "undefined" ? v : ""; - return "<" + n + ">" + thisValue + ""; - } - - // Generate a random number for sorting arrays randomly - function randOrd() { - return (Math.round(Math.random())-0.5); - } - - // If a string is a URL, format it as a link, else return the string as-is - function checkLink(s) { - return ((s.indexOf("http") === 0) || (s.indexOf(SLASH) === 0)) ? "" + s + "" : s; - } - - // Get the filename from the full URL - function fileName(s) { - return s.substring(s.lastIndexOf(SLASH)+1,s.length); - } - -/* Taken from http://dracoblue.net/dev/encodedecode-special-xml-characters-in-javascript/155/ */ - var xml_special_to_escaped_one_map = { - '&': '&', - '"': '"', - '<': '<', - '>': '>'}; - var escaped_one_to_xml_special_map = { - '&': '&', - '"': '"', - '<': '<', - '>': '>'}; - - function encodeXml(string) { - return string.replace(/([\&"<>])/g, function(str, item) { - return xml_special_to_escaped_one_map[item]; - }); - } - function decodeXml(string) { - return string.replace(/("|<|>|&)/g, - function(str, item) { - return escaped_one_to_xml_special_map[item]; - }); - } -/* Taken from http://dracoblue.net/dev/encodedecode-special-xml-characters-in-javascript/155/ */ - - // Escape column values - function escapeColumnValue(s) { - if(typeof s === "string") { - return s.replace(/&(?![a-zA-Z]{1,8};)/g, "&"); - } else { - return s; - } - } - - // Escape Url - function escapeUrl(u) { - return u.replace(/&/g,'%26'); - } - - // Split values like 1;#value into id and value - function SplitIndex(s) { - var spl = s.split(";#"); - this.id = spl[0]; - this.value = spl[1]; - } - - -})(jQuery); \ No newline at end of file diff --git a/license.txt b/license.txt new file mode 100644 index 0000000..774561a --- /dev/null +++ b/license.txt @@ -0,0 +1,7 @@ +Copyright (c) 2009-2012 Sympraxis Consulting LLC + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file