Problem Scenario:-
1) Create Two Custom Cascading List (Parent and Child)
2) In Parent List Add one Column Called Father
data:image/s3,"s3://crabby-images/25669/25669e794347ba868a912d166334f65131218652" alt=""
5) Make connection of Parent List with Child List
data:image/s3,"s3://crabby-images/7023a/7023a9f9f226240a15f721802dbe0dd88b9176db" alt=""
6) Now if you select One of the Parent then it will show you respective Child
If we Select Amitabh then it will show his Children’s and Vice versa.
data:image/s3,"s3://crabby-images/a6673/a66736fcc30e1727ff51c9d9b27f11e3a2537582" alt=""
7) Click on New Item of Child List
.
data:image/s3,"s3://crabby-images/ed1c4/ed1c409c7a4a0c9b8b61a5e76a404767d7a0ce4c" alt=""
8) It should select Fathers Name By Default instead of None
data:image/s3,"s3://crabby-images/273cd/273cde89a34d636c8edbec6aafdad8fb48704fe5" alt=""
Solution:-
Create & Install the feature
Open the \TEMPLATE\FEATURES folder under the 12 hive
Create a folder called NewChildListMenuAction
In that folder, create 2 text files, one called feature.xml and the second elements.xml
In your editor of choice (notepad is fine) open the feature.xml file and paste into it the following:
9) feature.xml
<?xml version="1.0" encoding="utf-8" ?>
<Feature Id="769826dd-9dd2-11db-96ca-005056c00008"
Title="Create Child List"
Description="This feature adds a Create Child in the New menu for Windows
SharePoint Services lists."
Version="1.0.0.0"
Scope="Site"
xmlns="http://schemas.microsoft.com/sharepoint/">
<ElementManifests>
<ElementManifest Location=" elements.xml" />
</ElementManifests>
</Feature>
<Elements
xmlns="http://schemas.microsoft.com/sharepoint/">
<!-- Add the action to the List Toolbar New Menu Dropdown
-->
<CustomAction
Id="SPSTIPS.
NewChildListActionsToolbar"
RegistrationType="List"
GroupId="NewMenu"
Location="Microsoft.SharePoint.StandardMenu"
Sequence="1000"
Title="New Child">
<UrlAction
Url="javascript:window.location=
'{SiteUrl}//Lists/child/NewForm.aspx?PageUrl=' + window.location"/>
</CustomAction>
</Elements>
stsadm -o installfeature -name NewChildListMenuAction –force
stsadm -o activatefeature -name NewChildListMenuAction -url [your site url here] –force
12) Add Content Editor Web Part to NewForm.aspx
13) Note:-
· By default you don’t have option of modify webpart so use below command in url.
NewForm.aspx?PageView=Shared&ToolPaneView=2
14) Paste Following code in content editor WebPart.
<script type="text/javascript">
_spBodyOnLoadFunctionNames.push("fillDefaultValues");
function fillDefaultValues() {
var qs = location.search.substring(1, location.search.length);
var args = qs.split("&");
var vals = new Object();
for (var i=0; i < args.length; i++) {
var nameVal = args[i].split("=");
var temp = unescape(nameVal[1]).split('+');
nameVal[1] = temp.join(' ');
vals[nameVal[0]] = nameVal[1];
}
setLookupFromFieldName("Father", vals["SelectedID"]);
//field name and query string parameter
switchback("Father"); //field name to lock
}
function setLookupFromFieldName(fieldName, value) {
var theSelect = getTagFromIdentifierAndTitle("select","Lookup",fieldName);
if (theSelect == null) {
var theInput = getTagFromIdentifierAndTitle("input","",fieldName);
ShowDropdown(theInput.id);
var opt=document.getElementById(theInput.opt);
setSelectedOption(opt, value);
OptLoseFocus(opt);
} else {
setSelectedOption(theSelect, value);
}
}
function setSelectedOption(select, value) {
var opts = select.options;
var l = opts.length;
if (select == null) return;
for (var i=0; i < l; i++) {
if (opts[i].value == value) {
select.selectedIndex = i;
return true;
}
}
return false;
}
function getTagFromIdentifierAndTitle(tagName, identifier, title) {
var len = identifier.length;
var tags = document.getElementsByTagName(tagName);
for (var i=0; i < tags.length; i++) {
var tempString = tags[i].id;
if (tags[i].title == title && (identifier == "" tempString.indexOf
(identifier) == tempString.length - len)) {
return tags[i];
}
}
return null;
}
function getDropDownImg () {
var downArrow=document.getElementsByTagName('img')
for(var i=0; i < downArrow.length; i++) {
if(downArrow[i].alt ==('Display lookup values')) {
downArrow[i].onclick = fillDefaultValues;
}
}
}
function switchback(fieldName){
var switchSelect = getTagFromIdentifierAndTitle("select","Lookup",fieldName);
if (switchSelect == null) {
var switchInput = getTagFromIdentifierAndTitle("input","",fieldName);
switchInput.onmouseup = fillDefaultValues;
getDropDownImg();
} else {
switchSelect.onchange = fillDefaultValues;
}
}
</script>
It will get selected id from Url and pass it to NewForm.aspx
data:image/s3,"s3://crabby-images/d9930/d99302d0a67a9ab74eaa8d928143c8f4a25c8d51" alt=""
16) On Newform.aspx we have added script in Content Editor Web Part which will bind proper Parent’s Lookup Value to the Dropdown.
No comments:
Post a Comment