AXForum  
Вернуться   AXForum > Microsoft Dynamics CRM > Dynamics CRM: Разработка
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 14.10.2009, 14:08   #121  
Bondonello is offline
Bondonello
Kostya Afendikov
Аватар для Bondonello
MCBMSS
Лучший по профессии 2009
 
510 / 106 (5) +++++
Регистрация: 06.06.2008
Адрес: Украина
Цитата:
Сообщение от moskalevas Посмотреть сообщение
Тут оказывается вот в чём проблема.В карточке ПРЕДЛОЖЕНИЕ есть поле Потенциальный клиент, в котором мы можем указывать либо Бизнес-партнёра(account), либо Контакт(Contact).
А у меня есть такой код:
quote quo = (quote)crmservice.Retrieve(EntityName.quote.ToString(), workflowContext.PrimaryEntityId,
new ColumnSet(new string[] { "customerid" }));
activityparty toparty = new activityparty();
toparty.partyid = new Lookup();
toparty.partyid.type = EntityName.account.ToString();
toparty.partyid.Value = quo.customerid.Value;
mail.to = new activityparty[] { toparty };

Здесь формируется поле карточки ЭЛЕКТРОННОГО ПИСЬМА "Кому". Надо бы сделать так,чтоб он заполнялось в зависимости от выбранного Потенциального клиента(то есть бизнес-партнёр или контакт). Не могу сообразить,как это сделать.
Делайте проверку по типу того, что вы получаете contact или account и формируйте соответственно эту часть
new ColumnSet(new string[] { "customerid" }));
activityparty toparty = new activityparty();
toparty.partyid = new Lookup();
toparty.partyid.type = EntityName.<account OR contact>.ToString();
toparty.partyid.Value = quo.customerid.Value;

в SDK смотрите примеры
Старый 14.10.2009, 14:09   #122  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Попробуйте так - вместо строки

toparty.partyid.type = EntityName.account.ToString();

напишите

toparty.partyid.type = quo.customerid.type;
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 19.10.2009, 10:00   #123  
moskalevas is offline
moskalevas
Участник
 
107 / 11 (1) +
Регистрация: 16.07.2009
Цитата:
Сообщение от a33ik Посмотреть сообщение
Попробуйте так - вместо строки

toparty.partyid.type = EntityName.account.ToString();

напишите

toparty.partyid.type = quo.customerid.type;
Спасибо!Воспользовался вашим советом.Теперь в зависимости от потенциального клиента(бизнес-партнёр или контакт) соответсвенно заполняется поле КОМУ карточки электронного письма.В карточке же Бизнес-партнёр есть поле Основной контакт(не всегда заполнено).Хотелось бы чтоб в создаваемое письмо в поле КОМУ передовался ещё этот параметр(основной контакт).
Старый 19.10.2009, 10:08   #124  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Цитата:
Сообщение от moskalevas Посмотреть сообщение
Спасибо!Воспользовался вашим советом.Теперь в зависимости от потенциального клиента(бизнес-партнёр или контакт) соответсвенно заполняется поле КОМУ карточки электронного письма.В карточке же Бизнес-партнёр есть поле Основной контакт(не всегда заполнено).Хотелось бы чтоб в создаваемое письмо в поле КОМУ передовался ещё этот параметр(основной контакт).
Следовательно без ещё одного запроса к вебсервису не обойдёшься. Вам необходимо проанализировать, что поле customerid заполнено бизнес-партнёром, далее получить его идентификатор, далее - при помощи Retrieve метода получить поля данного бизнес-партнёра, проанализировать, что поле контакта заполнено и уже после этого добавлять в поле To письма.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 19.10.2009, 10:13   #125  
moskalevas is offline
moskalevas
Участник
 
107 / 11 (1) +
Регистрация: 16.07.2009
Цитата:
Сообщение от a33ik Посмотреть сообщение
Следовательно без ещё одного запроса к вебсервису не обойдёшься. Вам необходимо проанализировать, что поле customerid заполнено бизнес-партнёром, далее получить его идентификатор, далее - при помощи Retrieve метода получить поля данного бизнес-партнёра, проанализировать, что поле контакта заполнено и уже после этого добавлять в поле To письма.
Что нужно сделать-понятно!а вот как-это уже другой вопрос
Может подскажите?или хотя бы ссылочку какую-нибудь подкините
Старый 19.10.2009, 10:22   #126  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Retrieve
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 20.10.2009, 14:58   #127  
moskalevas is offline
moskalevas
Участник
 
107 / 11 (1) +
Регистрация: 16.07.2009
Так и не хочет работать.
Вот какой последний рабочий вариант заполнения поля To:
quote quo = (quote)crmservice.Retrieve(EntityName.quote.ToString(), workflowContext.PrimaryEntityId, new ColumnSet(new string[] { "customerid" }));
activityparty toparty = new activityparty();
toparty.partyid = new Lookup();
toparty.partyid.type = quo.customerid.type;
toparty.partyid.Value = quo.customerid.Value;
mail.to = new activityparty[] { toparty };

Help, please!
Возникла бредовая идея создать поле в карточки предложения основной контакт. Туда с помощью яваскрипта и SOAP запроса передать значение с карточки контакта. И уже прям с карточки предложения выхватывать его и передавать в поле To. Но это не очень красиво и муторно.
Старый 20.10.2009, 15:04   #128  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Цитата:
Сообщение от moskalevas Посмотреть сообщение
Так и не хочет работать.
Вот какой последний рабочий вариант заполнения поля To:
quote quo = (quote)crmservice.Retrieve(EntityName.quote.ToString(), workflowContext.PrimaryEntityId, new ColumnSet(new string[] { "customerid" }));
activityparty toparty = new activityparty();
toparty.partyid = new Lookup();
toparty.partyid.type = quo.customerid.type;
toparty.partyid.Value = quo.customerid.Value;
mail.to = new activityparty[] { toparty };

Help, please!
Возникла бредовая идея создать поле в карточки предложения основной контакт. Туда с помощью яваскрипта и SOAP запроса передать значение с карточки контакта. И уже прям с карточки предложения выхватывать его и передавать в поле To. Но это не очень красиво и муторно.
А до чего дошли при доработке, и как я понял получении неработающего кода?
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 20.10.2009, 16:37   #129  
moskalevas is offline
moskalevas
Участник
 
107 / 11 (1) +
Регистрация: 16.07.2009
Пытался просто в поле To записать бизнес-партнёра,основной контакт(выбирал бизнес-партнёра.у которого поле основного контакта не пусто)
quote quo = (quote)crmservice.Retrieve(EntityName.quote.ToString(), workflowContext.PrimaryEntityId,
new ColumnSet(new string[] { "customerid" }));
account acc = (account)crmservice.Retrieve(EntityName.account.ToString(), workflowContext.PrimaryEntityId,
new ColumnSet(new string[] { "primarycontactid" }));
activityparty toparty = new activityparty();
toparty.partyid = new Lookup();
toparty.partyid.type = quo.customerid.type;
toparty.partyid.Value = quo.customerid.Value;
activityparty toparty1 = new activityparty();
toparty1.partyid = new Lookup();
toparty1.partyid.type = EntityName.account.ToString();
toparty1.partyid.Value = acc.primarycontactid.Value;
mail.to = new activityparty[] { toparty, toparty1 };
Старый 20.10.2009, 16:49   #130  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Обращаю Ваше пристальное внимание на следующие две строчки:

toparty1.partyid.type = EntityName.account.ToString();
toparty1.partyid.Value = acc.primarycontactid.Value;

Просто немного внимательности и всё бы заработало.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 21.10.2009, 11:46   #131  
moskalevas is offline
moskalevas
Участник
 
107 / 11 (1) +
Регистрация: 16.07.2009
Товарищи!Так и застрял на этой маленькой проблеме.

Немного подправил код,получил следующее:
quote quo = (quote)crmservice.Retrieve(EntityName.quote.ToString(), workflowContext.PrimaryEntityId,
new ColumnSet(new string[] { "customerid" }));
Guid quoid = quo.customerid.Value;
account acc = (account)crmservice.Retrieve(EntityName.account.ToString(), quoid,
new ColumnSet(new string[] { "primarycontactid" }));
activityparty toparty = new activityparty();
toparty.partyid = new Lookup();
toparty.partyid.type = quo.customerid.type;
toparty.partyid.Value = quo.customerid.Value;
activityparty toparty1 = new activityparty();
toparty1.partyid = new Lookup();
toparty1.partyid.type = acc.primarycontactid.type;
toparty1.partyid.Value = acc.primarycontactid.Value;
mail.to = new activityparty[] { toparty, toparty1 };

Почему не хочет отрабатывать,не пойму...
Старый 21.10.2009, 11:51   #132  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
А какая ошибка? Приведите Detail.InnerText генерируемого исключения.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 21.10.2009, 11:56   #133  
moskalevas is offline
moskalevas
Участник
 
107 / 11 (1) +
Регистрация: 16.07.2009
Цитата:
Сообщение от a33ik Посмотреть сообщение
А какая ошибка? Приведите Detail.InnerText генерируемого исключения.
А как получить Detail.InnerText исключения?
В логах асинхронного сервиса пишет:
[2009-10-21 11:33:11.2] Process:CrmAsyncService |Organization:e26d7e2d-33b0-417e-8875-7e0c045fda3e |Thread: 10 |Category: Platform.Workflow |User: 00000000-0000-0000-0000-000000000000 |Level: Error | WorkflowHost.OnWorkflowTerminated
>Workflow terminated: {5E625FCB-13BE-DE11-8F8D-003048743D04} - at System.Web.Services.Protocols.SoapHttpClientProtocol.ReadResponse(SoapClientMessage message, WebResponse response, Stream responseStream, Boolean asyncCall)
at System.Web.Services.Protocols.SoapHttpClientProtocol.Invoke(String methodName, Object[] parameters)
at Microsoft.Crm.SdkTypeProxy.CrmService.Create(BusinessEntity entity)
at Microsoft.Crm.Asynchronous.SdkTypeProxyCrmServiceWrapper.Create(BusinessEntity entity)
at E_mailFromQuote.SendReport.Execute(ActivityExecutionContext executionContext)
at System.Workflow.ComponentModel.ActivityExecutor`1.Execute(T activity, ActivityExecutionContext executionContext)
at System.Workflow.ComponentModel.CompositeActivityExecutor`1.Execute(T activity, ActivityExecutionContext executionContext)
at System.Workflow.ComponentModel.ActivityExecutor`1.Execute(Activity activity, ActivityExecutionContext executionContext)
at System.Workflow.ComponentModel.ActivityExecutorOperation.Run(IWorkflowCoreRuntime workflowCoreRuntime)
at System.Workflow.Runtime.Scheduler.Run()


Состояние бизнес-процесса:ожидание
Старый 21.10.2009, 12:02   #134  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Код обращения к вебсервису CRM оборачиваете конструкцией

try
{
//обращение к вебсервису
}
catch(SoapException sexc)
{
throw new Exception(sexc.Detail.InnerText);
}
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 26.10.2009, 19:33   #135  
SVK is offline
SVK
Участник
Аватар для SVK
 
36 / 10 (1) +
Регистрация: 20.09.2005
Адрес: Москва
Lightbulb Способы обновить custom attribute из plugin'а
Коллеги, я знаю два способа обновить кастомный атрибут какой-то стандартной сущности через плагин, зарегистрированный на Post Stage:
1) TargetUpdate DynamicEntity
2) Fetch
А есть ли еще какие-нибудь способы?

P.S. утомился каждый раз писать страницу кода для первого и задолбался для второго.
__________________
CRM programmer
Старый 26.10.2009, 19:52   #136  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Цитата:
Сообщение от SVK Посмотреть сообщение
Коллеги, я знаю два способа обновить кастомный атрибут какой-то стандартной сущности через плагин, зарегистрированный на Post Stage:
1) TargetUpdate DynamicEntity
2) Fetch
А есть ли еще какие-нибудь способы?

P.S. утомился каждый раз писать страницу кода для первого и задолбался для второго.
Fetch не умеет ничего обновлять. Вы чтото вероятно перепутали. Fetch - умеет только зачитывать данные.

По поводу Update - зачем пользоваться TargetUpdate? Update метод может обрабатывать и DynamicEntity...
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
За это сообщение автора поблагодарили: SVK (1).
Старый 27.10.2009, 08:56   #137  
moskalevas is offline
moskalevas
Участник
 
107 / 11 (1) +
Регистрация: 16.07.2009
Добрый день!
Программка заработала.Только не получается сделать проверку.Необходимо,если в карточке account поле primarycontactid пусто,то в карточке электронного письма заполнять поле to бизнес-партнёром,если же не пусто, то ещё заплнять поле cc(копия) основным контактом.Написал следующую проверку,но запуская бизнес процесс на выполнение в состоянии пишется ожидание и всё.

quote quo = (quote)crmservice.Retrieve(EntityName.quote.ToString(), workflowContext.PrimaryEntityId,
new ColumnSet(new string[] { "customerid" }));
Guid quoid = quo.customerid.Value;
account acc = (account)crmservice.Retrieve(EntityName.account.ToString(), quoid,
new ColumnSet(new string[] { "primarycontactid" }));

activityparty toparty = new activityparty();
toparty.partyid = new Lookup();
toparty.partyid.type = quo.customerid.type;
toparty.partyid.Value = quo.customerid.Value;
mail.to = new activityparty[] { toparty };
if (acc.primarycontactid.IsNull == false)
{
activityparty toparty1 = new activityparty();
toparty1.partyid = new Lookup();
toparty1.partyid.type = EntityName.contact.ToString();
toparty1.partyid.Value = acc.primarycontactid.Value;
mail.cc = new activityparty[] { toparty1 };
}
else
{
mail.cc = new activityparty[] { toparty };
}


Для варианта,когда у бизнес-партнёра заполнено поле "основной контакт" - работает.
Старый 27.10.2009, 10:02   #138  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Цитата:
Сообщение от moskalevas Посмотреть сообщение
Добрый день!
Программка заработала.Только не получается сделать проверку.Необходимо,если в карточке account поле primarycontactid пусто,то в карточке электронного письма заполнять поле to бизнес-партнёром,если же не пусто, то ещё заплнять поле cc(копия) основным контактом.Написал следующую проверку,но запуская бизнес процесс на выполнение в состоянии пишется ожидание и всё.

quote quo = (quote)crmservice.Retrieve(EntityName.quote.ToString(), workflowContext.PrimaryEntityId,
new ColumnSet(new string[] { "customerid" }));
Guid quoid = quo.customerid.Value;
account acc = (account)crmservice.Retrieve(EntityName.account.ToString(), quoid,
new ColumnSet(new string[] { "primarycontactid" }));

activityparty toparty = new activityparty();
toparty.partyid = new Lookup();
toparty.partyid.type = quo.customerid.type;
toparty.partyid.Value = quo.customerid.Value;
mail.to = new activityparty[] { toparty };
if (acc.primarycontactid.IsNull == false)
{
activityparty toparty1 = new activityparty();
toparty1.partyid = new Lookup();
toparty1.partyid.type = EntityName.contact.ToString();
toparty1.partyid.Value = acc.primarycontactid.Value;
mail.cc = new activityparty[] { toparty1 };
}
else
{
mail.cc = new activityparty[] { toparty };
}


Для варианта,когда у бизнес-партнёра заполнено поле "основной контакт" - работает.
Попробуйте строку

Код:
if (acc.primarycontactid.IsNull == false)
заменить на

Код:
if (acc.primarycontactid != null)
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 27.10.2009, 10:32   #139  
SVK is offline
SVK
Участник
Аватар для SVK
 
36 / 10 (1) +
Регистрация: 20.09.2005
Адрес: Москва
Я имел ввиду xml обновление, не фетч, конечно.
А вот за Update - спасибо!
__________________
CRM programmer
Теги
c#, custom workflow action, plugin, workflow, reporting services, report

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
mscrm4ever: CRM 4.0 Concatenating Fields Plug-In Blog bot Dynamics CRM: Blogs 0 14.02.2009 14:05
Microsoft Dynamics CRM Team Blog: Member, Static variable and Thread safety in Plug-in for CRM 4.0 Blog bot Dynamics CRM: Blogs 0 19.11.2008 00:05
Microsoft Dynamics CRM Team Blog: Microsoft Dynamics CRM Plug-in Template for Visual Studio Blog bot Dynamics CRM: Blogs 0 27.10.2008 23:05
Microsoft Dynamics CRM Team Blog: Storing Configuration Data for Microsoft Dynamics CRM Plug-ins Blog bot Dynamics CRM: Blogs 0 24.10.2008 22:05
Microsoft Dynamics CRM Team Blog: Accessing a SQL Database from a Microsoft Dynamics CRM Plug-in Blog bot Dynamics CRM: Blogs 0 14.07.2008 13:05

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 16:57.