bug fixes
* Makefile: my deploy config * NpgsqlMembershipProvider.cs: Fixes a Bug introduced by Npgsql driver upgrade * ResultPages.cs: . * style.css: other colors * BlogsController.cs: code cleaning * GoogleController.cs: refactoring * ErrorHtmlFormatter.cs: MarkdownDeep calls now come from yavscModel * YavscHelpers.cs: xmldoc * Index.aspx: code formatting * UserPosts.aspx: nothing to note * Web.csproj: MarkdownHelper has gone to the yavscModel project * MarkdownHelper.cs: * BlogEntryCollection.cs: refactoring + extract an intro from Markdown for PostInfo* * YavscModel.csproj: MarkdownHelper integration
This commit is contained in:
@ -1,3 +1,7 @@
|
||||
2015-10-04 Paul Schneider <paul@pschneider.fr>
|
||||
|
||||
* Makefile: my deploy config
|
||||
|
||||
2015-08-20 Paul Schneider <paul@pschneider.fr>
|
||||
|
||||
* Yavsc.sln: Adds the `Presta` project
|
||||
|
27
Makefile
27
Makefile
@ -4,17 +4,17 @@ CONFIG=Debug
|
||||
LDYDESTDIR=build/web/$(CONFIG)
|
||||
COPYUNCHANGED="false"
|
||||
|
||||
HOST_rsync_local=localhost
|
||||
DESTDIR_rsync_local=/srv/www/yavsc
|
||||
HOST_rsync_yavsc=lua.pschneider.fr
|
||||
DESTDIR_rsync_yavsc=/srv/www/yavsc
|
||||
|
||||
HOST_rsync_test=localhost
|
||||
DESTDIR_rsync_test=/srv/www/lua
|
||||
HOST_rsync_lua=lua.pschneider.fr
|
||||
DESTDIR_rsync_lua=/srv/www/lua
|
||||
|
||||
HOST_rsync_pre=lua.localdomain
|
||||
DESTDIR_rsync_pre=/srv/www/yavsc
|
||||
HOST_rsync_pre=lua.pschneider.fr
|
||||
DESTDIR_rsync_pre=/srv/www/yavscpre
|
||||
|
||||
HOST_rsync_prod=lua.localdomain
|
||||
DESTDIR_rsync_prod=/srv/www/lua
|
||||
HOST_rsync_prod=lua.pschneider.fr
|
||||
DESTDIR_rsync_prod=/srv/www/yavsc
|
||||
|
||||
DOCASSBS=NpgsqlBlogProvider.dll WorkFlowProvider.dll Yavsc.WebControls.dll ITContentProvider.dll NpgsqlMRPProviders.dll Yavsc.dll SalesCatalog.dll YavscModel.dll
|
||||
|
||||
@ -38,7 +38,6 @@ rsync_% : DESTDIR = $(DESTDIR_$@)
|
||||
rsync_% : deploy
|
||||
echo "!Deploying to $(HOST)!"
|
||||
$(RSYNCCMD) build/web/$(CONFIG)/ root@$(HOST):$(DESTDIR)
|
||||
ssh root@$(HOST) apachectl restart
|
||||
|
||||
build:
|
||||
xbuild /p:Configuration=$(CONFIG) /t:Build Yavsc.sln
|
||||
@ -46,6 +45,8 @@ build:
|
||||
clean:
|
||||
xbuild /t:Clean
|
||||
find -name "StyleCop.Cache" -exec rm {} \;
|
||||
|
||||
distclean: clean
|
||||
rm -rf $(LDYDESTDIR)
|
||||
|
||||
sourcepkg:
|
||||
@ -63,14 +64,10 @@ htmldoc: xmldoc
|
||||
docdeploy-prod: htmldoc
|
||||
rsync -ravu web/htmldoc root@$(PRODHOSTDIR)
|
||||
|
||||
rsync_local:
|
||||
rsync_lua:
|
||||
|
||||
rsync_test:
|
||||
rsync_yavsc:
|
||||
|
||||
rsync_pre:
|
||||
|
||||
rsync_prod:
|
||||
|
||||
bigrsync: rsync_test rsync_local rsync_pre rsync_prod
|
||||
|
||||
|
||||
|
@ -1,3 +1,8 @@
|
||||
2015-10-04 Paul Schneider <paul@pschneider.fr>
|
||||
|
||||
* NpgsqlMembershipProvider.cs: Fixes a Bug introduced by
|
||||
Npgsql driver upgrade
|
||||
|
||||
2015-08-04 Paul Schneider <paul@pschneider.fr>
|
||||
|
||||
* NpgsqlMRPProviders.csproj: new NpgsqlUserName provider
|
||||
|
@ -358,7 +358,10 @@ namespace Npgsql.Web
|
||||
}
|
||||
|
||||
MembershipUser u = GetUser (username, false);
|
||||
|
||||
if (passwordQuestion == null)
|
||||
passwordQuestion = "";
|
||||
if (passwordAnswer == null)
|
||||
passwordAnswer = "";
|
||||
if (u == null) {
|
||||
DateTime createDate = DateTime.Now;
|
||||
|
||||
|
@ -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 (" ");
|
||||
}
|
||||
}
|
||||
}
|
||||
if (ResultCount == 0) {
|
||||
writer.Write ("(");
|
||||
writer.Write (None);
|
||||
writer.Write (")");
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -4,7 +4,7 @@ body {
|
||||
background-color: black;
|
||||
color: #D0FFD0;
|
||||
font-family: 'Arial', cursive;
|
||||
padding: 0em;
|
||||
padding: 2em;
|
||||
}
|
||||
|
||||
.iconsmall { max-height: 1.3em; max-width: 1.3em; }
|
||||
@ -88,7 +88,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 {
|
||||
@ -99,11 +99,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,0,0.3); }
|
||||
.hiddenpost { background-color: rgba(16,16,16,0.5); }
|
||||
.fullwidth { width: 100%; }
|
||||
|
||||
textarea.fullwidth { min-height:10em; }
|
||||
@ -117,7 +117,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;
|
||||
@ -139,13 +139,13 @@ content: ")";
|
||||
a {
|
||||
text-decoration: none;
|
||||
color: #B0B080;
|
||||
background-color:rgba(20,0,20,0.5);
|
||||
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;
|
||||
}
|
||||
@ -161,19 +161,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);
|
||||
}
|
||||
|
||||
|
||||
@ -195,7 +195,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;
|
||||
|
@ -1,3 +1,23 @@
|
||||
2015-10-04 Paul Schneider <paul@pschneider.fr>
|
||||
|
||||
* style.css: other colors
|
||||
|
||||
* BlogsController.cs: code cleaning
|
||||
|
||||
* GoogleController.cs: refactoring
|
||||
|
||||
* ErrorHtmlFormatter.cs: MarkdownDeep calls now come from
|
||||
yavscModel
|
||||
|
||||
* YavscHelpers.cs: xmldoc
|
||||
|
||||
* Index.aspx: code formatting
|
||||
|
||||
* UserPosts.aspx: nothing to note
|
||||
|
||||
* Web.csproj: MarkdownHelper has gone to the yavscModel
|
||||
project
|
||||
|
||||
2015-10-02 Paul Schneider <paul@pschneider.fr>
|
||||
|
||||
* style.css: yauniformisation small & large screens.
|
||||
|
@ -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) );
|
||||
}
|
||||
|
@ -212,7 +212,7 @@ namespace Yavsc.Controllers
|
||||
HttpContext.Profile.SetPropertyValue ("Name", me.displayName);
|
||||
// TODO use image
|
||||
if (me.image != null) {
|
||||
HttpContext.Profile.SetPropertyValue ("avatar", me.image.url);
|
||||
HttpContext.Profile.SetPropertyValue ("Avatar", me.image.url);
|
||||
}
|
||||
if (me.placesLived != null) {
|
||||
People.Place pplace = me.placesLived.Where (x => x.primary).First ();
|
||||
|
@ -29,6 +29,7 @@ using System.Web.Mvc;
|
||||
using System.Net;
|
||||
using MarkdownDeep;
|
||||
using Yavsc.Helpers;
|
||||
using Yavsc.Model.Blogs;
|
||||
|
||||
namespace Yavsc.Formatters
|
||||
{
|
||||
|
@ -163,13 +163,17 @@ namespace Yavsc.Helpers
|
||||
foreach (MembershipUser u in users)
|
||||
YavscHelpers.SendActivationMessage (u);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Avatars the URL.
|
||||
/// </summary>
|
||||
/// <returns>The URL.</returns>
|
||||
/// <param name="helper">Helper.</param>
|
||||
/// <param name="username">Username.</param>
|
||||
public static string AvatarUrl (this HtmlHelper helper, string username) {
|
||||
ProfileBase pr = ProfileBase.Create (username);
|
||||
string avpath = (string ) 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,22 +33,19 @@
|
||||
<%= 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"];
|
||||
|
||||
%>
|
||||
<aside>
|
||||
<yavsc:ResultPages id="rp1" Action = "?pageIndex={0}" runat="server"></yavsc:ResultPages>
|
||||
</aside>
|
||||
<asp:HiddenField id="user" runat="server"></asp:HiddenField>
|
||||
rp1.PageIndex = (int) ViewData["PageIndex"];
|
||||
%><yavsc:ResultPages id="rp1" Action = "?pageIndex={0}" runat="server"></yavsc:ResultPages>
|
||||
</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,51 +56,50 @@ namespace Yavsc.Model.Blogs
|
||||
{
|
||||
return this.Where (x => x.Title == title).ToArray ();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Base post info.
|
||||
/// </summary>
|
||||
public class BasePostInfo {
|
||||
/// <summary>
|
||||
/// The identifier.
|
||||
/// </summary>
|
||||
public long Id;
|
||||
/// <summary>
|
||||
/// The posted.
|
||||
/// </summary>
|
||||
public DateTime Posted;
|
||||
/// <summary>
|
||||
/// The modified.
|
||||
/// </summary>
|
||||
public DateTime Modified;
|
||||
|
||||
/// <summary>
|
||||
/// The intro.
|
||||
/// </summary>
|
||||
public string Intro;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Post info.
|
||||
/// </summary>
|
||||
public struct PostInfoByTitle {
|
||||
public class PostInfoByTitle : BasePostInfo {
|
||||
|
||||
/// <summary>
|
||||
/// The name of the user.
|
||||
/// </summary>
|
||||
public string Author;
|
||||
/// <summary>
|
||||
/// The identifier.
|
||||
/// </summary>
|
||||
public long Id;
|
||||
/// <summary>
|
||||
/// The posted.
|
||||
/// </summary>
|
||||
public DateTime Posted;
|
||||
/// <summary>
|
||||
/// The modified.
|
||||
/// </summary>
|
||||
public DateTime Modified;
|
||||
|
||||
}
|
||||
/// <summary>
|
||||
/// Post info by user.
|
||||
/// </summary>
|
||||
public struct PostInfoByUser {
|
||||
public class PostInfoByUser : BasePostInfo {
|
||||
|
||||
/// <summary>
|
||||
/// The name of the user.
|
||||
/// </summary>
|
||||
public string Title;
|
||||
/// <summary>
|
||||
/// The identifier.
|
||||
/// </summary>
|
||||
public long Id;
|
||||
/// <summary>
|
||||
/// The posted.
|
||||
/// </summary>
|
||||
public DateTime Posted;
|
||||
/// <summary>
|
||||
/// The modified.
|
||||
/// </summary>
|
||||
public DateTime Modified;
|
||||
|
||||
}
|
||||
|
||||
/// <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>
|
||||
|
Reference in New Issue
Block a user