summaryrefslogtreecommitdiffstats
path: root/solve/PhotoEditor/Views
diff options
context:
space:
mode:
Diffstat (limited to 'solve/PhotoEditor/Views')
-rw-r--r--solve/PhotoEditor/Views/Home/Index.cshtml29
-rw-r--r--solve/PhotoEditor/Views/Home/Privacy.cshtml6
-rw-r--r--solve/PhotoEditor/Views/Shared/Error.cshtml25
-rw-r--r--solve/PhotoEditor/Views/Shared/_Layout.cshtml49
-rw-r--r--solve/PhotoEditor/Views/Shared/_Layout.cshtml.css48
-rw-r--r--solve/PhotoEditor/Views/Shared/_ValidationScriptsPartial.cshtml2
-rw-r--r--solve/PhotoEditor/Views/_ViewImports.cshtml3
-rw-r--r--solve/PhotoEditor/Views/_ViewStart.cshtml3
8 files changed, 165 insertions, 0 deletions
diff --git a/solve/PhotoEditor/Views/Home/Index.cshtml b/solve/PhotoEditor/Views/Home/Index.cshtml
new file mode 100644
index 0000000..88a9016
--- /dev/null
+++ b/solve/PhotoEditor/Views/Home/Index.cshtml
@@ -0,0 +1,29 @@
+@{
+ ViewData["Title"] = "Home Page";
+}
+
+<script src="js/jquery-3.7.1.min.js"></script>
+
+<div class="text-center">
+ <h1 class="display-4">Welcome</h1>
+ <p>Check out this cool, interactive, JS based PhotoEditor. Upload your image and get started right away!</a>.</p>
+
+ <input type="file" accept="image/*" name="image" id="file" onchange="loadFile(event)" style="display: none;">
+ <p><label for="file" style="cursor: pointer; border: 2px; border-style: dotted;">Upload Image</label></p>
+ <img id="output" width="600">
+ <br>
+ <p>
+ <a href="#" class="btn btn-primary" onclick="downloadImage()">Download Image</a>
+ <a href="#" class="btn btn-secondary" onclick="editImage('GrayscaleImage', [0.5])">Grayscale</a>
+ <a href="#" class="btn btn-secondary" onclick="editImage('BlackWhiteImage', [])">Black and White</a>
+ <a href="#" class="btn btn-secondary" onclick="editImage('InvertImage', [])">Invert Colors</a>
+ <a href="#" class="btn btn-secondary" onclick="editImage('RotateImage', [90])">Rotate 90 Degrees Clockwise</a>
+ <a href="#" class="btn btn-secondary" onclick="editImage('CropImage', [{'X':0,'Y':0,'W':20,'H':20}], ['PhotoEditor.Models.RectangleStruct'])">Crop 20x20</a>
+
+ </p>
+ <div class="alert alert-danger" style="display:none;" id="lastException" role="alert">
+
+ </div>
+</div>
+
+
diff --git a/solve/PhotoEditor/Views/Home/Privacy.cshtml b/solve/PhotoEditor/Views/Home/Privacy.cshtml
new file mode 100644
index 0000000..e6ddda9
--- /dev/null
+++ b/solve/PhotoEditor/Views/Home/Privacy.cshtml
@@ -0,0 +1,6 @@
+@{
+ ViewData["Title"] = "Privacy Policy";
+}
+<h1>@ViewData["Title"]</h1>
+
+<p>This is a CTF challenge. Did you really expect a Privacy Policy here?</p>
diff --git a/solve/PhotoEditor/Views/Shared/Error.cshtml b/solve/PhotoEditor/Views/Shared/Error.cshtml
new file mode 100644
index 0000000..4fa9d25
--- /dev/null
+++ b/solve/PhotoEditor/Views/Shared/Error.cshtml
@@ -0,0 +1,25 @@
+@model ErrorViewModel
+@{
+ ViewData["Title"] = "Error";
+}
+
+<h1 class="text-danger">Error.</h1>
+<h2 class="text-danger">An error occurred while processing your request.</h2>
+
+@if (Model.ShowRequestId)
+{
+ <p>
+ <strong>Request ID:</strong> <code>@Model.RequestId</code>
+ </p>
+}
+
+<h3>Development Mode</h3>
+<p>
+ Swapping to <strong>Development</strong> environment will display more detailed information about the error that occurred.
+</p>
+<p>
+ <strong>The Development environment shouldn't be enabled for deployed applications.</strong>
+ It can result in displaying sensitive information from exceptions to end users.
+ For local debugging, enable the <strong>Development</strong> environment by setting the <strong>ASPNETCORE_ENVIRONMENT</strong> environment variable to <strong>Development</strong>
+ and restarting the app.
+</p>
diff --git a/solve/PhotoEditor/Views/Shared/_Layout.cshtml b/solve/PhotoEditor/Views/Shared/_Layout.cshtml
new file mode 100644
index 0000000..231ebfc
--- /dev/null
+++ b/solve/PhotoEditor/Views/Shared/_Layout.cshtml
@@ -0,0 +1,49 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+ <meta charset="utf-8" />
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+ <title>@ViewData["Title"] - PhotoEditor</title>
+ <link rel="stylesheet" href="~/lib/bootstrap/dist/css/bootstrap.min.css" />
+ <link rel="stylesheet" href="~/css/site.css" asp-append-version="true" />
+ <link rel="stylesheet" href="~/PhotoEditor.styles.css" asp-append-version="true" />
+</head>
+<body>
+ <header>
+ <nav class="navbar navbar-expand-sm navbar-toggleable-sm navbar-light bg-white border-bottom box-shadow mb-3">
+ <div class="container-fluid">
+ <a class="navbar-brand" asp-area="" asp-controller="Home" asp-action="Index">PhotoEditor</a>
+ <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target=".navbar-collapse" aria-controls="navbarSupportedContent"
+ aria-expanded="false" aria-label="Toggle navigation">
+ <span class="navbar-toggler-icon"></span>
+ </button>
+ <div class="navbar-collapse collapse d-sm-inline-flex justify-content-between">
+ <ul class="navbar-nav flex-grow-1">
+ <li class="nav-item">
+ <a class="nav-link text-dark" asp-area="" asp-controller="Home" asp-action="Index">Home</a>
+ </li>
+ <li class="nav-item">
+ <a class="nav-link text-dark" asp-area="" asp-controller="Home" asp-action="Privacy">Privacy</a>
+ </li>
+ </ul>
+ </div>
+ </div>
+ </nav>
+ </header>
+ <div class="container">
+ <main role="main" class="pb-3">
+ @RenderBody()
+ </main>
+ </div>
+
+ <footer class="border-top footer text-muted">
+ <div class="container">
+ &copy; 2024 - PhotoEditor - <a asp-area="" asp-controller="Home" asp-action="Privacy">Privacy</a>
+ </div>
+ </footer>
+ <script src="~/lib/jquery/dist/jquery.min.js"></script>
+ <script src="~/lib/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
+ <script src="~/js/site.js" asp-append-version="true"></script>
+ @await RenderSectionAsync("Scripts", required: false)
+</body>
+</html>
diff --git a/solve/PhotoEditor/Views/Shared/_Layout.cshtml.css b/solve/PhotoEditor/Views/Shared/_Layout.cshtml.css
new file mode 100644
index 0000000..3ff01d4
--- /dev/null
+++ b/solve/PhotoEditor/Views/Shared/_Layout.cshtml.css
@@ -0,0 +1,48 @@
+/* Please see documentation at https://learn.microsoft.com/aspnet/core/client-side/bundling-and-minification
+for details on configuring this project to bundle and minify static web assets. */
+
+a.navbar-brand {
+ white-space: normal;
+ text-align: center;
+ word-break: break-all;
+}
+
+a {
+ color: #0077cc;
+}
+
+.btn-primary {
+ color: #fff;
+ background-color: #1b6ec2;
+ border-color: #1861ac;
+}
+
+.nav-pills .nav-link.active, .nav-pills .show > .nav-link {
+ color: #fff;
+ background-color: #1b6ec2;
+ border-color: #1861ac;
+}
+
+.border-top {
+ border-top: 1px solid #e5e5e5;
+}
+.border-bottom {
+ border-bottom: 1px solid #e5e5e5;
+}
+
+.box-shadow {
+ box-shadow: 0 .25rem .75rem rgba(0, 0, 0, .05);
+}
+
+button.accept-policy {
+ font-size: 1rem;
+ line-height: inherit;
+}
+
+.footer {
+ position: absolute;
+ bottom: 0;
+ width: 100%;
+ white-space: nowrap;
+ line-height: 60px;
+}
diff --git a/solve/PhotoEditor/Views/Shared/_ValidationScriptsPartial.cshtml b/solve/PhotoEditor/Views/Shared/_ValidationScriptsPartial.cshtml
new file mode 100644
index 0000000..ff9c793
--- /dev/null
+++ b/solve/PhotoEditor/Views/Shared/_ValidationScriptsPartial.cshtml
@@ -0,0 +1,2 @@
+<script src="~/lib/jquery-validation/dist/jquery.validate.min.js"></script>
+<script src="~/lib/jquery-validation-unobtrusive/jquery.validate.unobtrusive.min.js"></script>
diff --git a/solve/PhotoEditor/Views/_ViewImports.cshtml b/solve/PhotoEditor/Views/_ViewImports.cshtml
new file mode 100644
index 0000000..b9d6646
--- /dev/null
+++ b/solve/PhotoEditor/Views/_ViewImports.cshtml
@@ -0,0 +1,3 @@
+@using PhotoEditor
+@using PhotoEditor.Models
+@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers
diff --git a/solve/PhotoEditor/Views/_ViewStart.cshtml b/solve/PhotoEditor/Views/_ViewStart.cshtml
new file mode 100644
index 0000000..6e88aa3
--- /dev/null
+++ b/solve/PhotoEditor/Views/_ViewStart.cshtml
@@ -0,0 +1,3 @@
+@{
+ Layout = "_Layout";
+}