Skip to main content

Managed Metadata Column Value Add with Angular | JavaScript & JSOM | CSOM

Following would be high-level program flow;MMS Column Update Program Flow

SP Taxonomy need to be imported.

[code language="javascript"]

var scriptbase = _spPageContextInfo.webServerRelativeUrl + "/_layouts/15/";
$.getScript(scriptbase + "SP.Taxonomy.js");
[/code]

Create custom list item with metadata column in SharePoint with JSOM and Angular JS.

[code language="javascript"]
// Adding item to SharePoint custom list with Managed Metadata column (MMS column) with JSOM
(function () {
'use strict';

// define controller
var controllerId = "mmsColumnUploadCtrl";

angular
.module('app')
.controller(controllerId, ['$scope', mmsColumnUploadCtrl]);

// create controller
function mmsColumnUploadCtrl($scope) {
//global var
var vm = this;

//add metadata column to sharepoint
vm.AddMetadataColumn = function () {
var scriptbase = _spPageContextInfo.webServerRelativeUrl + "/_layouts/15/";

// create list item with MMS column
$.getScript(scriptbase + "SP.Taxonomy.js", createListItemWithMMSColumn);

}

//Create list item metadata with MMS column
function createListItemWithMMSColumn() {
//site URi
var siteUrl = 'http://<site url>/sites/MMSPOC';
// List name of updating
var listName = 'TestList';// List name
//Term GUID get from Service
var termId = 'ed414e70-cc02-444b-ba78-8456e6495e45';//term GUID
//For multi labled column may need to provice term lable also, else no
//var termLabel = 'ABCTEST';//Term label

// Client context
var clientContext = new SP.ClientContext(siteUrl);
var oList = clientContext.get_web().get_lists().getByTitle(listName);
var itemCreateInfo = new SP.ListItemCreationInformation();
var oListItem = oList.addItem(itemCreateInfo);
// Define item
oListItem.set_item('Title', 'New Item!'); // non MMS columns
oListItem.set_item('MMSCol', termId); //MMS column
// Update item
oListItem.update();

//client context..Async Req.
clientContext.load(oListItem);
clientContext.executeQueryAsync(
Function.createDelegate(this, onQuerySucceeded),
Function.createDelegate(this, onQueryFailed)
);
}

// On query success
function onQuerySucceeded(oListItem) {
console.info('Item created!');
}
// On query failed
function onQueryFailed(sender, args) {
console.error('Request failed. ' + args.get_message() + '\n' + args.get_stackTrace());
}

};

})();

[/code]

Update document library items' managed metadata column in SharePoint with JSOM and Angular

[code language="javascript"]
// Adding item to SharePoint "Document Library" with Managed Metadata column (MMS column) with JSOM
(function () {
'use strict';

// define controller
var controllerId = "mmsColumnUploadCtrl";

angular
.module('app')
.controller(controllerId, ['$scope', mmsColumnUploadCtrl]);

// create controller
function mmsColumnUploadCtrl($scope) {
//global var
var vm = this;

//add metadata column to sharepoint
vm.AddMetadataColumn = function () {
var scriptbase = _spPageContextInfo.webServerRelativeUrl + "/_layouts/15/";

// Create document item ith MSS column
$.getScript(scriptbase + "SP.Taxonomy.js", updateDocumentItemWithMMSColumn);

}

// Create document metadata of document library item with MMS column
function updateDocumentItemWithMMSColumn() {
//site URi
var siteUrl = 'http://<site>/sites/MMSPOC';

// List name of updating
var listName = 'MMSPOCDocLib';//document library name

// GUID of the term
var termId = 'ed414e70-cc02-444b-ba78-8456e6495e45';//term guid

//For multi-valued terms following will be needed
var termLabel = 'ABCTEST';//term label

//Item Id for update in the document library
//3 is item ID to be updated
//You may dynamically change with the requirement
var itemIdUpdating = 3;

// Client context
var clientContext = new SP.ClientContext(siteUrl);
var oList = clientContext.get_web().get_lists().getByTitle(listName);
var itemCreateInfo = new SP.ListItemCreationInformation();

var oListItem = oList.getItemById(itemIdUpdating);
// Define item
oListItem.set_item('Title', 'Item updated!');
oListItem.set_item('MMSCol', termId);
// Update item
oListItem.update();

//client context..Async Req.
clientContext.load(oListItem);
clientContext.executeQueryAsync(
Function.createDelegate(this, onQuerySucceeded),
Function.createDelegate(this, onQueryFailed)
);
}
// On query success
function onQuerySucceeded(oListItem) {
console.info('Item created!');
}
// On query failed
function onQueryFailed(sender, args) {
console.error('Request failed. ' + args.get_message() + '\n' + args.get_stackTrace());
}
};
[/code]
Await for more interesting coding samples and articles, keep following!! 

Comments

  1. […] https://kushanlahiru.wordpress.com/2016/09/05/managed-metadata-column-value-add-with-angular-javascr… […]

    ReplyDelete

Post a Comment

Popular posts from this blog

Turn off/ Hide Details panel/ Information Panel on modern SharePoint lists

Not always we require to show changes done by other which is a mandatory feature in SharePoint online.  What is details pane (aka. Information Pane)? Detail pane/ Information shows information regarding the document if you selected a one or its showing recent changes within a list or library. Follow link to Microsoft documentation about details pane. Bad news: Until Microsoft listen to User Voice , there is no straightforward way to enable disable this even you don't want. Good news: We could write a SharePoint framework extension to hack styles until Microsoft give us a permanent solution. How? I found this sample project (Inject CSS into modern SharePoint pages with React) which could reuse to our purpose. Thanks to Hugo for saving my time.  Steps to awesomeness:  Clone the project Resolve dependencies >  npm i Bundle >  gulp bundle --ship Package >  gulp package-solution --ship Upload package into SharePoint App catalog  

File attach (POST) to SharePoint 2013 List (custom) using Angular JS via REST API

Following describes how to upload attachment to SharePoint 2013 custom list using Angular JS. Note: You can be consumed the JSOM libraries to achieve this, but there is limitation of 1.5 Mb. Better approach would be consuming exposed REST API (SharePoint OOTB) which allowed up to 2 Gb of file to attached using client side scripts i.e. Angular JS. . Here I have used the “Angular File Upload” which capable of doing more tasks other than basic HTML input file control. By consuming this we can attach multiple files either to the list and etc. You can be found the information on how to include this module to your Angular view in following link. Use package manager command to install the scripts. For bower  -->        bower install angular-file-upload For nugget -->       npm install angular-file-upload It requires file buffer array to POST (save) our attachment via REST API, browsers FileReader API is required to use. Its available with almost all common browsers. You need to ensure t

📢 Update -Microsoft Teams IP Phones and Intune Enrollment

For customers who require desk phones and conference room phones to make and receive audio calls or join meetings, Microsoft Teams provides a growing portfolio of devices that can be purchased from our Teams Marketplace . For Teams phones including the Yealink T56A/T58A/CP960 and the Crestron Flex series IP phones that run on Android 5.x or later, there may be specific configurations that need to be enabled in the customer's tenant for the phones to successfully enroll into Intune.      Allowing successful Intune enrollment for Android versions 5.x and up     If all the following conditions below are true , you will need to enable a specific configuration setting in the Intune admin console to allow for a successful enrollment:   You are deploying a Teams IP phone with Android OS version 5.x or later.   You have connected your Intune tenant with managed Google Play in order to manage Android Enterprise devices.   You have configured your enrollment restrictions such that A