Compare commits
27 Commits
Styling-ma
...
master
Author | SHA1 | Date | |
---|---|---|---|
09ef1ca66e | |||
20655b74f0 | |||
ff5163cea5 | |||
1ed563fc7c | |||
cd89c4bdf7 | |||
d98f7d101a | |||
81b497f02d | |||
95bae9565f | |||
|
007fe99f1b | ||
|
e9ed7d4b77 | ||
18038707d0 | |||
|
3607ce2f2b | ||
7ef186c12b | |||
0e062a57e9 | |||
2cc1af2149 | |||
c5ca2aa2dc | |||
5115b88e85 | |||
1a97cae65f | |||
4f2e75eed1 | |||
cf4cc5650e | |||
|
a0c5d4357b | ||
|
d72384efe2 | ||
|
4240f1d563 | ||
|
d9521ae99d | ||
|
fd836b41b5 | ||
|
88edf07e00 | ||
|
15830cf648 |
BIN
Dokumentacja/Dokumentacja API.pdf
Normal file
BIN
Dokumentacja/Dokumentacja API.pdf
Normal file
Binary file not shown.
BIN
Dokumentacja/Dokumentacja_wykonanych_prac .pdf
Normal file
BIN
Dokumentacja/Dokumentacja_wykonanych_prac .pdf
Normal file
Binary file not shown.
BIN
Dokumentacja/Dokumetnacja.pdf
Normal file
BIN
Dokumentacja/Dokumetnacja.pdf
Normal file
Binary file not shown.
BIN
Dokumentacja/Najnowszy plan forum.pdf
Normal file
BIN
Dokumentacja/Najnowszy plan forum.pdf
Normal file
Binary file not shown.
Binary file not shown.
BIN
Dokumentacja/Poprawiona-architektura.pdf
Normal file
BIN
Dokumentacja/Poprawiona-architektura.pdf
Normal file
Binary file not shown.
Binary file not shown.
BIN
Dokumentacja/instrukcja obsługi.pdf
Normal file
BIN
Dokumentacja/instrukcja obsługi.pdf
Normal file
Binary file not shown.
@ -302,10 +302,20 @@ textarea {
|
||||
background-color: #f2f2f2;
|
||||
}
|
||||
|
||||
.delete-category__span{
|
||||
font-size:2rem;
|
||||
font-weight:400;
|
||||
margin-bottom:10rem;
|
||||
}
|
||||
|
||||
.delete-category__dl {
|
||||
height: 3rem;
|
||||
margin-bottom: 3rem;
|
||||
}
|
||||
|
||||
|
||||
|
||||
@media (min-width: 768px) {
|
||||
@media (min-width: 768px) {
|
||||
|
||||
|
||||
|
||||
@ -358,7 +368,8 @@ textarea {
|
||||
flex-direction: row;
|
||||
margin-top: 1rem;
|
||||
}
|
||||
.form-personal-data{
|
||||
|
||||
.form-personal-data {
|
||||
flex-direction: row;
|
||||
}
|
||||
|
||||
@ -367,10 +378,9 @@ textarea {
|
||||
}
|
||||
|
||||
.form-AddQuestion input[type=submit] {
|
||||
margin-top:0;
|
||||
margin-top: 0;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
@ -136,7 +136,7 @@ namespace Forum.Controllers
|
||||
|
||||
//
|
||||
// GET: /Account/Register
|
||||
[AllowAnonymous]
|
||||
[Authorize]
|
||||
public ActionResult Register()
|
||||
{
|
||||
return View();
|
||||
@ -145,7 +145,7 @@ namespace Forum.Controllers
|
||||
//
|
||||
// POST: /Account/Register
|
||||
[HttpPost]
|
||||
[AllowAnonymous]
|
||||
[Authorize]
|
||||
[ValidateAntiForgeryToken]
|
||||
public async Task<ActionResult> Register(RegisterViewModel model)
|
||||
{
|
||||
|
@ -133,6 +133,25 @@ namespace Forum.Controllers
|
||||
return RedirectToAction("Question", new {id = model.QuestionId});
|
||||
}
|
||||
|
||||
[Authorize]
|
||||
[System.Web.Mvc.Route("Home/DeleteAnswer/{id}")]
|
||||
public ActionResult DeleteAnswer(int? id)
|
||||
{
|
||||
var answer = _dbContext.Answers.Find(id);
|
||||
var question = _dbContext.Questions.FirstOrDefault(x => x.Answers.Any(y => y.Id == id));
|
||||
|
||||
if (answer != null)
|
||||
{
|
||||
_dbContext.Answers.Remove(answer);
|
||||
_dbContext.SaveChanges();
|
||||
}
|
||||
|
||||
if (question != null)
|
||||
return RedirectToAction("Question", new {id = question.Id});
|
||||
|
||||
return HttpNotFound();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
@ -222,6 +222,8 @@
|
||||
<Content Include="Content\bootstrap.css.map" />
|
||||
<Content Include="Content\bootstrap-theme.min.css.map" />
|
||||
<Content Include="Content\bootstrap-theme.css.map" />
|
||||
<None Include="Properties\PublishProfiles\forum-inzynieria1 - FTP.pubxml" />
|
||||
<None Include="Properties\PublishProfiles\forum-inzynieria1 - Web Deploy.pubxml" />
|
||||
<None Include="Scripts\jquery-3.3.1.intellisense.js" />
|
||||
<Content Include="Scripts\jquery-3.3.1.js" />
|
||||
<Content Include="Scripts\jquery-3.3.1.min.js" />
|
||||
|
@ -41,7 +41,7 @@
|
||||
</div>
|
||||
</div>
|
||||
<p>
|
||||
@Html.ActionLink("Utwórz nowego użytkownika", "Register")
|
||||
@*@Html.ActionLink("Utwórz nowego użytkownika", "Register")*@
|
||||
</p>
|
||||
@* Enable this once you have account confirmation enabled for password reset functionality
|
||||
<p>
|
||||
|
@ -4,29 +4,31 @@
|
||||
ViewBag.Title = "Delete";
|
||||
}
|
||||
|
||||
<h2>Delete</h2>
|
||||
<div class="single-category-wrapper">
|
||||
<h2>Usuwanie ketegorii</h2>
|
||||
<hr style="border-top: 1px solid #d3d3d3;" />
|
||||
|
||||
<h3>Are you sure you want to delete this?</h3>
|
||||
<div>
|
||||
<h4>Category</h4>
|
||||
<hr />
|
||||
<dl class="dl-horizontal">
|
||||
<dt>
|
||||
<span class="delete-category__span">Jesteś pewien, że chcesz usunąć kategorię?</span>
|
||||
<div style="margin-top: 3rem;">
|
||||
|
||||
<dl class="dl-horizontal delete-category__dl">
|
||||
<dt style="text-align:left">
|
||||
@Html.DisplayNameFor(model => model.CategoryName)
|
||||
</dt>
|
||||
|
||||
<dd>
|
||||
<dd style="margin-left:0;">
|
||||
@Html.DisplayFor(model => model.CategoryName)
|
||||
</dd>
|
||||
|
||||
</dl>
|
||||
|
||||
@using (Html.BeginForm()) {
|
||||
@using (Html.BeginForm())
|
||||
{
|
||||
@Html.AntiForgeryToken()
|
||||
|
||||
<div class="form-actions no-color">
|
||||
<input type="submit" value="Delete" class="btn btn-default" /> |
|
||||
@Html.ActionLink("Back to List", "Index")
|
||||
<input type="submit" value="Usuń" class="answer-list__add-btn" style="height:4rem; width:17rem; background-color:#af4f4f; margin-bottom: 3rem;" />
|
||||
</div>
|
||||
<div>@Html.ActionLink("Powrót do listy kategorii", "Index")
|
||||
</div>
|
||||
}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -4,19 +4,21 @@
|
||||
ViewBag.Title = "Edit";
|
||||
}
|
||||
|
||||
<h2>Edit</h2>
|
||||
<div class="single-category-wrapper">
|
||||
|
||||
<h2>Edytuj nazwię kategorii</h2>
|
||||
<hr style="border-top: 1px solid #d3d3d3; margin-bottom: 3rem;" />
|
||||
|
||||
|
||||
@using (Html.BeginForm())
|
||||
{
|
||||
|
||||
@using (Html.BeginForm())
|
||||
{
|
||||
@Html.AntiForgeryToken()
|
||||
|
||||
<div class="form-horizontal">
|
||||
<h4>Category</h4>
|
||||
<hr />
|
||||
|
||||
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
|
||||
@Html.HiddenFor(model => model.Id)
|
||||
|
||||
<div class="form-group">
|
||||
@Html.LabelFor(model => model.CategoryName, htmlAttributes: new { @class = "control-label col-md-2" })
|
||||
<div class="col-md-10">
|
||||
@ -24,19 +26,17 @@
|
||||
@Html.ValidationMessageFor(model => model.CategoryName, "", new { @class = "text-danger" })
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-group">
|
||||
<div class="col-md-offset-2 col-md-10">
|
||||
<input type="submit" value="Save" class="btn btn-default" />
|
||||
<input type="submit" value="Zapisz" class="answer-list__add-btn" style="height:4rem; width:17rem" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
}
|
||||
|
||||
<div>
|
||||
@Html.ActionLink("Back to List", "Index")
|
||||
</div>
|
||||
|
||||
@section Scripts {
|
||||
}
|
||||
<div>
|
||||
@Html.ActionLink("Powrót do listy kategorii", "Index")
|
||||
</div>
|
||||
</div>
|
||||
@section Scripts {
|
||||
@Scripts.Render("~/bundles/jqueryval")
|
||||
}
|
||||
}
|
||||
|
@ -12,7 +12,7 @@
|
||||
<table class="table">
|
||||
<tr>
|
||||
<th>
|
||||
@Html.DisplayNameFor(model => model.CategoryName)
|
||||
Nazwa kategorii
|
||||
</th>
|
||||
<th></th>
|
||||
</tr>
|
||||
|
@ -30,7 +30,7 @@
|
||||
foreach (var answer in Model.Answers)
|
||||
{
|
||||
<li class="answer-list__single-answer">
|
||||
<div class="answer-list__answer__info" @{if(answer.Professional!=null){<text>style="background-color: #7ecc2a"</text>}}>
|
||||
<div class="answer-list__answer__info" @{if (answer.Professional != null) { <text> style="background-color: #7ecc2a" </text> }}>
|
||||
@{
|
||||
if (answer.Professional != null)
|
||||
{
|
||||
@ -41,6 +41,12 @@
|
||||
<span class="username">@answer.Nick napisał(a)</span>
|
||||
}
|
||||
}
|
||||
@{
|
||||
if (User.Identity.IsAuthenticated)
|
||||
{
|
||||
@Html.ActionLink("Usuń odpowiedź", "DeleteAnswer", new {id = answer.Id},new{@style="color:#fff;"});
|
||||
}
|
||||
}
|
||||
@answer.Date
|
||||
</div>
|
||||
<div class="answer-list__content">
|
||||
|
@ -9,7 +9,7 @@
|
||||
<li>
|
||||
@Html.ActionLink("Witaj " + User.Identity.GetUserName() + "!", "Index", "Manage", routeValues: null, htmlAttributes: new { title = "Manage" })
|
||||
</li>
|
||||
<li>@Html.ActionLink("Zarejestruj się", "Register", "Account", routeValues: null, htmlAttributes: new { id = "registerLink" })</li>
|
||||
<li>@Html.ActionLink("Dodaj profesjonalistę", "Register", "Account", routeValues: null, htmlAttributes: new { id = "registerLink" })</li>
|
||||
<li><a href="javascript:document.getElementById('logoutForm').submit()">Wyloguj się</a></li>
|
||||
</ul>
|
||||
}
|
||||
|
@ -12,7 +12,7 @@
|
||||
<add name="DefaultConnection" connectionString="Data Source=(LocalDb)\MSSQLLocalDB;AttachDbFilename=|DataDirectory|\ForumInzyneria1.mdf;Initial Catalog=ForumInzyneria1;Integrated Security=True" providerName="System.Data.SqlClient" />
|
||||
</connectionStrings>
|
||||
<appSettings>
|
||||
<add key="MailSenderAddress" value="http://localhost:51829/Home/Index" />
|
||||
<add key="MailSenderAddress" value="http://mailsender-inzynieria1.azurewebsites.net/Home/Index" />
|
||||
<add key="webpages:Version" value="3.0.0.0" />
|
||||
<add key="webpages:Enabled" value="false" />
|
||||
<add key="ClientValidationEnabled" value="true" />
|
||||
|
@ -301,6 +301,11 @@ textarea {
|
||||
height: 200px;
|
||||
}
|
||||
|
||||
.w100 {
|
||||
width: 100% !important;
|
||||
max-width: 100% !important;
|
||||
}
|
||||
|
||||
.form-emailsend
|
||||
{
|
||||
color: black;
|
||||
|
@ -4,23 +4,36 @@ using System.Web.Mvc;
|
||||
using System.Web.ModelBinding;
|
||||
using System;
|
||||
using Newtonsoft.Json;
|
||||
using System.Configuration;
|
||||
|
||||
namespace MailSender.Controllers
|
||||
{
|
||||
[RoutePrefix("")]
|
||||
public class HomeController : Controller
|
||||
{
|
||||
[HttpPost]
|
||||
public ActionResult Index([System.Web.Http.FromBody]MailDTO.MailDTO mail)
|
||||
{
|
||||
var model = new Models.MailModel(mail);
|
||||
TempData.Add("mailMod", model);
|
||||
return View(model);
|
||||
}
|
||||
|
||||
[HttpGet]
|
||||
public ActionResult Index()
|
||||
{
|
||||
if(TempData["mailMod"] != null)
|
||||
{
|
||||
return View(TempData["mailMod"]);
|
||||
}
|
||||
return View(new Models.MailModel());
|
||||
}
|
||||
|
||||
[System.Web.Http.HttpGet]
|
||||
public ActionResult Error(string errMsg)
|
||||
{
|
||||
ViewData.Add("errMsg", errMsg);
|
||||
return View();
|
||||
TempData.Add("errMsg", errMsg);
|
||||
return RedirectToAction("Index");
|
||||
}
|
||||
|
||||
[System.Web.Mvc.HttpPost]
|
||||
@ -28,16 +41,19 @@ namespace MailSender.Controllers
|
||||
{
|
||||
if (ModelState.IsValid)
|
||||
{
|
||||
var smtpClient = new SmtpClient(Settings.smtpServer, Settings.smtpPort)
|
||||
var smtpClient = new SmtpClient(ConfigurationManager.AppSettings["smtp-server"],
|
||||
Int32.Parse(ConfigurationManager.AppSettings["smtp-port"]))
|
||||
{
|
||||
Credentials = new NetworkCredential(Settings.user, Settings.pass),
|
||||
Credentials = new NetworkCredential(
|
||||
ConfigurationManager.AppSettings["user-mail"],
|
||||
ConfigurationManager.AppSettings["pass-mail"]),
|
||||
EnableSsl = true
|
||||
};
|
||||
smtpClient.Send(Settings.user, model.EMailTo, model.Subject, model.Content);
|
||||
return RedirectToAction("Index");
|
||||
smtpClient.Send(ConfigurationManager.AppSettings["user-mail"], model.EMailTo, model.Subject, model.Content);
|
||||
return Redirect(ConfigurationManager.AppSettings["forum-address"]);
|
||||
}
|
||||
else
|
||||
return RedirectToAction("Error", new { errMsg = "Error nie umiesz pisac maila menelu" });
|
||||
return RedirectToAction("Error", new { errMsg = "Błąd wysyłania wiadomości e-mail." });
|
||||
}
|
||||
}
|
||||
}
|
@ -175,7 +175,6 @@
|
||||
</Compile>
|
||||
<Compile Include="Models\MailModel.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
<Compile Include="Settings.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Content Include="Content\bootstrap-theme.css" />
|
||||
@ -191,6 +190,8 @@
|
||||
<Content Include="ApplicationInsights.config">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<None Include="Properties\PublishProfiles\mailsender-inzynieria1 - FTP.pubxml" />
|
||||
<None Include="Properties\PublishProfiles\mailsender-inzynieria1 - Web Deploy.pubxml" />
|
||||
<None Include="Scripts\jquery-3.3.1.intellisense.js" />
|
||||
<Content Include="Scripts\jquery-3.3.1.js" />
|
||||
<Content Include="Scripts\jquery-3.3.1.min.js" />
|
||||
|
@ -30,6 +30,10 @@ namespace MailSender.Models
|
||||
[StringLength(500, ErrorMessage = "Message has to have between 1 and 500 chars", MinimumLength = 1)]
|
||||
public string Content { get; set; }
|
||||
|
||||
public MailModel()
|
||||
{
|
||||
Content = EMailTo = Subject = string.Empty;
|
||||
}
|
||||
|
||||
public MailModel(MailDTO.MailDTO DTO)
|
||||
{
|
||||
|
@ -1,10 +0,0 @@
|
||||
namespace MailSender
|
||||
{
|
||||
public class Settings
|
||||
{
|
||||
public static string smtpServer = "smtp.gmail.com";
|
||||
public static int smtpPort = 587;
|
||||
public static string user = "ttestowy504@gmail.com";
|
||||
public static string pass = "ChyzySoftware";
|
||||
}
|
||||
}
|
@ -4,28 +4,30 @@
|
||||
}
|
||||
|
||||
|
||||
@if (ViewData.ContainsKey("mailErr"))
|
||||
@if (TempData["mailErr"] != null)
|
||||
{
|
||||
<h3>Error: @ViewData["mailErr"]</h3>
|
||||
string errStr = TempData["mailErr"] as string;
|
||||
<h3>Error: @TempData["mailErr"]</h3>
|
||||
TempData["mailErr"] = null;
|
||||
}
|
||||
|
||||
@using (Html.BeginForm("Send", "Home", FormMethod.Post))
|
||||
{
|
||||
<div class="form-group">
|
||||
@Html.LabelFor(i => i.Subject, new { @class = "label-form" })
|
||||
@Html.EditorFor(i => i.Subject, new { htmlAttributes = new { @value = Model.Subject, @class = "form-control form-emailsend", @placeholder = "Temat" } })
|
||||
@Html.EditorFor(i => i.Subject, new { htmlAttributes = new { @value = Model.Subject, @class = "form-control form-emailsend w100", @placeholder = "Temat" } })
|
||||
@Html.ValidationMessageFor(i => i.Subject)
|
||||
</div>
|
||||
|
||||
<div class="form-group">
|
||||
@Html.LabelFor(i => i.EMailTo, new { @class = "label-form" })
|
||||
@Html.EditorFor(i => i.EMailTo, new { htmlAttributes = new { @value = Model.EMailTo, @class = "form-control form-emailsend", @placeholder = "Do" } })
|
||||
@Html.EditorFor(i => i.EMailTo, new { htmlAttributes = new { @value = Model.EMailTo, @class = "form-control form-emailsend w100", @placeholder = "Do" } })
|
||||
@Html.ValidationMessageFor(i => i.EMailTo)
|
||||
</div>
|
||||
|
||||
<div class="form-group" >
|
||||
@Html.LabelFor(i => i.Content, new { @class = "label-form" })
|
||||
@Html.EditorFor(i => i.Content, new { htmlAttributes = new { @value = Model.Content, @class = "form-control", @id = "exampleFormControlTextarea3", @rows=9, @placeholder = "Odpowiedź" } })
|
||||
@Html.EditorFor(i => i.Content, new { htmlAttributes = new { @value = Model.Content, @class = "form-control w100", @id = "exampleFormControlTextarea3", @rows=9, @placeholder = "Odpowiedź" } })
|
||||
@Html.ValidationMessageFor(i => i.Content)
|
||||
</div>
|
||||
|
||||
|
@ -20,10 +20,8 @@
|
||||
@Html.ActionLink("E-mail", "Index", "Home", new { area = "" }, new { @class = "navbar-brand" })
|
||||
</div>
|
||||
<div class="navbar-collapse collapse">
|
||||
<ul class="nav navbar-nav">
|
||||
<li>@Html.ActionLink("Strona Główna", "Index", "Home")</li>
|
||||
<li>@Html.ActionLink("O mnie", "About", "Home")</li>
|
||||
<li>@Html.ActionLink("Kontakt", "Contact", "Home")</li>
|
||||
<ul class="nav navbar-nar">
|
||||
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -10,6 +10,11 @@
|
||||
</configSections>
|
||||
<appSettings>
|
||||
<add key="webpages:Version" value="3.0.0.0" />
|
||||
<add key="user-mail" value="ttestowy504@gmail.com" />
|
||||
<add key="pass-mail" value="ChyzySoftware" />
|
||||
<add key="smtp-port" value="587" />
|
||||
<add key="smtp-server" value="smtp.gmail.com" />
|
||||
<add key="forum-address" value="http://forum-inzynieria1.azurewebsites.net/home/index"/>
|
||||
<add key="webpages:Enabled" value="false" />
|
||||
<add key="ClientValidationEnabled" value="true" />
|
||||
<add key="UnobtrusiveJavaScriptEnabled" value="true" />
|
||||
|
Loading…
Reference in New Issue
Block a user