Merge commit 'acd2a473bbf4f3006e40384a45413a4db177b082'

Conflicts:
	ChangeLog
	ITContentProvider/ChangeLog
	Makefile
	NpgsqlBlogProvider/ChangeLog
	NpgsqlContentProvider/ChangeLog
	NpgsqlMRPProviders/ChangeLog
	TestAPI/ChangeLog
	web/App_Themes/style.css
	web/ChangeLog
	web/Helpers/YavscHelpers.cs
	web/Models/App.master
	web/Views/Blogs/UserPosts.aspx
main
Paul Schneider 10 years ago
commit 303e4fa57b
21 changed files with 143 additions and 1330 deletions

@ -1,28 +0,0 @@
2015-10-04 Paul Schneider <paul@pschneider.fr>
* Makefile: cleaner code
2015-08-20 Paul Schneider <paul@pschneider.fr>
* Yavsc.sln: Adds the `Presta` project
2015-08-14 Paul Schneider <paul@pschneider.fr>
* README.md: blanked: not clear enough
2015-07-17 Paul Schneider <paul@pschneider.fr>
* Yavsc.sln:
2015-06-09 Paul Schneider <paul@pschneider.fr>
* Yavsc.sln: creates a packaging project
2015-06-07 Paul Schneider <paul@pschneider.fr>
* Makefile: cleans the StyleCop cache
2015-06-06 Paul Schneider <paul@pschneider.fr>
* Yavsc.sln: modifies the Version control integration

@ -1,18 +0,0 @@
2015-10-01 Paul Schneider <paul@pschneider.fr>
* packages.config:
* ITContentProvider.csproj:
2015-07-15 Paul Schneider <paul@pschneider.fr>
* ITContentProvider.csproj: Moves to Mono framework
2015-06-10 Paul Schneider <paul@pschneider.fr>
* ITContentProvider.csproj:
2015-06-09 Paul Schneider <paul@pschneider.fr>
* ITContentProvider.csproj: Helps to fix packaging, and cleans
dependencies

@ -1,35 +0,0 @@
2015-10-01 Paul Schneider <paul@pschneider.fr>
* packages.config:
* NpgsqlBlogProvider.csproj:
2015-09-27 Paul Schneider <paul@pschneider.fr>
* NpgsqlBlogProvider.cs: Fixes the sql command preparation
2015-09-23 Paul Schneider <paul@pschneider.fr>
* NpgsqlBlogProvider.cs: refactoring: The `UserName` property
from the `BlogEntry` class is renamed to `Author`
2015-08-04 Paul Schneider <paul@pschneider.fr>
* NpgsqlBlogProvider.cs: * Remove post by id
* Manage collections of entries on a couple (user,title), not
a single post
2015-07-15 Paul Schneider <paul@pschneider.fr>
* NpgsqlBlogProvider.csproj: Moves to Mono framework
2015-07-02 Paul Schneider <paul@pschneider.fr>
* NpgsqlBlogProvider.cs:
* NpgsqlBlogProvider.csproj:
2015-06-09 Paul Schneider <paul@pschneider.fr>
* NpgsqlBlogProvider.csproj: Helps to fix packaging, and
cleans dependencies

@ -1,62 +0,0 @@
2015-10-01 Paul Schneider <paul@pschneider.fr>
* packages.config:
* NpgsqlContentProvider.csproj:
2015-09-27 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs: Fixes the sql command preparation
2015-09-10 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs:
2015-09-10 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs: * refactoring
* updates the circle
2015-08-20 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs: circle members are now stored in bd
upon their user's name
2015-08-04 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs: Fixes the "Match" method.
* NpgsqlContentProvider.cs: refactoring
2015-07-15 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs: Makes Circles private, or not
* NpgsqlContentProvider.cs: Impacts htmldoc
* NpgsqlContentProvider.csproj: Moves to Mono framework
2015-07-02 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs:
2015-06-18 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs: Fixes the Circle creation
* NpgsqlContentProvider.cs: code formatting
2015-06-10 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs:
2015-06-10 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs: implements a Circle provider
* NpgsqlContentProvider.csproj: new circle provider
2015-06-09 Paul Schneider <paul@pschneider.fr>
* NpgsqlContentProvider.csproj: Helps to fix packaging, and
cleans dependencies

@ -1,46 +0,0 @@
2015-10-01 Paul Schneider <paul@pschneider.fr>
* packages.config:
* NpgsqlProfileProvider.cs:
* NpgsqlMRPProviders.csproj:
* NpgsqlMembershipProvider.cs:
2015-08-04 Paul Schneider <paul@pschneider.fr>
* NpgsqlMRPProviders.csproj: new NpgsqlUserName provider
* NpgsqlRoleProvider.cs: simpler init method
* NpgsqlUserNameProvider.cs: impements a UserNameProvider
2015-08-01 Paul Schneider <paul@pschneider.fr>
* NpgsqlMembershipProvider.cs: Fixes the membership update.
2015-07-15 Paul Schneider <paul@pschneider.fr>
* NpgsqlMRPProviders.csproj: Moves to Mono framework
* NpgsqlMembershipProvider.cs: Makes possible to change the
UserName
* NpgsqlRoleProvider.cs: Drops this SQL code, which is
actually maintained in Web/instdbws.sql
2015-06-18 Paul Schneider <paul@pschneider.fr>
* NpgsqlMembershipProvider.cs: should fix a bug at resetting
the password
2015-06-10 Paul Schneider <paul@pschneider.fr>
* NpgsqlMembershipProvider.cs: Fixes the Google registration
since usage of NuGet for Npgsql
2015-06-09 Paul Schneider <paul@pschneider.fr>
* NpgsqlCircleProvider.cs: Refactoring: Npgsql prefix
* NpgsqlMRPProviders.csproj: Helps to fix packaging, and
cleans dependencies

@ -1,14 +0,0 @@
2015-10-01 Paul Schneider <paul@pschneider.fr>
* TestAPI.csproj:
* packages.config:
2015-07-17 Paul Schneider <paul@pschneider.fr>
* TestAPI.csproj:
* AssemblyInfo.cs:
* TestAutomate.cs: Tests an Automate
* packages.config: using Machine.Specifications

@ -1,3 +1,7 @@
2015-10-04 Paul Schneider <paul@pschneider.fr>
* ResultPages.cs: .
2015-09-23 Paul Schneider <paul@pschneider.fr>
* InputUserName.cs: formatting

@ -4,6 +4,7 @@ using System.Security.Permissions;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.ComponentModel;
using System.Collections;
namespace Yavsc.WebControls
{
@ -29,19 +30,16 @@ namespace Yavsc.WebControls
}
/// <summary>
/// Gets or sets the results per page.
/// </summary>
/// <value>The results per page.</value>
[Bindable (true)]
[DefaultValue(10)]
public int ResultsPerPage {
public int PageSize {
get {
return (int)( ViewState["ResultsPerPage"]==null?10:ViewState["ResultsPerPage"]);
return (int)( ViewState["PageSize"]==null?10:ViewState["PageSize"]);
}
set {
ViewState["ResultsPerPage"]=value;
ViewState["PageSize"]=value;
}
}
@ -50,11 +48,8 @@ namespace Yavsc.WebControls
/// Gets or sets the result count.
/// </summary>
/// <value>The result count.</value>
[Bindable (true)]
[DefaultValue(0)]
public int ResultCount {
get {
return (int)( ViewState["ResultCount"]==null?0:ViewState["ResultCount"]);
}
set {
@ -66,7 +61,6 @@ namespace Yavsc.WebControls
/// Gets or sets the text.
/// </summary>
/// <value>The text.</value>
[Bindable (true)]
[DefaultValue("Pages:")]
[Localizable(true)]
public string Text {
@ -85,25 +79,27 @@ namespace Yavsc.WebControls
/// </summary>
/// <value>The action.</value>
[Bindable (true)]
[DefaultValue("")]
[DefaultValue("?pageIndex=")]
public string Action {
get {
string s = (string)ViewState["Action"];
return (s == null) ? String.Empty : s;
return (s == null) ? "?pageIndex=" : s;
}
set {
ViewState["Action"] = value;
}
}
/// <summary>
/// Gets or sets the none.
/// </summary>
/// <value>The none.</value>
[Bindable (true)]
[DefaultValue("none")]
public string None {
get {
string s = (string) ViewState["None"];
return (s == null) ? String.Empty : s;
return (string) ViewState["None"];
}
set {
ViewState["None"] = value;
@ -116,26 +112,28 @@ namespace Yavsc.WebControls
/// <value>The current page.</value>
[Bindable (true)]
[DefaultValue(0)]
public int CurrentPage {
public int PageIndex {
get {
int i = (int)(ViewState["CurrentPage"]==null?0:ViewState["CurrentPage"]);
int i = (int)(ViewState["PageIndex"]==null?0:ViewState["PageIndex"]);
return i;
}
set {
ViewState["CurrentPage"] = value;
ViewState["PageIndex"] = value;
}
}
/// <summary>
/// Renders the contents as the list of links to pages of results.
/// </summary>
/// <param name="writer">Writer.</param>
protected override void RenderContents (HtmlTextWriter writer)
{
if (ResultCount > 0 && ResultCount > ResultsPerPage ) {
if (ResultCount > 0 && ResultCount > PageSize ) {
writer.WriteEncodedText (Text);
int pageCount = ((ResultCount-1) / ResultsPerPage) + 1;
for (int pi = (CurrentPage < 5) ? 0 : CurrentPage - 5; pi < pageCount && pi < CurrentPage + 5; pi++) {
if (CurrentPage == pi)
int pageCount = ((ResultCount-1) / PageSize) + 1;
if ( pageCount > 1 ) {
for (int pi = (PageIndex < 5) ? 0 : PageIndex - 5; pi < pageCount && pi < PageIndex + 5; pi++) {
if (PageIndex == pi)
writer.RenderBeginTag ("b");
else {
writer.AddAttribute (HtmlTextWriterAttribute.Href,
@ -147,10 +145,9 @@ namespace Yavsc.WebControls
writer.Write ("&nbsp;");
}
}
}
if (ResultCount == 0) {
writer.Write ("(");
writer.Write (None);
writer.Write (")");
}
}

@ -96,7 +96,7 @@ aside {
max-width: 40em;
padding: .5em;
margin: .5em;
background-color: rgba(32,32,64,0.8);
background-color: rgba(32,32,32,0.8);
border-radius:10px;
}
.postpreview video, .postpreview img {
@ -107,11 +107,11 @@ aside {
display:block;
margin:1em;
padding:1em;
background-color: rgba(32,32,64,0.8);
background-color: rgba(32,32,32,0.8);
color: #aaa;
border-radius:10px;
}
.hiddenpost { background-color: rgba(16,16,16,0.7); }
.hiddenpost { background-color: rgba(16,16,16,0.5); }
.fullwidth { width: 100%; }
textarea.fullwidth { min-height:10em; }
@ -125,7 +125,7 @@ textarea.fullwidth { min-height:10em; }
}
.panel,.bshpanel, aside {
background-color: rgba(32,16,16,0.8);
background-color: rgba(32,32,16,0.8);
border-radius:5px;
margin:.5em;
padding: .5em;
@ -147,11 +147,13 @@ content: ")";
a {
text-decoration: none;
color: #B0B080;
background-color:rgba(20,20,20,0.5);
text-decoration: none;
}
.usertitleref {
color: #B0B080;
border-radius: 5px;
background-color:rgba(0,0,32,0.8);
background-color:rgba(0,0,32,0.6);
font-family: 'Arial', cursive;
padding: 1em;
}
@ -167,19 +169,19 @@ label {
.message, #message {
font-size: large;
background-color: rgba(0,64,0,0.1);
background-color: rgba(64,64,0,0.5);
}
.dirty {
background-color: rgba(128,128,0,0.3);
background-color: rgba(128,128,0,0.5);
}
.error, #error {
color: #f88;
font-size: large;
background-color: rgba(128,0,0,0.3);
background-color: rgba(256,0,0,0.5);
}
.validation-summary-errors{
color: #f88;
background-color: rgba(64,0,0,0.3);
background-color: rgba(256,0,0,0.5);
}
@ -201,7 +203,7 @@ ul.preview li:nth-child(n) {
.actionlink {
color: #B0B080;
border-radius: 5px;
background-color:rgba(0,0,32,0.8);
background-color:rgba(0,0,32,0.5);
cursor: pointer;
font-family: 'Arial', cursive;
padding: .2em;

File diff suppressed because it is too large Load Diff

@ -82,11 +82,10 @@ namespace Yavsc.Controllers
/// <param name="pageSize">Page size.</param>
public ActionResult BlogList (int pageIndex = 0, int pageSize = 10)
{
ViewData ["SiteName"] = sitename;
int totalRecords;
var bs = BlogManager.LastPosts (pageIndex, pageSize, out totalRecords);
ViewData ["RecordCount"] = totalRecords;
ViewData ["pageSize"] = pageSize;
ViewData ["ResultCount"] = totalRecords;
ViewData ["PageSize"] = pageSize;
ViewData ["PageIndex"] = pageIndex;
return View ("Index", new BlogEntryCollection(bs) );
}

@ -29,6 +29,7 @@ using System.Web.Mvc;
using System.Net;
using MarkdownDeep;
using Yavsc.Helpers;
using Yavsc.Model.Blogs;
namespace Yavsc.Formatters
{

@ -171,10 +171,9 @@ namespace Yavsc.Helpers
/// <param name="username">Username.</param>
public static string AvatarUrl (this HtmlHelper helper, string username) {
ProfileBase pr = ProfileBase.Create (username);
var avpath = pr.GetPropertyValue("Avatar") ;
if (avpath != null)
return helper.Encode (avpath);
return "/avatars/" + helper.Encode(username)+".png";
var a = pr.GetPropertyValue("Avatar") ;
if (a == null || a is DBNull) return "/avatars/" + helper.Encode(username)+".png";
return helper.Encode ((string)a);
}
}
}

@ -10,7 +10,7 @@
<div class="postpreview">
<%= Html.ActionLink(p.Title, "UserPost",
new { user = g.Key, title = p.Title }, new { @class = "usertitleref" } ) %>
<p><%= Html.Markdown(p.Intro,"/bfiles/"+p.Id+"/") %></p>
<aside>
(Posté le <%=p.Posted.ToString("D") %>)
@ -24,14 +24,15 @@
</div> <% } %>
<% } %>
</div>
<form runat="server" id="form1" method="GET">
<% rp1.ResultCount = Model.Count; rp1.ResultsPerPage = 50; %>
<% rp1.CurrentPage = (int) ViewData["PageIndex"]; %>
<% rp1.None = Html.Translate("no content"); %>
<yavsc:ResultPages id="rp1" Action = "?pageIndex={0}" runat="server" >
<% rp1.ResultCount = (int) ViewData["ResultCount"];
rp1.PageSize = (int) ViewData ["PageSize"];
rp1.PageIndex = (int) ViewData["PageIndex"];
rp1.None = Html.Translate("no content");
%>
<yavsc:ResultPages id="rp1" runat="server" >
<None>Aucun résultat</None>
</yavsc:ResultPages>
</form>
</asp:Content>

@ -33,24 +33,23 @@
<%= Html.ActionLink("Editer","Edit", new { id = e.Id }, new { @class="actionlink" }) %>
<%= Html.ActionLink("Supprimer","RemovePost", new { id = e.Id }, new { @class="actionlink" } ) %>
<% } %>
</aside>
</div>
<% } %>
<aside>
<form runat="server" id="form1" method="GET">
<%
rp1.ResultCount = (int) ViewData["RecordCount"];
rp1.CurrentPage = (int) ViewData["PageIndex"];
user.Value = (string) ViewData["BlogUser"];
rp1.PageIndex = (int) ViewData["PageIndex"];
%>
<aside>
<yavsc:ResultPages id="rp1" Action = "?pageIndex={0}" runat="server">
<None><i>Pas de contenu</i></None>
</yavsc:ResultPages>
</aside>
<asp:HiddenField id="user" runat="server"></asp:HiddenField>
</form>
</aside>
</asp:Content>

@ -188,7 +188,6 @@
<Compile Include="IValueProvider.cs" />
<Compile Include="Formatters\EstimToPdfFormatter.MSAN.cs" />
<Compile Include="Helpers\TemplateException.cs" />
<Compile Include="Helpers\MarkdownHelper.cs" />
<Compile Include="Formatters\FormatterException.cs" />
<Compile Include="NUnitTestClass.cs" />
<Compile Include="TestExec.cs" />

@ -56,15 +56,11 @@ namespace Yavsc.Model.Blogs
{
return this.Where (x => x.Title == title).ToArray ();
}
/// <summary>
/// Post info.
/// </summary>
public struct PostInfoByTitle {
/// <summary>
/// The name of the user.
/// Base post info.
/// </summary>
public string Author;
public class BasePostInfo {
/// <summary>
/// The identifier.
/// </summary>
@ -78,29 +74,32 @@ namespace Yavsc.Model.Blogs
/// </summary>
public DateTime Modified;
}
/// <summary>
/// Post info by user.
/// The intro.
/// </summary>
public struct PostInfoByUser {
public string Intro;
}
/// <summary>
/// The name of the user.
/// Post info.
/// </summary>
public string Title;
public class PostInfoByTitle : BasePostInfo {
/// <summary>
/// The identifier.
/// The name of the user.
/// </summary>
public long Id;
public string Author;
}
/// <summary>
/// The posted.
/// Post info by user.
/// </summary>
public DateTime Posted;
public class PostInfoByUser : BasePostInfo {
/// <summary>
/// The modified.
/// The name of the user.
/// </summary>
public DateTime Modified;
public string Title;
}
/// <summary>
@ -108,11 +107,12 @@ namespace Yavsc.Model.Blogs
/// </summary>
public IEnumerable<IGrouping<string,PostInfoByTitle>> GroupByTitle()
{
bool truncated;
return from be in this
orderby be.Posted descending
group
new PostInfoByTitle { Author=be.Author, Id=be.Id,
Posted=be.Posted, Modified=be.Modified }
Posted=be.Posted, Modified=be.Modified, Intro = MarkdownHelper.MarkdownIntro(be.Content, out truncated) }
by be.Title
into titlegroup
select titlegroup;
@ -123,11 +123,12 @@ namespace Yavsc.Model.Blogs
/// <returns>The by user.</returns>
public IEnumerable<IGrouping<string,PostInfoByUser>> GroupByUser()
{
bool truncated;
return from be in this
orderby be.Posted descending
group
new PostInfoByUser { Title=be.Title, Id=be.Id,
Posted=be.Posted, Modified=be.Modified }
Posted=be.Posted, Modified=be.Modified, Intro = MarkdownHelper.MarkdownIntro(be.Content, out truncated) }
by be.Author
into usergroup
select usergroup;

@ -2,7 +2,7 @@
using System.Web.Mvc;
using MarkdownDeep;
namespace Yavsc.Helpers
namespace Yavsc.Model.Blogs
{
/// <summary>
/// Helper class for transforming Markdown.
@ -44,27 +44,47 @@ namespace Yavsc.Helpers
return new MvcHtmlString(html);
}
public static IHtmlString MarkdownToHtmlIntro(this HtmlHelper helper, out bool truncated, string text, string urlBaseLocation="")
{
public static string MarkdownIntro(string markdown, out bool truncated) {
int maxLen = 250;
// Transform the supplied text (Markdown) into HTML.
var markdownTransformer = new Markdown();
markdownTransformer.ExtraMode = true;
markdownTransformer.UrlBaseLocation = urlBaseLocation;
if (text.Length < maxLen) {
if (markdown.Length < maxLen) {
truncated = false;
return new MvcHtmlString(markdownTransformer.Transform(text));
return markdown;
}
string intro = text.Remove (maxLen);
string intro = markdown.Remove (maxLen);
truncated = true;
int inl = intro.LastIndexOf ("\n");
if (inl > 20)
intro = intro.Remove (inl);
intro += " ...";
string html = markdownTransformer.Transform(intro);
return intro;
}
/// <summary>
/// Markdowns to html intro.
/// </summary>
/// <returns>The to html intro.</returns>
/// <param name="truncated">Truncated.</param>
/// <param name="text">Text.</param>
/// <param name="urlBaseLocation">URL base location.</param>
public static string MarkdownToHtmlIntro(out bool truncated, string text, string urlBaseLocation="") {
var md = MarkdownIntro(text, out truncated);
var markdownTransformer = new Markdown();
markdownTransformer.ExtraMode = true;
markdownTransformer.UrlBaseLocation = urlBaseLocation;
string html = markdownTransformer.Transform(md);
return html;
}
/// <summary>
/// Markdowns to html intro.
/// </summary>
/// <returns>The to html intro.</returns>
/// <param name="helper">Helper.</param>
/// <param name="truncated">Truncated.</param>
/// <param name="text">Text.</param>
/// <param name="urlBaseLocation">URL base location.</param>
public static IHtmlString MarkdownToHtmlIntro(this HtmlHelper helper, out bool truncated, string text, string urlBaseLocation="")
{
// Wrap the html in an MvcHtmlString otherwise it'll be HtmlEncoded and displayed to the user as HTML :(
return new MvcHtmlString(html);
return new MvcHtmlString(MarkdownToHtmlIntro (out truncated, text, urlBaseLocation));
}
/// <summary>

@ -1,3 +1,11 @@
2015-10-04 Paul Schneider <paul@pschneider.fr>
* MarkdownHelper.cs:
* BlogEntryCollection.cs: refactoring + extract an intro from
Markdown for PostInfo*
* YavscModel.csproj: MarkdownHelper integration
2015-10-01 Paul Schneider <paul@pschneider.fr>
* Profile.cs: refactoring

@ -41,6 +41,9 @@
<Reference Include="System.Net.Http" />
<Reference Include="System.Net.Http.Formatting" />
<Reference Include="System.Web.ApplicationServices" />
<Reference Include="MarkdownDeep">
<HintPath>..\web\lib\MarkdownDeep.dll</HintPath>
</Reference>
</ItemGroup>
<ItemGroup>
<Compile Include="Properties\AssemblyInfo.cs" />
@ -167,6 +170,7 @@
<Compile Include="RolesAndMembers\ChangeUserNameProvider.cs" />
<Compile Include="RolesAndMembers\UserManager.cs" />
<Compile Include="Circles\CircleBase.cs" />
<Compile Include="Blogs\MarkdownHelper.cs" />
</ItemGroup>
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
<ItemGroup>

Loading…