Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Private/waabusea/move media to resources #2391

Open
wants to merge 5 commits into
base: main
Choose a base branch
from

Conversation

WaelAbuSeada
Copy link
Member

@WaelAbuSeada WaelAbuSeada commented Nov 23, 2024

Summary

Media files will not exists in "Media resources" table anymore, instead will be added as resources to the appropriate app. For system layer, adding wizard images to guided experience. As well as copilot image when service is not available

Fixes #460898

@WaelAbuSeada WaelAbuSeada requested review from a team as code owners November 23, 2024 21:28
Copy link

Issue #460898 is not valid. Please make sure you link an issue that exists, is open and is approved.

@WaelAbuSeada WaelAbuSeada requested a review from a team as a code owner November 24, 2024 20:15
src/System Application/App/AI/app.json Show resolved Hide resolved
@@ -88,6 +88,11 @@
"id": "4af62c1c-2f6d-4574-ba34-bb5c149cdf93",
"name": "Guided Experience Test",
"publisher": "Microsoft"
},
{
"id": "d3433b68-4901-445f-9547-fdfeca57575a",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think we should encourage this, using internalsvisibleto can easily get out of hand.
Create an API in the GuidedExperience Facade and use ModuleInfo to block non-Microsoft from invoking it.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

True, I was just considering if this is something we would like to make internal or not. Probably no need and I will switch it to public.

Copy link
Contributor

@haoranpb haoranpb left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I understand the part

"instead will be added as resources to the appropriate app."

But can you elaborate on this?

Media files will not exists in "Media resources" table anymore

Comment on lines -108 to +111
if MediaResources.Get('COPILOTNOTAVAILABLE.PNG') then
BannerVisible := MediaResources."Media Reference".HasValue;
BannerVisible := GuidedExperience.LoadFileFromTenantMediaSet(TenantMediaSet, 'CopilotNotAvailable.png');
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure I understand, why are we loading Media using procedures from GuidedExperience here?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We are loading wizard images from tenant media set, there is a fine line of ownership I agree. but it is the best place I could find

if MediaResourcesStandard.Get('ASSISTEDSETUP-NOTEXT-400PX.PNG') and
MediaResourcesDone.Get('ASSISTEDSETUPDONE-NOTEXT-400PX.PNG') and (CurrentClientType() = ClientType::Web)
then
TopBannerVisible := MediaResourcesDone."Media Reference".HasValue();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same here, are we taking dependency from Email module to Guided Experience to load Media?

I see we have a System Module called Image, might be more suitable for this purpose

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I also think that Guided Experince doesn't fit, but the existing image modules don't really either.

Comment on lines +447 to +477
/// <summary> Loads Assisted Setup top banners from tenant media set.</summary>
/// <param name="TenantMediaSetStandard">Tenant Media set record by var for standard image.</param>
/// <param name="TenantMediaSetCompleted">Tenant Media set record by var for done image.</param>
/// <param name="TenantMediaSetInfo">Tenant Media set record by var for info image.</param>
/// <returns>True if the top banners are loaded successfuly</returns>
procedure LoadTopBanners(var TenantMediaSetStandard: Record "Tenant Media Set"; var TenantMediaSetCompleted: Record "Tenant Media Set"; var TenantMediaSetInfo: Record "Tenant Media Set"): Boolean
begin
exit(GuidedExperienceImpl.LoadTopBanners(TenantMediaSetStandard, TenantMediaSetCompleted, TenantMediaSetInfo));
end;

/// <summary> Loads an image from tenant media set.</summary>
/// <param name="TenantMediaSet">Tenant Media set record by var for standard image.</param>
/// <param name="FileName">Image name.</param>
/// <returns>True if the the image is loaded successfuly</returns>
procedure LoadFileFromTenantMediaSet(var TenantMediaSet: Record "Tenant Media Set"; FileName: Text[250]): Boolean
var
begin
exit(GuidedExperienceImpl.LoadFileFromTenantMediaSet(TenantMediaSet, FileName));
end;

/// <summary> Insert an image to tenant media set from system app resources.</summary>
/// <param name="TenantMediaSet">Tenant Media set record by var for standard image.</param>
/// <param name="FilePath">Path to file name.</param>
/// <param name="FileName">File name.</param>
/// <returns>True if the the image is loaded successfuly</returns>
internal procedure InsertSystemFileToTenantMediaSet(var TenantMediaSet: Record "Tenant Media Set"; FilePath: Text[100]; FileName: Text[250])
var
begin
GuidedExperienceImpl.InsertSystemFileToTenantMediaSet(TenantMediaSet, FilePath, FileName);
end;

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure how those procedures fit in Guided Experience, consider Image module per previous comment

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

First one, is strictly for banners in a wizard, and should definitely be there. The problem with the rest is that they are not really only for images, as resources can be anything in the future

@pri-kise
Copy link
Contributor

Before the images are removed from the MediaResources please add good alternatives and wait for the cleanup the common period of time, that partners are able to refactor their wizards.

And please update the new documentation for wizard creation then, too.
https://learn.microsoft.com/en-us/dynamics365/business-central/dev-itpro/developer/devenv-designing-navigate-pages
The same applies for the learning path.
Currenlty the MediaResources are used in the example for wizards.

As soon as the examples is updated and you provide a good mechanis to get those images in custom wizards then we're able to refactor our code and update common snippets (https://github.com/waldo1001/crs-al-language-extension/blob/master/snippets/page.json)

@TKapitan
Copy link
Contributor

TKapitan commented Dec 8, 2024

As @pri-kise said, it needs to follow the proper obsoletion path. But I'm not sure how to notify partners in pipeline about this change. Without this, you can be sure there will be many complains once this is removed from tenant media as there is certainly hundreds of apps that are using these resources as it was (still is) part of the learning path and official examples how to build this kind of pages.

exit(TenantMediaSet."Media ID".HasValue);
end;

procedure InsertSystemFileToTenantMediaSet(var TenantMediaSet: Record "Tenant Media Set"; FilePath: Text[100]; FileName: Text[250])
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this procedure should be set to local. I would like a function that first looks in the tenant media, if there is nothing there, then it should be inserted from the resources.
And then the FilePath is also useless, it is currently always "images/".

@@ -36,10 +36,13 @@
"TranslationFile",
"GenerateCaptions"
],
"resourceFolders": [
".resources"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are you using .ressource because ressources is not possible? At least that's what I've discovered. Dot folders are currently always for content that is not repository relevant. Like .alpackages, .vscode, .snapshots. I would prefer data here.

src/System Application/App/AI/app.json Show resolved Hide resolved
if MediaResourcesStandard.Get('ASSISTEDSETUP-NOTEXT-400PX.PNG') and
MediaResourcesDone.Get('ASSISTEDSETUPDONE-NOTEXT-400PX.PNG') and (CurrentClientType() = ClientType::Web)
then
TopBannerVisible := MediaResourcesDone."Media Reference".HasValue();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I also think that Guided Experince doesn't fit, but the existing image modules don't really either.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants