Dynamics 365 Finance and Operations Dynalink nedir?

Bu yazıda Dynamics 365 Finance and Operations veri kaynakları arasında oluşan Dynalink nedir nasıl kullanılır anlatmaya çalışacağım. X++ tabloları ve EDT‘leri otomatik ilişkiler oluşturur ve bunları birçok yerde kullanır. Tablo veya EDT de olan ilişkiler üzerinden Datasource’lar arasında otomatik bir link oluşturur ve bu link sayesinden ilgili kayıtlar filtrelenmiş olur.  Bir örnekle açıklamaya çalışayım.

Aktivite projemden açıklamaya çalışacağım. Aktivite listesi üzerinde masrafları girebildiğim bir form var. Bu sadece MenuItem kullanarak açılan bir form içinde herhangi bir kod yok ama iki tablo arasında ilişki olduğu için ilgili aktiviteye ait masraflar filtrelenerek geliyor.  Burada oluşan linke Dynalink diyoruz.

Resim-1

Eğer tüm masraf girişlerini gösteren başka bir buton eklersem nasıl çalıştırabilirim bakalım. Bunun için ayrı bir form yapmıyorum yeni bir MenuItem oluşturup buton olarak ekliyorum.

Resim-2

Menu Item Button üzerinden bir değişiklik yapmıyorum.

Resim-3

init metodunu ezip aşağıdaki gibi bir kod yazıyorum. Burada önemli olan hangi MenuItem ile açtığımı anlamak için yazdığım kod ve veri kaynağı üzerinden clearDynalink() metodu. Bu sayede Aktiviteler ve Masraflar tabloları arasında oluşan linki kırıyoruz.

Resim-4

Bu yazıda veri kaynakları arasında tablo ve EDT ilişkilerinden kaynaklı oluşan Dynalink nedir nasıl oluşur ve nasıl kaldırılır anlatmaya çalıştım. Birçok durumda oluşan Dynalink sebebiyle formlarda istedikleri veriyi gösteremeyen arkadaşlara destek verdim. Bu konunun çok kolay gözden kaçtığını düşündüğüm için bir yazı hazırlamak istedim. Query altyapısına hâkim olmak iyi bir X++ yazılımcısı olmanın en temel adımlarından biri. Burayla ilgili çalışmak ve mantığını daha iyi anlamak için denemeler yapmak lazım.

Selamlar.

www.fatihdemirci.net

TAGs: Microsoft Life Cycle Services, LCS, Azure, Azure DevOps,  Dynalink, Microsoft Dynamics 365, MsDyn365FO, MsDyn365CE, MsDyn365, Segmented Entry, Power Automate, Power Apss, Power Virtual Agents, Dynamics 365 nedir

Microsoft MVP Oldum!!!

Merhaba,

Mart 2021 itibariyle ilk Microsoft MVP ödülünü aldığım. Çok uzun zamandır beklediğim bir haberdi. 3 yıl önce ilk defa aday gösterilmiştim. O zaman olmamıştı. Bu yıl tekrar aday gösterildim. Normalden uzun süren bir değerlendirme sonucunda ödüle layık görüldüm.

Şu anda Türkiye’de 20 tane aktif MVP var. İş uygulamaları kategorisinde tekim. Bu da bana çok fazla sorumluluk yüklüyor. Zaten halı hazırda bir ekosistem oluşturmak için çabalamaktayım am bu ödülle birlikte daha da motive oldum. Bu süreçte bir çok destek aldım. Herkese tek tek teşekkür etmek istiyorum. Bunlar olmasa bu ödül mümkün olmazdı. Son bir yılda 80’e yakın makale yazdım, 50’nin üzerinde video çektim ve 13 etkinlik düzenledim. Bunlar dışında konferanslar ve mentorluk faaliyetlerine de devam ettim. Çok yoğun bir yıl geçirmiş oldum. Önümüzdeki yılda da bu faaliyetlerime devam edeceğim.

www.fatihdemirci.net

TAGs: Microsoft Life Cycle Services, LCS, Azure, Azure DevOps, DefaultAccount, MVP, Microsoft Dynamics 365, MsDyn365FO, MsDyn365CE, MsDyn365, Segmented Entry, Power Automate, Power Apss, Power Virtual Agents, Dynamics 365 nedir, Dynamics 365 ERP, Dynamics 365 CRM

Dynamics 365 Finance and Operations LedgerDimension ve Segmented Entry nasıl eklenir?

Bu yazıda Dynamics 365 Finance and Operations içinde bir tabloya LedgerDimension nasıl eklenir ve bu alanı formda Segmented entry control ile nasıl kullanıcıya kullandırabiliriz anlatmaya çalışacağım.

LedgerDimension aslında DimensionAttributeValueCombination kaydıdır. LedgerDimension MainAccount ve DefaultDimension’ın bileşimidir.

Öncelikle Tabloya LedgerDimensionAccount EDT sini kullanarak bir alan ekleyelim. Eğer sürükle bırak ile eklerseniz otomatik ilişkiyi oluşturacak. Yoksa elle eklemeniz gerekir.

Resim-1

Sonrasında forma gelip eklediğimiz alanı tasarımda istediğimiz bir yere sürükleyip bırakıyoruz. Segmented Entry oluşuyor. Özelliklerinde resimde görünen tanımları yapmalıyız. Özellikle Controller Class çok önemli.

Resim-2

Derleyip çalıştırdığımızda formda alanımızı göreceğiz. DefaultAccount ile aradaki farkı görebilirsiniz. Sadece Main Account değil boyutlarda geliyor ve bir kombinasyon oluşturuluyor.

Resim-3

Oluşan verileri Sql üzerinden incelediğimizde aradaki fark çok net bir şekilde ortaya çıkıyor.

Resim-4

Bu yazıda LedgerDimension nedir ve nasıl eklenir anlatmaya çalıştım. Sonraki yazılarımda bunları kodda nasıl kullanıp birbirlerine çeviriyoruz anlatmaya devam edeceğim.

Selamlar.

www.fatihdemirci.net

TAGs: Microsoft Life Cycle Services, LCS, Azure, Azure DevOps, DefaultAccount, LedgerDimension, Microsoft Dynamics 365, MsDyn365FO, MsDyn365CE, MsDyn365, Segmented Entry, Power Automate, Power Apss, Power Virtual Agents, Dynamics 365 nedir, Dynamics 365 ERP, Dynamics 365 CRM

Dynamics 365 Finance and Operations DefaultAccount ve Segmented Entry nasıl eklenir?

Bu yazıda Dynamics 365 Finance and Operations içinde bir tabloya DefaultAccount nasıl eklenir ve bu alanı formda Segmented entry control ile nasıl kullanıcıya kullandırabiliriz anlatmaya çalışacağım.

DefaultAccount aslında DimensionAttributeValueCombination kaydıdır. MainAccount tablosunu referans alır ama asıl yeri orası değildir. Birçok boyut ve hesap ilişkisinde kullanılır.

Öncelikle Tabloya LedgerDimensionDefaultAccount EDT sini kullanarak bir alan ekleyelim. Eğer sürükle bırak ile eklerseniz otomatik ilişkiyi oluşturacak. Yoksa elle eklemeniz gerekir.

Resim-1

Sonrasında forma gelip eklediğimiz alanı tasarımda istediğimiz bir yere sürükleyip bırakıyoruz. Segmented Entry oluşuyor. Özelliklerinde resimde görünen tanımları yapmalıyız. Özellikle Controller Class çok önemli.

Resim-2

Derleyip çalıştırdığımızda formda alanımızı göreceğiz.

Resim-3

Bu yazıda DefaultAccount ve Segmented Entry den bahsettim. Bu alanın kodda nasıl kullanıldığıyla ilgili Ax2012’ de çok yazım olmuştu. D365 içinde örekler yapacağım.

Selamlar.

www.fatihdemirci.net

TAGs: Microsoft Life Cycle Services, LCS, Azure, Azure DevOps, DefaultAccount, Microsoft Dynamics 365, MsDyn365FO, MsDyn365CE, MsDyn365, Segmented Entry, Power Automate, Power Apss, Power Virtual Agents, Dynamics 365 nedir, Dynamics 365 ERP, Dynamics 365 CRM

Dynamics 365 Finance and Operations Date Effectiveness Nasıl Kullanılır?

Bu yazıda Date Effectiveness nedir ne işe yarar anlatmaya çalışacağım.  İş uygulamaları tamamen veriye dayalı uygulamalardır. Bu verinin doğru ve tutarlı olması aynı zamanda kolay ve hızlı bir şekilde işlenebilmesi gerekir. Bu sebeple X++ veriyi yönetmek için birçok farklı özellik sunar bunlardan biri de Date Effectiveness dır. Eğer başlangıç ve bitiş tarihi veya zamanına ihtiyacı olan bir yapı varsa bu özellik sizin için bu tablonun verilerinin yönetilmesini kolaylaştırır. Hem veri girişinde hem de sorgulamasında birçok otomatik edilmiş özellik mevcuttur.

Örnek bir tabloya ekleyip nasıl kullanıldığını anlamaya çalışalım. Öncelikle eklemek istediğimiz tablonun Valid Time State Field Type özelliğini seçiyoruz. Burada ben Date seçtim UTCDateTime diğer seçenek eğer onu seçerseniz zamanı da eklemiş olursunuz. Seçimi yapınca otomatik olarak ValidTo ve ValidFrom alanları eklenecek.

Resim-1

Read more

Dynamics 365 Finance and Operations Yeni Bir Finansal Boyut DefaultDimensin Alanı Nasıl Eklenir?

Bu yazıda Dynamics 365 Finance and Operations içinde yeni bir finansal boyut alanı tablo ve forma nasıl eklenir anlatmaya çalışacağım. Uygulama içinde iki tip boyut var birincisi stoksal boyutlar, ikincisi finansal boyutlar. Bu yazıda konumuz finansal boyutlar olacak. Öncelikle birkaç kavramı netleştirelim. DefaultDimension içinde sadece boyut bilgileri olan bir kombinasyondur. FinancialDimension ise içinde muhasebe hesabıyla birlikte boyutların olduğu bir kombinasyondur. Bu iki tipin birbirine çevrimi çok sık kullandığımız bir yapıdır. Bir de DefaultAccount var oda sadece muhasebe hesabı için kullanılan hesap kaydıdır. Bu yazıda bir tabloya DefaultDimens alnı açıp formada bütün boyutları gösterecek yapının nasıl kurulacağını anlatacağım.

Öncelikle int64 tipinde yeni bir alan oluşturalım.

Resim-1

Read more

D365 FinOps PowerSummit Introduction to Development

Merhaba,

Geçen hafta benim için faklı bir deneyim olan FinOps BootCampte İngilizce geliştirmeye giriş sunumu yaptım. Şöyleki bir kaç hafta önce Raz bende bu etkinlikte bir sunum yapmamı istedi. Konuyu bana bıraktı ama herkesin ileri seviye  konular anlatmak istediğini ama katılımcılardan bir çoğunun yeni mezun olduğunu ve başlangıç seviyesi bir konu anlatmamın daha iyi olacağını söyledi. Bende geliştirmeye yeni başlayanlar için bir çalışma yaptım. Seçtiğim  konu benim yıllardır eğitimini verdiğim ve çok  iyi bildiğim bir konu ama 1 saate İngilizce anlatmak beni biraz strese soktu.

MB-500 eğitimini baz alıp bir hazırlık yaptım ama sonradan sunum ağırlıklı değil de demo olsun istedim. D365 de canlı demo yapmak çok riskli bir çok şey ters gidebiliyor ve derlemeler uzun sürebiliyor. Bu yüzden tüm demoyu önceden başka bir ortamda hazır ettim eğer bir aksilik olurda yetişemezsem oradan devam ederim diye. Bir iki kere zaman hesabı yaptım ve tam 1 saati doldurduğumu gördüm. sunuma başladım fena da gitmiyordu kendimce tam zamanında bitirdim ama benden sonraki sunumu yapacak kişi gelmemiş bende ilk etapta anlamadım. Gelene kadar soru cevap yapalım dedik. Ben bir kaç dakikaya gelir diye düşünürken hiç gelmedi dolayısıyla 1 saat düşündüğüm sunum 2 saat oldu. son saate demoda gösteremedim bazı konuları gösterdim ve gelen soruları cevapladım. İkinci saatin bitiminde bile hala soru vardı. Organizasyon ekibi çok teşekkür etti. Böylece tüm dünyadan Dynamicscilerin takip ettiği bir etkinlikte 2 saat İngilizce sunum yapmış oldum.

Selamlar.

Dynamics 365 Finance and Operations Yeni Bir İş Akışı Nasıl Oluşturulur?

Bu yazıda Dynamics 365 Finance and Operations yeni bir iş akışı (Workflow) nasıl oluşturulur anlatmaya çalışacağım. Öncelikle yeni bir tablo ve formumuz olmalı ben örnek olsun diye FDActivityType tablosunu kullanacağım.  Adımlar halinde anlatacağım.

Resim-1

Read more

X++ :26- Extension ile Standart Bir Formun Event Metotlarına kod eklemek.

Bu yazıda Visual Studio üzerinden Extension mantığıyla standart bir formun DataSource eventlerine kod nasıl eklenir anlatmaya çalışacağım.

Önceki yazımda smmActivities’e bir alan eklemiştik. Şimdi yine smmActivities dataSource’nun bazı olaylarına kod ekleyelim. Öncelikle validateDelete koduna eklem yapmak istiyorum. Standart kod böyleymiş.

Resim-1

Öncelikle yeni bir sınıf oluşturuyorum daha önce oluşturduğum Extension formunu açıyorum. DataSource’a gelip eventlerden ilgili eventi bulup Copy event handler method diyorum.

Resim-2

Sonra bunları oluşturduğum sınıfa yapıştırıyorum ve aşağıdaki gibi içlerini dolduruyorum.

class FDSmmActivitiesFormEventHandler

{

/// <summary>

///

/// </summary>

/// <param name=”sender”></param>

/// <param name=”e”></param>

[FormDataSourceEventHandler(formDataSourceStr(smmActivities, smmActivities), FormDataSourceEventType::ValidatingDelete)]

public static void smmActivities_OnValidatingDelete(FormDataSource sender, FormDataSourceEventArgs e)

{

smmActivities smmActivities = sender.cursor(); // Bu sayede aktif kaydı aldım.

if(smmActivities.FDActivityId !=”")

{

checkFailed(“FDActivityTable Record Exist.”);

}

}

/// <summary>

///

/// </summary>

/// <param name=”sender”></param>

/// <param name=”e”></param>

[FormDataSourceEventHandler(formDataSourceStr(smmActivities, smmActivities), FormDataSourceEventType::Activated)]

public static void smmActivities_OnActivated(FormDataSource sender, FormDataSourceEventArgs e)

{

smmActivities smmActivities = sender.cursor(); // Bu sayede aktif kaydı aldım

FormRun formRun = sender.formRun(); // Form run a ulaştım

FormControl formControl =  formRun.design(0).controlName(“smmActivities_FDActivityId”); // Herhangi bir form nesnesine bu şekilde ulaşabilirim.

if(smmActivities.Status == smmActivityStatus::Read) // Örnek olsun diye yaptım çok mantıklı bir kontrol değil.

{

formControl.enabled(false);

}

else

{

formControl.enabled(true);

}

}

}

Bu yazıda Extension mantığıyla standart bir formun eventlerine nasıl kod eklenir anlatmaya çalıştım. Eski mantığa göre biraz daha zor ve uzun süren bir iş ama getirileri çok büyük. Extension bundan sonra uzun bir süre hayatımızda olacak mantığını kavrayıp bütün işleri bu mantıkla çözmeye çalışmak gerekiyor.

Selamlar.

www.fatihdemirci.net

TAGs: Microsoft Life Cycle Services, LCS, Azure, Azure DevOps, Extension, Microsoft Dynamics 365, MsDyn365FO, MsDyn365CE, MsDyn365

X++ :25- Extension ile Standart Bir Tablo Metoduna Ekleme Yapmak.

Bu yazıda Visual Studio üzerinden Extension mantığıyla standart bir tablo metoduna kod nasıl eklenir anlatmaya çalışacağım.

Önceki yazımda smmActivities’e bir metot eklemiştim. Şimdi yine smmActivities’te bir kayıt oluşturulduğunda bu metodu tetiklemek için ne yapmalıyız anlatacağım. Öncelikle bir sınıf oluşturalım. Sonrasında resimde olduğu gibi smmActivities için daha önce oluşturduğumuz Extension üzerinden Copy event handler method deyip post olanı kopyalıyoruz.

Resim-1

class FDSmmActivitiesEventHandler

{

/// <summary>

///

/// </summary>

/// <param name=”args”></param>

[PostHandlerFor(tableStr(smmActivities), tableMethodStr(smmActivities, insert))] // Bu kısım bizim için gerekli tanımları yapıyor.

public static void smmActivities_Post_insert(XppPrePostArgs args)

{

smmActivities smmActivities;

;

smmActivities = args.getThis(); // GetThis() ile üzerinde bulunduğumuz kaydı alıyoruz.

smmActivities.createFDActivityTable(smmActivities); // Bir önceki yazıda oluşturduğumuz metot.

}

/// <summary>

///

/// </summary>

/// <param name=”args”></param>

[PreHandlerFor(tableStr(smmActivities), tableMethodStr(smmActivities, validateField))] // Aynı şekilde validateField metodunun bu sefer preHandler oluşturuyoruz.

public static void smmActivities_Pre_validateField(XppPrePostArgs args)

{

}

}

Bu yazıda standart bir tablo metoduna pre post eventHandler nasıl eklenir anlatmaya çalıştım. Burada da isimlendirmeye dikkat etmek lazım.

Selamlar.

www.fatihdemirci.net

TAGs: Microsoft Life Cycle Services, LCS, Azure, Azure DevOps, Extension, Microsoft Dynamics 365, MsDyn365FO, MsDyn365CE, MsDyn365

Page 5 of 40« First...34567102030...Last »