216 lines
7.1 KiB
C#
216 lines
7.1 KiB
C#
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using WeatherForecast.Models;
|
|
|
|
namespace WeatherForecast.Controllers;
|
|
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
[ApiController]
|
|
[AllowAnonymous]
|
|
[Route("api/[controller]")]
|
|
public class StaticContentController : ControllerBase {
|
|
|
|
private readonly ILogger<StaticContentController> _logger;
|
|
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <param name="logger"></param>
|
|
public StaticContentController(
|
|
ILogger<StaticContentController> logger
|
|
) {
|
|
_logger = logger;
|
|
}
|
|
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpGet]
|
|
public IActionResult Get([FromQuery] string? locale = "en-US") {
|
|
|
|
var routes = new List<RouteModel> {
|
|
new RouteModel ("/", "Home"),
|
|
new RouteModel ("/home", "Home")
|
|
};
|
|
|
|
var shopRoute = new RouteModel("/shop",
|
|
new List<RouteModel> {
|
|
new RouteModel ("", "ShopCatalog"),
|
|
new RouteModel (":page", "ShopCatalog"),
|
|
new RouteModel (":page", new List<RouteModel> {
|
|
new RouteModel (":slug", "ShopItem")
|
|
})
|
|
});
|
|
|
|
var blogRoute = new RouteModel("/blog",
|
|
new List<RouteModel> {
|
|
new RouteModel ("", "BlogCatalog"),
|
|
new RouteModel (":page", "BlogCatalog"),
|
|
new RouteModel (":page", new List<RouteModel> {
|
|
new RouteModel (":slug", "BlogItem")
|
|
})
|
|
});
|
|
|
|
routes.Add(shopRoute);
|
|
routes.Add(blogRoute);
|
|
|
|
var demoRoutes = new List<RouteModel> {
|
|
new RouteModel ("/counter", "Counter"),
|
|
new RouteModel ("/fetch-data", new List<RouteModel> {
|
|
new RouteModel ("", "FetchData"),
|
|
new RouteModel (":startDateIndex", "FetchData")
|
|
})
|
|
};
|
|
|
|
routes = routes.Concat(demoRoutes).ToList();
|
|
|
|
var adminRoutes = new List<RouteModel> {
|
|
new RouteModel ("/admin", "AdminHome")
|
|
};
|
|
|
|
var serviceRoutes = new List<RouteModel> {
|
|
new RouteModel ("/signin", "Signin"),
|
|
new RouteModel ("/signup", "Signup"),
|
|
new RouteModel ("*", "Error")
|
|
};
|
|
|
|
var topMenu = new List<MenuItemModel> {
|
|
new MenuItemModel ("Home", "/"),
|
|
new MenuItemModel ("Shop", "/shop"),
|
|
new MenuItemModel ("Blog", "/blog"),
|
|
new MenuItemModel ("Signin", "/signin"),
|
|
new MenuItemModel ("Sognout", "/signout")
|
|
};
|
|
|
|
var sideMenu = new List<MenuItemModel> {
|
|
new MenuItemModel ("alert-triangle", "Home", "/admin"),
|
|
new MenuItemModel ("activity", "Page", new List<MenuItemModel> {
|
|
new MenuItemModel ("activity", "Page-1", "Page-1"),
|
|
new MenuItemModel ("activity", "Page-2", "Page-2"),
|
|
new MenuItemModel ("activity", "Page-3", "Page-3")
|
|
}),
|
|
new MenuItemModel ("Counter", "/counter"),
|
|
new MenuItemModel ("Fetch data", "/fetch-data")
|
|
};
|
|
|
|
|
|
|
|
|
|
var blogItems = new List<BlogItemModel>();
|
|
for (int i = 0; i < 3; i++) {
|
|
var blogItemModel = new BlogItemModel {
|
|
Id = Guid.NewGuid(),
|
|
Slug = "blog-post-title",
|
|
Image = new ImageModel { Src = "https://dummyimage.com/600x350/ced4da/6c757d", Alt = "..." },
|
|
Badge = "news",
|
|
Title = "Blog post title",
|
|
ShortText = "Lorem ipsum, dolor sit amet consectetur adipisicing elit. Eaque fugit ratione dicta mollitia. Officiis ad...",
|
|
Text = "",
|
|
Author = new AuthorModel {
|
|
Id = Guid.NewGuid(),
|
|
Image = new ImageModel { Src = "https://dummyimage.com/40x40/ced4da/6c757d", Alt = "..." },
|
|
NickName = "Admin"
|
|
},
|
|
Created = DateTime.UtcNow,
|
|
Tags = new List<string> { "react", "redux", "webapi" },
|
|
|
|
ReadTime = 10,
|
|
Likes = 200,
|
|
};
|
|
|
|
blogItems.Add(blogItemModel);
|
|
}
|
|
|
|
|
|
var pages = new List<object>();
|
|
|
|
pages.Add(new {
|
|
Id = "HomePage",
|
|
TitleSection = new {
|
|
Title = "Hello, World!",
|
|
Text = @"
|
|
<p>Welcome to your new single-page application, built with:</p>
|
|
<ul>
|
|
<li><a href='https://get.asp.net/'>ASP.NET Core</a> and <a href='https://msdn.microsoft.com/en-us/library/67ef8sbd.aspx'>C#</a> for cross-platform server-side code</li>
|
|
<li><a href='https://facebook.github.io/react/'>React</a> and <a href='https://redux.js.org/'>Redux</a> for client-side code</li>
|
|
<li><a href='https://getbootstrap.com/'>Bootstrap</a>, <a href='https://reactstrap.github.io/?path=/story/home-installation--page'>Reactstrap</a> and <a href=\""https://feathericons.com/\"">Feather icons</a> for layout and styling</li>
|
|
</ul>",
|
|
Image = new ImageModel { Src = "https://dummyimage.com/600x400/343a40/6c757d", Alt = "..." },
|
|
PrimaryLink = new MenuItemModel("Get Started", "#features"),
|
|
SecondaryLink = new MenuItemModel("Learn More", "#!")
|
|
},
|
|
FeaturesSection = new {
|
|
Title = "To help you get started, we have also set up:",
|
|
Items = new[] {
|
|
new {
|
|
Icon = "navigation",
|
|
Title = "Client-side navigation",
|
|
Text = "For example, click <em>Counter</em> then <em>Back</em> to return here."
|
|
},
|
|
new {
|
|
Icon = "server",
|
|
Title = "Development server integration",
|
|
Text = "In development mode, the development server from <code>create-react-app</code> runs in the background automatically, so your client-side resources are dynamically built on demand and the page refreshes when you modify any file."
|
|
},
|
|
new {
|
|
Icon = "terminal",
|
|
Title = "Efficient production builds",
|
|
Text = "In production mode, development-time features are disabled, and your <code>dotnet publish</code> configuration produces minified, efficiently bundled JavaScript files."
|
|
}
|
|
}
|
|
},
|
|
TestimonialsSection = new {
|
|
Items = new[] {
|
|
new {
|
|
Text = "The <code>ClientApp</code> subdirectory is a standard React application based on the <code>create-react-app</code> template. If you open a command prompt in that directory, you can run <code>yarn</code> commands such as <code>yarn test</code> or <code>yarn install</code>.",
|
|
Author = new AuthorModel {
|
|
Image = new ImageModel { Src = "https://dummyimage.com/40x40/ced4da/6c757d", Alt = "..." },
|
|
NickName = "Tom Ato/CEO, Pomodoro"
|
|
}
|
|
}
|
|
}
|
|
},
|
|
FeaturedBlogsSection = new {
|
|
Title = "From our blog",
|
|
Items = blogItems
|
|
},
|
|
CallToActionSection = new {
|
|
Title = "New products, delivered to you.",
|
|
Text = "Sign up for our newsletter for the latest updates.",
|
|
PrivacyDisclaimer = "We care about privacy, and will never share your data."
|
|
}
|
|
});
|
|
|
|
pages.Add(new {
|
|
Id = "ShopCatalog",
|
|
TitleSection = new {
|
|
Title = "Shop in style",
|
|
Text = "With this shop hompeage template"
|
|
}
|
|
});
|
|
|
|
pages.Add(new {
|
|
Id = "BlogCatalog",
|
|
TitleSection = new {
|
|
Title = "Welcome to Blog Home!",
|
|
Text = "A Bootstrap 5 starter layout for your next blog homepage"
|
|
}
|
|
});
|
|
|
|
return Ok(new {
|
|
SiteName = "MAKS-IT",
|
|
|
|
Routes = routes,
|
|
AdminRoutes = adminRoutes,
|
|
ServiceRoutes = serviceRoutes,
|
|
|
|
TopMenu = topMenu,
|
|
SideMenu = sideMenu,
|
|
Pages = pages
|
|
});
|
|
}
|
|
}
|