60
votes

I had a VB projected and converted it to C# using online conversion tools. Now the problem is xaml and xaml.cs file do not connect to each other, that is they don't recognize their dependencies (Red area in Fig). Actually it should appear like Window1 Files (Green Area in the image.) How can I achieve this.

Solution Explorer

I am trying my hands on WPF so may be a layman sort of question.

12

12 Answers

78
votes

This is simple, try to add in project existing items and select the XAML (not .cs, etc.) files in list of formats. In VS2010 thats helps.

56
votes

If you cannot get the IDE to do it (Papa John's post), then you can do it by editing the project file.

That information is in the .csproj file (which is an XML file -- you can open it in a text editor, or by right-clicking on it, choosing "unload", and then opening it -- choose reload to load it up as a project again).

Here is the information to look for, you would need to add the "DependentUpon" tag.

<Compile Include="TheFile.xaml.cs">
  <DependentUpon>TheFile.xaml</DependentUpon>
</Compile>
26
votes

Easiest Way!!!

I came across the same. I got the way out. Here is how to get the .xaml.cs nested under the .xaml in Solution Explorer:

  1. In Windows File Explorer (outside of Visual Studio), open the folder where the required files are.
  2. Select both files (.xaml and .xaml.cs) together.
  3. Drag it onto your project name in the Solution Explorer.
  4. Its done! :)
8
votes

Using a Xamarin PCL Solution:

1) Go to your PCL folder and open your MySolution.csproj file

2) There should be several groups of <ItemGroup> tags. One of them declares <EmbeddedResource> tags and another will contain, <Compile> <DependentUpon></DependentUpon></Compile> groups of tags.

3) For MyPage.xaml and MyPage.xaml.cs files to be linked, you must have a group of xmls that declare your xaml page.

<EmbeddedResource Include="MyPage.xaml">
      <Generator>MSBuild:UpdateDesignTimeXaml</Generator>
      <LogicalName>MyPage.xaml</LogicalName>
</EmbeddedResource>
<Compile Include="MyPage.xaml.cs">
      <DependentUpon>MyPage.xaml</DependentUpon>
</Compile>

Note that if your page is in a folder you should specify that like so:

<Compile Include="Views\MyPage.xaml.cs">
      <DependentUpon>MyPage.xaml</DependentUpon>
</Compile>
<EmbeddedResource Include="Views\MyPage.xaml">
      <Generator>MSBuild:UpdateDesignTimeXaml</Generator>
      <LogicalName>MyPage.xaml</LogicalName>
</EmbeddedResource>

Note that this works with OSX and Windows

5
votes

Based on Kyle White's comment on the official Xamarin bug report 55591: .xaml files in .NETStandard library appear twice in solution explorer, I found a simple solution to this problem within the linked .NET Standard sample project by Oren Novotny

Within your .csproj file, add the following <ItemGroup>:

<ItemGroup>
  <Compile Update="**\*.xaml.cs" DependentUpon="%(Filename)" />
  <EmbeddedResource Include="**\*.xaml" SubType="Designer" Generator="MSBuild:UpdateDesignTimeXaml" LogicalName="%(Filename)%(Extension)" />
</ItemGroup>

Afterwards, all xaml files within the project structure will be displayed in the Solution Explorer window automatically - even if you'll ever add new xaml files.

How does this magic work?

The Compile element within the ItemGroup is using wildcards to iterate through all directories, searching for .xaml.cs files and marking them as dependent on the xaml files of the same name. Please note that this works only because the %(Filename) item metadata used for the DependentUpon element contains the left-most file extension, which matches the name of the xaml file by convention. The EmbeddedResource element will include all xaml files to the project, so that they are visible within the Solution Explorer window while marking them as Designer files, and declaring that the UpdateDesignTimeXaml target defined within the Xamarin.Forms NuGet package should be used to generate code from the markup file.

3
votes

Using Xamarin Shared Code solution:

1) Go to you project folder after unloading the shared project

2) Find the projitems file and edit that adding the DependentUpon tag as described in other answers above.

3) Save the file

4) Go back to visual studio and you should get a dialog that allows you to reload all or just open the project again.

3
votes

An even easier and faster solution for Xamarin Forms projects, no need to touch csproj file at all, very quick fix.

Make sure you have Show All Files selected for solution explorer - it may be on by default.

  1. Select all affected files
  2. Right click > Exclude from Project
  3. Select the same files again (should be faded out)
  4. Right Click > Include in Project

They should now all be nested correctly and all the changes necessary to the .csproj file will be done.

You may have an InitializeComponent() does not exist in the current context) error after this. If that's the case, the simple fix is..

  • Select all affected items and change Build Action from Page to Embedded Resource
1
votes

If you get the Nested File VS Extension, you can do this by right clicking similarly named files and choosing to "nest automatically" or you can nest manually.

https://marketplace.visualstudio.com/items?itemName=MadsKristensen.FileNesting

1
votes

In a Shared Project there is .shproj file instead of a .csproj file and the and items do not exist there. However I found there is also a .projitems file and adding a section there as described above caused the .xaml and .cs files to be linked

1
votes

I was able to just restart Visual Studio for Mac 2019 v16.2 and it reconnected my .xaml & .cs files that should've been connected.

If that doesn't work, Hitsa's solution worked for me as well on a separate occasion.

0
votes

The usual - Close Visual Studio, delete the vs folder in the root folder of your solution and reopen Visual Studio (2019) just worked for me.

0
votes

For VS 2019, you have only to edit .csproj file and eliminate all references to .xaml.cs file es:

<ItemGroup>
    <Folder Include="Models\" />
    <Folder Include="Services\" />
    <Folder Include="ViewModels\" />
  </ItemGroup>

  <ItemGroup>
    <EmbeddedResource Update="Views\MyPage.xaml">
      <LogicalName>MyPage.xaml</LogicalName>
    </EmbeddedResource>
  </ItemGroup>