Я создаю кустомное поле в sharepoint.. Изначально проект взял отсюда http://blog.12thwave.com/?p=7
Поменял базовый класс на SPFieldLookup
Поменял св-во Value на
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
public override object Value
{
get
{
EnsureChildControls();
SPFieldLookupValue returnValue = new SPFieldLookupValue(Convert.ToInt32(CascadingDropDownList.SelectedItem.Value), CascadingDropDownList.SelectedItem.Text);
return returnValue;
}
set
{
EnsureChildControls();
string lookupValue = Convert.ToString(value), strValue = string.Empty;
if (lookupValue.IndexOf('#') > 0)
strValue = lookupValue.Substring(0, lookupValue.IndexOf('#') - 1);
else
strValue = lookupValue;
if (!string.IsNullOrEmpty(strValue) && CascadingDropDownList.Items.FindByValue(strValue) != null)
CascadingDropDownList.Items.FindByValue(strValue).Selected = true;
else if (!this.Field.Required)
CascadingDropDownList.SelectedIndex = 0;
}
}
Поменял определение поля на
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
<?xml version="1.0" encoding="utf-8"?>
<FieldTypes>
<FieldType>
<Field Name="TypeName">Cascading Drop Down List</Field>
<Field Name="TypeDisplayName">Cascading Drop Down List</Field>
<Field Name="TypeShortDescription">Cascading Drop Down List</Field>
<Field Name="InternalType">Lookup</Field>
<Field Name="SQLType">int</Field>
<Field Name="ParentType">Lookup</Field>
<Field Name="FieldTypeClass">CascadeDropDown.CascadingDropDownListField, CascadeDropDown, Version=1.0.0.0, Culture=Neutral, PublicKeyToken=9ba647c4a4416404</Field>
<Field Name="FieldEditorUserControl">/_controltemplates/CascadingDropDownListFieldEditControl.ascx</Field>
<Field Name="Sortable">TRUE</Field>
<Field Name="Filterable">TRUE</Field>
..
.
.
<RenderPattern Name="DisplayPattern">
<FieldSwitch>
<Expr>
<Property Select="FieldRef"/>
</Expr>
<Case Value="">
<FieldSwitch>
<Expr>
<Property Select="CountRelated"/>
</Expr>
<Case Value="TRUE">
<LookupColumn HTMLEncode="TRUE"/>
</Case>
<Default>
<Switch>
<Expr>
<Column/>
</Expr>
<Case Value="">
</Case>
<Default>
<FieldSwitch>
<Expr>
<Property Select="LookupType"/>
</Expr>
<Case Value="Computed">
<LookupColumn/>
</Case>
<Default>
<HTML><![CDATA[<A HREF="]]></HTML>
<URL Cmd="Lookup"/>
<HTML><![CDATA[">]]></HTML>
<LookupColumn HTMLEncode="TRUE"/>
<HTML><![CDATA[</A>]]></HTML>
</Default>
</FieldSwitch>
</Default>
</Switch>
</Default>
</FieldSwitch>
</Case>
<Default>
<LookupColumn HTMLEncode="TRUE"/>
</Default>
</FieldSwitch>
</RenderPattern>
</FieldType>
</FieldTypes>
Задал в классе филда св-во
1.
2.
3.
4.
public override Type FieldValueType
{
get { return typeof(SPFieldLookupValue); }
}
Все вроде отлично работает..добавляется как положено НО...
Почему то значения в длукапных полях получаются 2;#2 , 4;#4.. Что за ерунда.. При том что св-во Value создает правильные значения.. Т.е. new SPFieldLookupValue( 2,"Avenir IT"). И переходит по лукапам тоже правильно.. Я уже недели 2 не могу разобраться с этой проблемой. Идеи,терпение,сроки вышли. Помогите пожалуйста разобраться.. Я проект выложил
сюды Вам думаю тоже такая фишка может пригодиться.