سلام؛ تعدادی از کلاسهایی که الان در پروژه وب قرار دارن مثل HtmlCleaner ، HttpCompress، RSS و امثال اینها بهتره از پروژه وب خارج بشن و به پروژه Common منتقل شوند.
بازخوردهای پروژهها
نکته : برای فهم بهتر مفاهیم، آشنایی اولیه با MEF و مفاهیمی نظیر Export و Import و AggregateCatalog و AssemblyCatalog نیاز است. در صورتی که با این مطالب آشنایی ندارید میتوانید از (^) شروع کنید.
<UserControl x:Class="Module1.Module1View1" xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" FlowDirection="RightToLeft" FontFamily="Tahoma"> <StackPanel> <sdk:DataGrid Height="100"> <sdk:DataGrid.Columns> <sdk:DataGridTextColumn Header="کد" Width="50" /> <sdk:DataGridTextColumn Header="عنوان" Width="200" /> <sdk:DataGridTextColumn Header="نویسنده" Width="150" /> </sdk:DataGrid.Columns> </sdk:DataGrid> <Button x:Name="NextViewButton" Width="150" Height="25" Foreground="Red" Background="Blue" Content="لیست طبقه بندی ها" /> </StackPanel> </UserControl>
[Export(typeof(Module1View1))] public partial class Module1View1 : UserControl { [Import] public IRegionManager TheRegionManager { private get; set; } public Module1View1() { InitializeComponent(); NextViewButton.Click += NextViewButton_Click; } void NextViewButton_Click(object sender, RoutedEventArgs e) { TheRegionManager.RequestNavigate ( "MyRegion1", new Uri("Module1View2", UriKind.Relative), a => { } ); } }
<UserControl xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk" x:Class="Module1.Module1View2" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" FlowDirection="RightToLeft" FontFamily="Tahoma"> <StackPanel> <sdk:DataGrid Height="100"> <sdk:DataGrid.Columns> <sdk:DataGridTextColumn Header="کد" Width="150"/> <sdk:DataGridTextColumn Header="عنوان" Width="150"/> </sdk:DataGrid.Columns> </sdk:DataGrid> <Button x:Name="NextViewButton" Width="150" Height="25" Foreground="Green" Background="Yellow" Content="لیست کتاب ها" /> </StackPanel> </UserControl>
using Microsoft.Practices.Prism.Regions; using System; using System.ComponentModel.Composition; using System.Windows; using System.Windows.Controls; namespace Module1 { [Export] public partial class Module1View2 : UserControl { IRegion _region1; [ImportingConstructor] public Module1View2( [Import] IRegionManager regionManager ) { InitializeComponent(); ViewModel viewModel = new ViewModel(); DataContext = viewModel; viewModel.ShouldNavigateFromCurrentViewEvent += () => { return true; }; _region1 = regionManager.Regions["MyRegion1"]; NextViewButton.Click += NextViewButton_Click; } void NextViewButton_Click( object sender, RoutedEventArgs e ) { _region1.RequestNavigate ( new Uri( "Module1View1", UriKind.Relative ), a => { } ); } } }
using System; using System.Net; using System.Windows; using System.Windows.Controls; using System.Windows.Documents; using System.Windows.Ink; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Animation; using System.Windows.Shapes; using System.ComponentModel.Composition; using Microsoft.Practices.Prism.Regions; namespace Module1 { public class ViewModel : IConfirmNavigationRequest { public event Func<bool> ShouldNavigateFromCurrentViewEvent; public bool IsNavigationTarget( NavigationContext navigationContext ) { return true; } public void OnNavigatedTo( NavigationContext navigationContext ) { } public void OnNavigatedFrom( NavigationContext navigationContext ) { } public void ConfirmNavigationRequest( NavigationContext navigationContext, Action<bool> continuationCallback ) { bool shouldNavigateFromCurrentViewFlag = false; if ( ShouldNavigateFromCurrentViewEvent != null ) shouldNavigateFromCurrentViewFlag = ShouldNavigateFromCurrentViewEvent(); continuationCallback( shouldNavigateFromCurrentViewFlag ); } } }
using Microsoft.Practices.Prism.MefExtensions.Modularity; using Microsoft.Practices.Prism.Modularity; using Microsoft.Practices.Prism.Regions; using System.ComponentModel.Composition; namespace Module1 { [ModuleExport(typeof(Module1Impl))] public class Module1Impl : IModule { [Import] public IRegionManager TheRegionManager { private get; set; } public void Initialize() { TheRegionManager.RegisterViewWithRegion("MyRegion1", typeof(Module1View1)); TheRegionManager.RegisterViewWithRegion("MyRegion1", typeof(Module1View2)); } } }
<UserControl x:Class="NavigationViaViewModel.Shell" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:prism="http://www.codeplex.com/prism" FlowDirection="RightToLeft" FontFamily="Tahoma"> <Grid x:Name="LayoutRoot" Background="White"> <TextBlock Text="لیست کتابها به همراه طبقه بندی آن ها" FontSize="19" Foreground="Black" HorizontalAlignment="Center" VerticalAlignment="Top" /> <ContentControl HorizontalAlignment="Center" VerticalAlignment="Center" prism:RegionManager.RegionName="MyRegion1" /> </Grid> </UserControl>
using Microsoft.Practices.Prism.MefExtensions; using Microsoft.Practices.Prism.Modularity; using System.ComponentModel.Composition.Hosting; using System.Windows; namespace NavigationViaViewModel { public class TheBootstrapper : MefBootstrapper { protected override void InitializeShell() { base.InitializeShell(); Application.Current.RootVisual = (UIElement)Shell; } protected override DependencyObject CreateShell() { return Container.GetExportedValue<Shell>(); } protected override void ConfigureAggregateCatalog() { base.ConfigureAggregateCatalog(); AggregateCatalog.Catalogs.Add(new AssemblyCatalog(this.GetType().Assembly)); } protected override IModuleCatalog CreateModuleCatalog() { ModuleCatalog moduleCatalog = new ModuleCatalog(); moduleCatalog.AddModule ( new ModuleInfo { InitializationMode = InitializationMode.WhenAvailable, Ref = "Module1.xap", ModuleName = "Module1Impl", ModuleType = "Module1.Module1Impl, Module1, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" } ); return moduleCatalog; } } }
public partial class App : Application { public App() { this.Startup += this.Application_Startup; InitializeComponent(); } private void Application_Startup(object sender, StartupEventArgs e) { var bootstrapper = new TheBootstrapper(); bootstrapper.Run(); } }
<Comp1>This is a content coming from the parent</Comp1>
@page "/ParentComponent" <h1 class="text-danger">Parent Child Component</h1> <ChildComponent Title="This title is passed as a parameter from the Parent Component"> A `Render Fragment` from the parent! </ChildComponent> <ChildComponent Title="This is the second child component"></ChildComponent> @code { }
<li class="nav-item px-3"> <NavLink class="nav-link" href="ParentComponent"> <span class="oi oi-list-rich" aria-hidden="true"></span> Parent/Child Relation </NavLink> </li>
<div> <div class="alert alert-info">@Title</div> <div class="alert alert-success"> @if (ChildContent == null) { <span> Hello, from Empty Render Fragment </span> } else { <span>@ChildContent</span> } </div> </div> @code { [Parameter] public string Title { get; set; } [Parameter] public RenderFragment ChildContent { get; set; } }
<button class="btn btn-danger" @onclick="@(() => OnClickBtnMethod.InvokeAsync((1, "A message from child!")))"> Show a message from the child! </button> @code { // ... [Parameter] public EventCallback<(int, string)> OnClickBtnMethod { get; set; } }
@page "/ParentComponent" <h1 class="text-danger">Parent Child Component</h1> <ChildComponent OnClickBtnMethod="ShowMessage" Title="This title is passed as a parameter from the Parent Component"> A `Render Fragment` from the parent! </ChildComponent> <ChildComponent Title="This is the second child component"> <p><b>@MessageText</b></p> </ChildComponent> @code { string MessageText = ""; private void ShowMessage((int Value, string Message) args) { MessageText = args.Message; } }
@code { // ... [Parameter] public RenderFragment ChildContent { get; set; } [Parameter] public RenderFragment DangerChildContent { get; set; } }
<ChildComponent OnClickBtnMethod="ShowMessage" Title="This title is passed as a parameter from the Parent Component"> <ChildContent> A `Render Fragment` from the parent! </ChildContent> <DangerChildContent> A danger content from the parent! </DangerChildContent> </ChildComponent>
@if(DangerChildContent == null) { @if (ChildContent == null) { <span> Hello, from Empty Render Fragment </span> } else { <span>@ChildContent</span> } } else { <span>@DangerChildContent</span> }
For .NET Core 3.0, we’re shipping a brand new namespace called System.Text.Json with support for a reader/writer, a document object model (DOM), and a serializer. In this blog post, I’m telling you why we built it, how it works, and how you can try it.
namespace jqGrid10.Models { public class Post { public int Id { set; get; } public string Title { set; get; } public string CategoryName { set; get; } public int NumberOfViews { set; get; } } }
$('#list').jqGrid({ caption: "آزمایش دهم", //... grouping: true, groupingView: { groupField: ['CategoryName'], groupOrder: ['asc'], groupText : ['<b>{0} - {1} ردیف</b>'], groupDataSorted: true, groupColumnShow: false, groupCollapse: true, groupSummary: [true], showSummaryOnHide: true } });
colModel: [ // ........ { name: '@(StronglyTyped.PropertyName<Post>(x => x.Title))', index: '@(StronglyTyped.PropertyName<Post>(x => x.Title))', align: 'right', width: 150, summaryTpl: '<div style="text-align: left;">خلاصه </div>', summaryType: function (val, name, record) { return ""; } }, // ........ { name: '@(StronglyTyped.PropertyName<Post>(x => x.NumberOfViews))', index: '@(StronglyTyped.PropertyName<Post>(x => x.NumberOfViews))', align: 'center', width: 70, summaryType: 'sum', summaryTpl: '<b>جمع مشاهدات: {0}</b>' } ],
$('#list').jqGrid({ caption: "آزمایش دهم", //......... loadComplete: function() { //......... $('#list').jqGrid('groupingToggle', 'list' + 'ghead_0_0'); $("tr.jqfoot td").css({ "background": "#2f4f4f", "color": "#FFF" }); }, });