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

feat: Add XAML Fundamentals section with pages and examples #1661

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

Conversation

Zakariathr22
Copy link
Contributor

@Zakariathr22 Zakariathr22 commented Nov 21, 2024

Description

This pull request introduces the "XAML Fundamentals" section, including pages and examples for XAML Resources, XAML Styles, Binding, and Templates, main changes are:

  • Added sample code files for XAML Resources, XAML Styles, Binding, and Templates.
  • Added new assets for theme resource examples and updated control images.
  • Updated ControlInfoData.json to include the new "XAML Fundamentals" section.
  • Added pages for XAML Resources, XAML Styles, Binding, and Templates, each with practical examples.
  • Updated navigation to include the new section and handle its items programmatically.

Motivation and Context

I noticed that many learners, especially those new to WinUI 3, often turn to the WinUI 3 Gallery application as their starting point. While the app provides excellent explanations of controls and code samples, it sometimes introduces concepts that may be unfamiliar to beginners.

To address this, I had created a dedicated section in the application called XAML Fundamentals. This section is organized into key topics, including: XAML Resources, XAML Styles, Binding, and Templates.

The goal is to help learners better understand these foundational concepts by providing clear explanations, practical examples, and links to relevant documentation.

How Has This Been Tested?

This code was tested manually, and no issues were encountered during the testing. The changes are isolated to the new section and do not affect other areas of the app.

Screenshots:

XAML Resouces Page
image

XAML Styles
image

Binding
image

Templates
image

Search Page
image

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to change)

… and navigation updates

1. Added sample code files for Resources, ResourceDictionary, Theme Resources, XAML Styles, Binding, and Templates.
2. Added new assets for theme resource examples and updated control images.
3. Updated `ControlInfoData.json` to include the new "XAML Fundamentals" section.
4. Added pages for Resources, ResourceDictionary, Theme Resources, XAML Styles, Binding, and Templates, each with practical examples.
5. Updated navigation to include the new section and handle its items programmatically.
@Zakariathr22 Zakariathr22 changed the title **feat**: Add XAML Fundamentals section with pages and examples feat: Add XAML Fundamentals section with pages and examples Nov 21, 2024
@Zakariathr22 Zakariathr22 marked this pull request as draft November 22, 2024 11:38
@Zakariathr22 Zakariathr22 marked this pull request as ready for review November 22, 2024 18:18
@Jay-o-Way

This comment was marked as resolved.

@Zakariathr22
Copy link
Contributor Author

Nit: note the unnecessary use of Capital letters for a number of Words.

Adjusted as suggested.

@Jay-o-Way

This comment was marked as resolved.

Jay-o-Way

This comment was marked as resolved.

@Jay-o-Way
Copy link
Contributor

@niels9001 @karkarl (off-topic) I feel issue #1542 is quickly getting more and more important!

@Jay-o-Way
Copy link
Contributor

Did you know?

Note

Starting in Windows 10, version 1607, the XAML framework provides a built in Boolean to Visibility converter. The converter maps true to the Visible enumeration value and false to Collapsed so you can bind a Visibility property to a Boolean without creating a converter. Note that this is not a feature of function binding, only property binding. To use the built in converter, your app's minimum target SDK version must be 14393 or later. You can't use it when your app targets earlier versions of Windows 10. For more info about target versions, see Version adaptive code.

https://learn.microsoft.com/windows/uwp/xaml-platform/x-bind-markup-extension#remarks

@Zakariathr22
Copy link
Contributor Author

@Jay-o-Way
Thank you for your review and insightful feedback; I’ll work on implementing your suggestions.
Please let me know if there’s anything else I should address.

@Zakariathr22 Zakariathr22 marked this pull request as draft November 29, 2024 07:14
… theme resources.

- Simplified the comparison table between `x:Bind` and `Binding` and reduce repetition by using styles.
- Added the default binding mode for each type in the comparison table for better clarity.
- Removed hardcoded colors and replaced them with theme resources.
- Added two new examples:
* Demonstrating converters using `x:Bind`.
* Showing `Binding` with `FallbackValue` and `TargetNullValue`.
- Made minor design tweaks.
@Zakariathr22 Zakariathr22 marked this pull request as ready for review November 29, 2024 21:30
Jay-o-Way

This comment was marked as resolved.

Jay-o-Way

This comment was marked as resolved.

Copy link
Contributor

@niels9001 niels9001 left a comment

Choose a reason for hiding this comment

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

LGTM! Amazing work @Zakariathr22!

@Zakariathr22
Copy link
Contributor Author

@niels9001
Thank you for your help and reviews; they made a significant difference.

@niels9001
Copy link
Contributor

@Zakariathr22 We've reviewed the PR and saw some (minor) improvements we could make.

Would you mind getting the latest changes from main and can I PR against your branch? It's probably faster that way :)!

@Zakariathr22
Copy link
Contributor Author

Zakariathr22 commented Dec 15, 2024

Would you mind getting the latest changes from main and can I PR against your branch? It's probably faster that way :)!

@niels9001

The latest changes from main have been retrieved

Sure, feel free to go ahead, thanks for helping out!

@Zakariathr22
Copy link
Contributor Author

@niels9001
I can also grant you a write access if you like :)

@marcelwgn
Copy link
Contributor

Below my thoughts on the current content:

Theme resources page:

  • Also, do we need a "visual" example for resource dictionaries if it looks almost the same as the previous example?
  • I think having the following XAML as example of how resource scoping works might be a bit more helpful and in the source code, we reference the same brush every time so it is clear what is happening.
    Image of three nested boxes

Styling page:

  • The blue styled button flashes white upon hovering (at least in dark theme)
  • Do we want to show non key based styling? It feels a bit of an anti pattern to teach it since I think you would ignore the base style through that pattern
  • Not sure what the last example is trying to tell since the first example already uses BasedOn. I think it would be better to explain it there and skip that example

Binding page:

  • For the one way and two way binding, I would probably use two columns to be able to compare it side by side instead of that toggle.
  • Maybe we should use a more interesting converter than the nullability/visibility one given that already is handled somewhat natively already?
  • Should we call out some of the key differences between x:Bind and binding instead of linking to the docs outright?

@AndrewKeepCoding
Copy link
Contributor

IMHO, the API details button (the i button) is confusing in this case because Resources, Styles, Binding and Templates represent features rather than classes.

image

@Jay-o-Way
Copy link
Contributor

  • The blue styled button flashes white upon hovering (at least in dark theme)

Yep, the hover state is not affected...

  • Maybe we should use a more interesting converter than the nullability/visibility one given that already is handled somewhat natively already?

Good one!

  • Should we call out some of the key differences between x:Bind and binding instead of linking to the docs outright?

We actually had that, but Niels wanted it changed #1661 (comment)

@Zakariathr22
Copy link
Contributor Author

Zakariathr22 commented Jan 8, 2025

Hi @marcelwgn, thanks for sharing this!

  • I think having the following XAML as example of how resource scoping works might be a bit more helpful and in the source code, we reference the same brush every time so it is clear what is happening.
    Image of three nested boxes

Great idea! I’ll do it.

  • Also, do we need a "visual" example for resource dictionaries if it looks almost the same as the previous example?

You’re right; it’s quite similar to the previous example. I have two ideas to fix this:

  1. Leave it as it is, since I’ll update the previous example as you suggested.
  2. Or Remove the example and replace it with a code presenter instead.

What do you think?

  • The blue styled button flashes white upon hovering (at least in dark theme)

Yes, I didn’t realize that either. I think we should apply the style to a different type of control or a different type of styling. Do you have any suggestions?

  • Do we want to show non key based styling? It feels a bit of an anti pattern to teach it since I think you would ignore the base style through that pattern

I think by presenting non-key-based styles, the user understands how styles are automatically applied to specific control types. This helps the user grasp the concept of TargetType and see the connection between styles and controls more clearly.

  • Not sure what the last example is trying to tell since the first example already uses BasedOn. I think it would be better to explain it there and skip that example

Actually, the BasedOn property wasn’t implemented in the first example initially. We only added it to meet a11y requirements, as Niels requested here
For that reason, I can modify the first example as I suggested earlier without needing to use BasedOn. Do you think that would be a good idea?

  • For the one way and two way binding, I would probably use two columns to be able to compare it side by side instead of that toggle.
  • Maybe we should use a more interesting converter than the nullability/visibility one given that already is handled somewhat natively already?

Very good ideas.

  • Should we call out some of the key differences between x:Bind and binding instead of linking to the docs outright?

As Jay mentioned, we actually had that setup before, but Niels wanted it changed, and I agree with Niels on this point.

this is something we should keep in the docs only? We should focus on samples for WinUI Gallery, and the link you have to MS Learn might already be sufficient

@Zakariathr22
Copy link
Contributor Author

Hi @AndrewKeepCoding, thanks for sharing your opinion,

IMHO, the API details button (the i button) is confusing in this case because Resources, Styles, Binding and Templates represent features rather than classes.

  • Style is a class in the Microsoft.UI.Xaml namespace. Check it out here.
  • The templates, including ControlTemplate, DataTemplate, and ItemsPanelTemplate, are classes in the Microsoft.UI.Xaml.Controls namespace. You can explore them here: ControlTemplate, DataTemplate, and ItemsPanelTemplate.
  • As for the others, it’s not entirely clear. We have ResourceDictionary as a class, but Resources and Theme Resources aren't.
  • The same applies to Binding, but x:Bind is not a class.

Do you have any suggestions?

@Jay-o-Way, I'd like also to know your thoughts on this.

@Zakariathr22
Copy link
Contributor Author

@marcelwgn #1661 (comment)

Copy link
Contributor

@marcelwgn marcelwgn left a comment

Choose a reason for hiding this comment

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

Thank you for making those adjustments @Zakariathr22 ! Below my thoughts:

The blue styled button flashes white upon hovering (at least in dark theme)

I think this is addressed now?

I think by presenting non-key-based styles, the user understands how styles are automatically applied to specific control types. This helps the user grasp the concept of TargetType and see the connection between styles and controls more clearly.

I see your point, it is good to showcase how TargetType works. I guess we can leave it in.

Actually, the BasedOn property wasn’t implemented in the first example initially. We only added it to meet a11y requirements, as Niels requested #1661 (comment)
For that reason, I can modify the first example as I suggested earlier without needing to use BasedOn. Do you think that would be a good idea?

I think the A11Y issues could have been fixed without BasedOn but I think its still good practice to use based on. Can we merge the first and basedon sample to avoid this duplication maybe?

</RichTextBlock>

<RichTextBlock>
<Paragraph FontWeight="SemiBold">Reasons for using resource dictionaries:</Paragraph>
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 most of these points are more accurate for resources. ResourceDictionaries on their own are generally only reusable, and I have not seen that very often (i.e. a ResourceDictionary used multiple times throughout one project). In my experience, most of the time RDs are created because XAML needs you to so you can define resources. I would argue we could remove the RD section given that the code sample is also very similar. @niels9001 what do you think?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@marcelwgn @niels9001
I included the ResourceDictionary part because it's very important for defining new theme resources, as it's explained in the next part, and it helps organize resources within a theme. However, if you think explaining it is not as necessary, I can remove it and focus on the core concept of using theme resources directly.

Copy link
Contributor Author

@Zakariathr22 Zakariathr22 Jan 14, 2025

Choose a reason for hiding this comment

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

@niels9001 Should we keep the ResourceDictionary part for its role in defining and organizing theme resources, or remove it?

Edit: I may not be available when you see this, but you still have write access to the branch, so please feel free to proceed with whatever you believe is best.

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

Successfully merging this pull request may close these issues.

5 participants