먼저 빈 SharePoint Project를 하나 생성합니다.
data:image/s3,"s3://crabby-images/8a8d2/8a8d2224926f6fb11e27ee532b08ceab4448e687" alt=""
[New Item]을 하나 추가하고,
data:image/s3,"s3://crabby-images/331b2/331b2569299641fa2336fb8ae824e6fed06c9b0c" alt=""
[Class]를 선택합니다.
data:image/s3,"s3://crabby-images/66b59/66b59b994d36e400ef516a3d2777a81401409572" alt=""
추가한 Class에 다음과 같이 원하는 형태로 Field Type을 개발합니다.
data:image/s3,"s3://crabby-images/674e1/674e19aa2fa4bb56d2854f426b788d17ebd7834e" alt=""
public class VendorFieldType : SPFieldText { public VendorFieldType(SPFieldCollection fields, string fieldName) : base(fields, fieldName) { } public VendorFieldType(SPFieldCollection fields, string typeName, string displayName) : base(fields, typeName, displayName) { }
public override string DefaultValue { get { string defaultValue = string.Empty; SPSecurity.RunWithElevatedPrivileges(delegate { try { SPWeb web = SPContext.Current.Web; SPUser user = web.CurrentUser; SPList list = web.Lists["Vendor List"]; SPQuery query = new SPQuery(); query.Query = "<Where><Eq><FieldRef Name='Contact_x0020_Name'/><Value Type='Text'>" + user.Name + "</Value></Eq></Where>"; SPListItemCollection itemC = list.GetItems(query);
foreach (SPListItem item in itemC) { defaultValue = string.Format("{0}", item["Vendor"]); } } catch (Exception ex) { EventLog.WriteEntry("VendorFieldType", ex.Message.ToString(), EventLogEntryType.Error); } });
return defaultValue; } set { base.DefaultValue = value; } }
//public override string GetValidatedString(object value) //{ //if (!value.ToString().StartsWith("P")) //{ // throw new SPFieldValidationException( // "Product code must start with 'P'"); //} //if (value.ToString().Length != 4) //{ // throw new SPFieldValidationException( // "Product code must be 4 chars"); //}
//return value.ToString().ToUpper(); //} |
이제, SharePoint에서 표시되고, 배포되어질 Field Type용 xml을 만들어 봅니다.
우선, xml을 업로드 할 [SharePoint Mapped Folder]를 추가합니다.
data:image/s3,"s3://crabby-images/b6ac7/b6ac7fc12a369f28b0307a28800d566e222fd826" alt=""
[TEMPLATE] - [XML]을 선택합니다.
data:image/s3,"s3://crabby-images/cb95f/cb95f12dfaa232baff136f4344d897b00e2b8d0f" alt=""
추가한 위치에다 XML File을 추가합니다.
data:image/s3,"s3://crabby-images/097d0/097d06e6a87d25e197a2d0073d157c68776f8785" alt=""
xml에 다음과 같이 입력합니다.
data:image/s3,"s3://crabby-images/31fed/31fed306892063dc5eb612826232ef5f64ea5f6b" alt=""
<?xml version="1.0" encoding="utf-8" ?> <FieldTypes> <FieldType> <Field Name="TypeName">Get Vendor</Field> <Field Name="ParentType">Text</Field> <Field Name="TypeDisplayName">Get Vendor</Field> <Field Name="TypeShortDescription">Get Vendor</Field> <Field Name="UserCreatable">TRUE</Field> <Field Name="Sortable">TRUE</Field> <Field Name="AllowBaseTypeRendering">TRUE</Field> <Field Name="Filterable">TRUE</Field> <Field Name="FieldTypeClass">Element.SharePoint.FieldType.VendorFieldType, $SharePoint.Project.AssemblyFullName$</Field> <PropertySchema> <Fields> </Fields> </PropertySchema> </FieldType> </FieldTypes> |
이제 프로젝트를 배포하고 나면, 아래와 같이 필드를 추가해서 사용할 수가 있습니다.
data:image/s3,"s3://crabby-images/604ba/604ba0bd3af674d4a477fd00dd32f7d5e8086268" alt=""