Gregory Rudolph
3 years ago
28 changed files with 1204 additions and 0 deletions
@ -0,0 +1,35 @@
@@ -0,0 +1,35 @@
|
||||
{ |
||||
"version": "0.2.0", |
||||
"configurations": [ |
||||
{ |
||||
// Use IntelliSense to find out which attributes exist for C# debugging |
||||
// Use hover for the description of the existing attributes |
||||
// For further information visit https://github.com/OmniSharp/omnisharp-vscode/blob/master/debugger-launchjson.md |
||||
"name": ".NET Core Launch (web)", |
||||
"type": "coreclr", |
||||
"request": "launch", |
||||
"preLaunchTask": "build", |
||||
// If you have changed target frameworks, make sure to update the program path. |
||||
"program": "${workspaceFolder}/bin/Debug/net5.0/NikolaNet.dll", |
||||
"args": [], |
||||
"cwd": "${workspaceFolder}", |
||||
"stopAtEntry": false, |
||||
// Enable launching a web browser when ASP.NET Core starts. For more information: https://aka.ms/VSCode-CS-LaunchJson-WebBrowser |
||||
"serverReadyAction": { |
||||
"action": "openExternally", |
||||
"pattern": "\\bNow listening on:\\s+(https?://\\S+)" |
||||
}, |
||||
"env": { |
||||
"ASPNETCORE_ENVIRONMENT": "Development" |
||||
}, |
||||
"sourceFileMap": { |
||||
"/Views": "${workspaceFolder}/Views" |
||||
} |
||||
}, |
||||
{ |
||||
"name": ".NET Core Attach", |
||||
"type": "coreclr", |
||||
"request": "attach" |
||||
} |
||||
] |
||||
} |
@ -0,0 +1,42 @@
@@ -0,0 +1,42 @@
|
||||
{ |
||||
"version": "2.0.0", |
||||
"tasks": [ |
||||
{ |
||||
"label": "build", |
||||
"command": "dotnet", |
||||
"type": "process", |
||||
"args": [ |
||||
"build", |
||||
"${workspaceFolder}/NikolaNet.csproj", |
||||
"/property:GenerateFullPaths=true", |
||||
"/consoleloggerparameters:NoSummary" |
||||
], |
||||
"problemMatcher": "$msCompile" |
||||
}, |
||||
{ |
||||
"label": "publish", |
||||
"command": "dotnet", |
||||
"type": "process", |
||||
"args": [ |
||||
"publish", |
||||
"${workspaceFolder}/NikolaNet.csproj", |
||||
"/property:GenerateFullPaths=true", |
||||
"/consoleloggerparameters:NoSummary" |
||||
], |
||||
"problemMatcher": "$msCompile" |
||||
}, |
||||
{ |
||||
"label": "watch", |
||||
"command": "dotnet", |
||||
"type": "process", |
||||
"args": [ |
||||
"watch", |
||||
"run", |
||||
"${workspaceFolder}/NikolaNet.csproj", |
||||
"/property:GenerateFullPaths=true", |
||||
"/consoleloggerparameters:NoSummary" |
||||
], |
||||
"problemMatcher": "$msCompile" |
||||
} |
||||
] |
||||
} |
@ -0,0 +1,11 @@
@@ -0,0 +1,11 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk.Web"> |
||||
|
||||
<PropertyGroup> |
||||
<TargetFramework>net5.0</TargetFramework> |
||||
</PropertyGroup> |
||||
|
||||
<ItemGroup> |
||||
<PackageReference Include="Newtonsoft.Json" Version="13.0.1" /> |
||||
</ItemGroup> |
||||
|
||||
</Project> |
@ -0,0 +1,26 @@
@@ -0,0 +1,26 @@
|
||||
@page |
||||
@model ErrorModel |
||||
@{ |
||||
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 the <strong>Development</strong> environment displays 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> |
@ -0,0 +1,32 @@
@@ -0,0 +1,32 @@
|
||||
using System; |
||||
using System.Collections.Generic; |
||||
using System.Diagnostics; |
||||
using System.Linq; |
||||
using System.Threading.Tasks; |
||||
using Microsoft.AspNetCore.Mvc; |
||||
using Microsoft.AspNetCore.Mvc.RazorPages; |
||||
using Microsoft.Extensions.Logging; |
||||
|
||||
namespace NikolaNet.Pages |
||||
{ |
||||
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)] |
||||
[IgnoreAntiforgeryToken] |
||||
public class ErrorModel : PageModel |
||||
{ |
||||
public string RequestId { get; set; } |
||||
|
||||
public bool ShowRequestId => !string.IsNullOrEmpty(RequestId); |
||||
|
||||
private readonly ILogger<ErrorModel> _logger; |
||||
|
||||
public ErrorModel(ILogger<ErrorModel> logger) |
||||
{ |
||||
_logger = logger; |
||||
} |
||||
|
||||
public void OnGet() |
||||
{ |
||||
RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier; |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,8 @@
@@ -0,0 +1,8 @@
|
||||
@page |
||||
@model PrivacyModel |
||||
@{ |
||||
ViewData["Title"] = "Privacy Policy"; |
||||
} |
||||
<h1>@ViewData["Title"]</h1> |
||||
|
||||
<p>Nothing is stored server-side. Delete the "Auth" cookie and that's all we have.</p> |
@ -0,0 +1,2 @@
@@ -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> |
@ -0,0 +1,3 @@
@@ -0,0 +1,3 @@
|
||||
@{ |
||||
Layout = "_Layout"; |
||||
} |
@ -0,0 +1,26 @@
@@ -0,0 +1,26 @@
|
||||
using System; |
||||
using System.Collections.Generic; |
||||
using System.Linq; |
||||
using System.Threading.Tasks; |
||||
using Microsoft.AspNetCore.Hosting; |
||||
using Microsoft.Extensions.Configuration; |
||||
using Microsoft.Extensions.Hosting; |
||||
using Microsoft.Extensions.Logging; |
||||
|
||||
namespace NikolaNet |
||||
{ |
||||
public class Program |
||||
{ |
||||
public static void Main(string[] args) |
||||
{ |
||||
CreateHostBuilder(args).Build().Run(); |
||||
} |
||||
|
||||
public static IHostBuilder CreateHostBuilder(string[] args) => |
||||
Host.CreateDefaultBuilder(args) |
||||
.ConfigureWebHostDefaults(webBuilder => |
||||
{ |
||||
webBuilder.UseStartup<Startup>(); |
||||
}); |
||||
} |
||||
} |
@ -0,0 +1,56 @@
@@ -0,0 +1,56 @@
|
||||
using System; |
||||
using System.Collections.Generic; |
||||
using System.Linq; |
||||
using System.Threading.Tasks; |
||||
using Microsoft.AspNetCore.Builder; |
||||
using Microsoft.AspNetCore.Hosting; |
||||
using Microsoft.AspNetCore.HttpsPolicy; |
||||
using Microsoft.Extensions.Configuration; |
||||
using Microsoft.Extensions.DependencyInjection; |
||||
using Microsoft.Extensions.Hosting; |
||||
|
||||
namespace NikolaNet |
||||
{ |
||||
public class Startup |
||||
{ |
||||
public Startup(IConfiguration configuration) |
||||
{ |
||||
Configuration = configuration; |
||||
} |
||||
|
||||
public IConfiguration Configuration { get; } |
||||
|
||||
// This method gets called by the runtime. Use this method to add services to the container.
|
||||
public void ConfigureServices(IServiceCollection services) |
||||
{ |
||||
services.AddRazorPages(); |
||||
} |
||||
|
||||
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
|
||||
public void Configure(IApplicationBuilder app, IWebHostEnvironment env) |
||||
{ |
||||
if (env.IsDevelopment()) |
||||
{ |
||||
app.UseDeveloperExceptionPage(); |
||||
} |
||||
else |
||||
{ |
||||
app.UseExceptionHandler("/Error"); |
||||
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
|
||||
app.UseHsts(); |
||||
} |
||||
|
||||
app.UseHttpsRedirection(); |
||||
app.UseStaticFiles(); |
||||
|
||||
app.UseRouting(); |
||||
|
||||
app.UseAuthorization(); |
||||
|
||||
app.UseEndpoints(endpoints => |
||||
{ |
||||
endpoints.MapRazorPages(); |
||||
}); |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,10 @@
@@ -0,0 +1,10 @@
|
||||
{ |
||||
"DetailedErrors": true, |
||||
"Logging": { |
||||
"LogLevel": { |
||||
"Default": "Information", |
||||
"Microsoft": "Warning", |
||||
"Microsoft.Hosting.Lifetime": "Information" |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,10 @@
@@ -0,0 +1,10 @@
|
||||
{ |
||||
"Logging": { |
||||
"LogLevel": { |
||||
"Default": "Information", |
||||
"Microsoft": "Warning", |
||||
"Microsoft.Hosting.Lifetime": "Information" |
||||
} |
||||
}, |
||||
"AllowedHosts": "*" |
||||
} |
After Width: | Height: | Size: 5.3 KiB |
@ -0,0 +1,22 @@
@@ -0,0 +1,22 @@
|
||||
The MIT License (MIT) |
||||
|
||||
Copyright (c) 2011-2018 Twitter, Inc. |
||||
Copyright (c) 2011-2018 The Bootstrap Authors |
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy |
||||
of this software and associated documentation files (the "Software"), to deal |
||||
in the Software without restriction, including without limitation the rights |
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
||||
copies of the Software, and to permit persons to whom the Software is |
||||
furnished to do so, subject to the following conditions: |
||||
|
||||
The above copyright notice and this permission notice shall be included in |
||||
all copies or substantial portions of the Software. |
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
||||
THE SOFTWARE. |
@ -0,0 +1,12 @@
@@ -0,0 +1,12 @@
|
||||
Copyright (c) .NET Foundation. All rights reserved. |
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License"); you may not use |
||||
these files except in compliance with the License. You may obtain a copy of the |
||||
License at |
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0 |
||||
|
||||
Unless required by applicable law or agreed to in writing, software distributed |
||||
under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR |
||||
CONDITIONS OF ANY KIND, either express or implied. See the License for the |
||||
specific language governing permissions and limitations under the License. |
@ -0,0 +1,432 @@
@@ -0,0 +1,432 @@
|
||||
// Unobtrusive validation support library for jQuery and jQuery Validate
|
||||
// Copyright (c) .NET Foundation. All rights reserved.
|
||||
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
||||
// @version v3.2.11
|
||||
|
||||
/*jslint white: true, browser: true, onevar: true, undef: true, nomen: true, eqeqeq: true, plusplus: true, bitwise: true, regexp: true, newcap: true, immed: true, strict: false */ |
||||
/*global document: false, jQuery: false */ |
||||
|
||||
(function (factory) { |
||||
if (typeof define === 'function' && define.amd) { |
||||
// AMD. Register as an anonymous module.
|
||||
define("jquery.validate.unobtrusive", ['jquery-validation'], factory); |
||||
} else if (typeof module === 'object' && module.exports) { |
||||
// CommonJS-like environments that support module.exports
|
||||
module.exports = factory(require('jquery-validation')); |
||||
} else { |
||||
// Browser global
|
||||
jQuery.validator.unobtrusive = factory(jQuery); |
||||
} |
||||
}(function ($) { |
||||
var $jQval = $.validator, |
||||
adapters, |
||||
data_validation = "unobtrusiveValidation"; |
||||
|
||||
function setValidationValues(options, ruleName, value) { |
||||
options.rules[ruleName] = value; |
||||
if (options.message) { |
||||
options.messages[ruleName] = options.message; |
||||
} |
||||
} |
||||
|
||||
function splitAndTrim(value) { |
||||
return value.replace(/^\s+|\s+$/g, "").split(/\s*,\s*/g); |
||||
} |
||||
|
||||
function escapeAttributeValue(value) { |
||||
// As mentioned on http://api.jquery.com/category/selectors/
|
||||
return value.replace(/([!"#$%&'()*+,./:;<=>?@\[\\\]^`{|}~])/g, "\\$1"); |
||||
} |
||||
|
||||
function getModelPrefix(fieldName) { |
||||
return fieldName.substr(0, fieldName.lastIndexOf(".") + 1); |
||||
} |
||||
|
||||
function appendModelPrefix(value, prefix) { |
||||
if (value.indexOf("*.") === 0) { |
||||
value = value.replace("*.", prefix); |
||||
} |
||||
return value; |
||||
} |
||||
|
||||
function onError(error, inputElement) { // 'this' is the form element
|
||||
var container = $(this).find("[data-valmsg-for='" + escapeAttributeValue(inputElement[0].name) + "']"), |
||||
replaceAttrValue = container.attr("data-valmsg-replace"), |
||||
replace = replaceAttrValue ? $.parseJSON(replaceAttrValue) !== false : null; |
||||
|
||||
container.removeClass("field-validation-valid").addClass("field-validation-error"); |
||||
error.data("unobtrusiveContainer", container); |
||||
|
||||
if (replace) { |
||||
container.empty(); |
||||
error.removeClass("input-validation-error").appendTo(container); |
||||
} |
||||
else { |
||||
error.hide(); |
||||
} |
||||
} |
||||
|
||||
function onErrors(event, validator) { // 'this' is the form element
|
||||
var container = $(this).find("[data-valmsg-summary=true]"), |
||||
list = container.find("ul"); |
||||
|
||||
if (list && list.length && validator.errorList.length) { |
||||
list.empty(); |
||||
container.addClass("validation-summary-errors").removeClass("validation-summary-valid"); |
||||
|
||||
$.each(validator.errorList, function () { |
||||
$("<li />").html(this.message).appendTo(list); |
||||
}); |
||||
} |
||||
} |
||||
|
||||
function onSuccess(error) { // 'this' is the form element
|
||||
var container = error.data("unobtrusiveContainer"); |
||||
|
||||
if (container) { |
||||
var replaceAttrValue = container.attr("data-valmsg-replace"), |
||||
replace = replaceAttrValue ? $.parseJSON(replaceAttrValue) : null; |
||||
|
||||
container.addClass("field-validation-valid").removeClass("field-validation-error"); |
||||
error.removeData("unobtrusiveContainer"); |
||||
|
||||
if (replace) { |
||||
container.empty(); |
||||
} |
||||
} |
||||
} |
||||
|
||||
function onReset(event) { // 'this' is the form element
|
||||
var $form = $(this), |
||||
key = '__jquery_unobtrusive_validation_form_reset'; |
||||
if ($form.data(key)) { |
||||
return; |
||||
} |
||||
// Set a flag that indicates we're currently resetting the form.
|
||||
$form.data(key, true); |
||||
try { |
||||
$form.data("validator").resetForm(); |
||||
} finally { |
||||
$form.removeData(key); |
||||
} |
||||
|
||||
$form.find(".validation-summary-errors") |
||||
.addClass("validation-summary-valid") |
||||
.removeClass("validation-summary-errors"); |
||||
$form.find(".field-validation-error") |
||||
.addClass("field-validation-valid") |
||||
.removeClass("field-validation-error") |
||||
.removeData("unobtrusiveContainer") |
||||
.find(">*") // If we were using valmsg-replace, get the underlying error
|
||||
.removeData("unobtrusiveContainer"); |
||||
} |
||||
|
||||
function validationInfo(form) { |
||||
var $form = $(form), |
||||
result = $form.data(data_validation), |
||||
onResetProxy = $.proxy(onReset, form), |
||||
defaultOptions = $jQval.unobtrusive.options || {}, |
||||
execInContext = function (name, args) { |
||||
var func = defaultOptions[name]; |
||||
func && $.isFunction(func) && func.apply(form, args); |
||||
}; |
||||
|
||||
if (!result) { |
||||
result = { |
||||
options: { // options structure passed to jQuery Validate's validate() method
|
||||
errorClass: defaultOptions.errorClass || "input-validation-error", |
||||
errorElement: defaultOptions.errorElement || "span", |
||||
errorPlacement: function () { |
||||
onError.apply(form, arguments); |
||||
execInContext("errorPlacement", arguments); |
||||
}, |
||||
invalidHandler: function () { |
||||
onErrors.apply(form, arguments); |
||||
execInContext("invalidHandler", arguments); |
||||
}, |
||||
messages: {}, |
||||
rules: {}, |
||||
success: function () { |
||||
onSuccess.apply(form, arguments); |
||||
execInContext("success", arguments); |
||||
} |
||||
}, |
||||
attachValidation: function () { |
||||
$form |
||||
.off("reset." + data_validation, onResetProxy) |
||||
.on("reset." + data_validation, onResetProxy) |
||||
.validate(this.options); |
||||
}, |
||||
validate: function () { // a validation function that is called by unobtrusive Ajax
|
||||
$form.validate(); |
||||
return $form.valid(); |
||||
} |
||||
}; |
||||
$form.data(data_validation, result); |
||||
} |
||||
|
||||
return result; |
||||
} |
||||
|
||||
$jQval.unobtrusive = { |
||||
adapters: [], |
||||
|
||||
parseElement: function (element, skipAttach) { |
||||
/// <summary>
|
||||
/// Parses a single HTML element for unobtrusive validation attributes.
|
||||
/// </summary>
|
||||
/// <param name="element" domElement="true">The HTML element to be parsed.</param>
|
||||
/// <param name="skipAttach" type="Boolean">[Optional] true to skip attaching the
|
||||
/// validation to the form. If parsing just this single element, you should specify true.
|
||||
/// If parsing several elements, you should specify false, and manually attach the validation
|
||||
/// to the form when you are finished. The default is false.</param>
|
||||
var $element = $(element), |
||||
form = $element.parents("form")[0], |
||||
valInfo, rules, messages; |
||||
|
||||
if (!form) { // Cannot do client-side validation without a form
|
||||
return; |
||||
} |
||||
|
||||
valInfo = validationInfo(form); |
||||
valInfo.options.rules[element.name] = rules = {}; |
||||
valInfo.options.messages[element.name] = messages = {}; |
||||
|
||||
$.each(this.adapters, function () { |
||||
var prefix = "data-val-" + this.name, |
||||
message = $element.attr(prefix), |
||||
paramValues = {}; |
||||
|
||||
if (message !== undefined) { // Compare against undefined, because an empty message is legal (and falsy)
|
||||
prefix += "-"; |
||||
|
||||
$.each(this.params, function () { |
||||
paramValues[this] = $element.attr(prefix + this); |
||||
}); |
||||
|
||||
this.adapt({ |
||||
element: element, |
||||
form: form, |
||||
message: message, |
||||
params: paramValues, |
||||
rules: rules, |
||||
messages: messages |
||||
}); |
||||
} |
||||
}); |
||||
|
||||
$.extend(rules, { "__dummy__": true }); |
||||
|
||||
if (!skipAttach) { |
||||
valInfo.attachValidation(); |
||||
} |
||||
}, |
||||
|
||||
parse: function (selector) { |
||||
/// <summary>
|
||||
/// Parses all the HTML elements in the specified selector. It looks for input elements decorated
|
||||
/// with the [data-val=true] attribute value and enables validation according to the data-val-*
|
||||
/// attribute values.
|
||||
/// </summary>
|
||||
/// <param name="selector" type="String">Any valid jQuery selector.</param>
|
||||
|
||||
// $forms includes all forms in selector's DOM hierarchy (parent, children and self) that have at least one
|
||||
// element with data-val=true
|
||||
var $selector = $(selector), |
||||
$forms = $selector.parents() |
||||
.addBack() |
||||
.filter("form") |
||||
.add($selector.find("form")) |
||||
.has("[data-val=true]"); |
||||
|
||||
$selector.find("[data-val=true]").each(function () { |
||||
$jQval.unobtrusive.parseElement(this, true); |
||||
}); |
||||
|
||||
$forms.each(function () { |
||||
var info = validationInfo(this); |
||||
if (info) { |
||||
info.attachValidation(); |
||||
} |
||||
}); |
||||
} |
||||
}; |
||||
|
||||
adapters = $jQval.unobtrusive.adapters; |
||||
|
||||
adapters.add = function (adapterName, params, fn) { |
||||
/// <summary>Adds a new adapter to convert unobtrusive HTML into a jQuery Validate validation.</summary>
|
||||
/// <param name="adapterName" type="String">The name of the adapter to be added. This matches the name used
|
||||
/// in the data-val-nnnn HTML attribute (where nnnn is the adapter name).</param>
|
||||
/// <param name="params" type="Array" optional="true">[Optional] An array of parameter names (strings) that will
|
||||
/// be extracted from the data-val-nnnn-mmmm HTML attributes (where nnnn is the adapter name, and
|
||||
/// mmmm is the parameter name).</param>
|
||||
/// <param name="fn" type="Function">The function to call, which adapts the values from the HTML
|
||||
/// attributes into jQuery Validate rules and/or messages.</param>
|
||||
/// <returns type="jQuery.validator.unobtrusive.adapters" />
|
||||
if (!fn) { // Called with no params, just a function
|
||||
fn = params; |
||||
params = []; |
||||
} |
||||
this.push({ name: adapterName, params: params, adapt: fn }); |
||||
return this; |
||||
}; |
||||
|
||||
adapters.addBool = function (adapterName, ruleName) { |
||||
/// <summary>Adds a new adapter to convert unobtrusive HTML into a jQuery Validate validation, where
|
||||
/// the jQuery Validate validation rule has no parameter values.</summary>
|
||||
/// <param name="adapterName" type="String">The name of the adapter to be added. This matches the name used
|
||||
/// in the data-val-nnnn HTML attribute (where nnnn is the adapter name).</param>
|
||||
/// <param name="ruleName" type="String" optional="true">[Optional] The name of the jQuery Validate rule. If not provided, the value
|
||||
/// of adapterName will be used instead.</param>
|
||||
/// <returns type="jQuery.validator.unobtrusive.adapters" />
|
||||
return this.add(adapterName, function (options) { |
||||
setValidationValues(options, ruleName || adapterName, true); |
||||
}); |
||||
}; |
||||
|
||||
adapters.addMinMax = function (adapterName, minRuleName, maxRuleName, minMaxRuleName, minAttribute, maxAttribute) { |
||||
/// <summary>Adds a new adapter to convert unobtrusive HTML into a jQuery Validate validation, where
|
||||
/// the jQuery Validate validation has three potential rules (one for min-only, one for max-only, and
|
||||
/// one for min-and-max). The HTML parameters are expected to be named -min and -max.</summary>
|
||||
/// <param name="adapterName" type="String">The name of the adapter to be added. This matches the name used
|
||||
/// in the data-val-nnnn HTML attribute (where nnnn is the adapter name).</param>
|
||||
/// <param name="minRuleName" type="String">The name of the jQuery Validate rule to be used when you only
|
||||
/// have a minimum value.</param>
|
||||
/// <param name="maxRuleName" type="String">The name of the jQuery Validate rule to be used when you only
|
||||
/// have a maximum value.</param>
|
||||
/// <param name="minMaxRuleName" type="String">The name of the jQuery Validate rule to be used when you
|
||||
/// have both a minimum and maximum value.</param>
|
||||
/// <param name="minAttribute" type="String" optional="true">[Optional] The name of the HTML attribute that
|
||||
/// contains the minimum value. The default is "min".</param>
|
||||
/// <param name="maxAttribute" type="String" optional="true">[Optional] The name of the HTML attribute that
|
||||
/// contains the maximum value. The default is "max".</param>
|
||||
/// <returns type="jQuery.validator.unobtrusive.adapters" />
|
||||
return this.add(adapterName, [minAttribute || "min", maxAttribute || "max"], function (options) { |
||||
var min = options.params.min, |
||||
max = options.params.max; |
||||
|
||||
if (min && max) { |
||||
setValidationValues(options, minMaxRuleName, [min, max]); |
||||
} |
||||
else if (min) { |
||||
setValidationValues(options, minRuleName, min); |
||||
} |
||||
else if (max) { |
||||
setValidationValues(options, maxRuleName, max); |
||||
} |
||||
}); |
||||
}; |
||||
|
||||
adapters.addSingleVal = function (adapterName, attribute, ruleName) { |
||||
/// <summary>Adds a new adapter to convert unobtrusive HTML into a jQuery Validate validation, where
|
||||
/// the jQuery Validate validation rule has a single value.</summary>
|
||||
/// <param name="adapterName" type="String">The name of the adapter to be added. This matches the name used
|
||||
/// in the data-val-nnnn HTML attribute(where nnnn is the adapter name).</param>
|
||||
/// <param name="attribute" type="String">[Optional] The name of the HTML attribute that contains the value.
|
||||
/// The default is "val".</param>
|
||||
/// <param name="ruleName" type="String" optional="true">[Optional] The name of the jQuery Validate rule. If not provided, the value
|
||||
/// of adapterName will be used instead.</param>
|
||||
/// <returns type="jQuery.validator.unobtrusive.adapters" />
|
||||
return this.add(adapterName, [attribute || "val"], function (options) { |
||||
setValidationValues(options, ruleName || adapterName, options.params[attribute]); |
||||
}); |
||||
}; |
||||
|
||||
$jQval.addMethod("__dummy__", function (value, element, params) { |
||||
return true; |
||||
}); |
||||
|
||||
$jQval.addMethod("regex", function (value, element, params) { |
||||
var match; |
||||
if (this.optional(element)) { |
||||
return true; |
||||
} |
||||
|
||||
match = new RegExp(params).exec(value); |
||||
return (match && (match.index === 0) && (match[0].length === value.length)); |
||||
}); |
||||
|
||||
$jQval.addMethod("nonalphamin", function (value, element, nonalphamin) { |
||||
var match; |
||||
if (nonalphamin) { |
||||
match = value.match(/\W/g); |
||||
match = match && match.length >= nonalphamin; |
||||
} |
||||
return match; |
||||
}); |
||||
|
||||
if ($jQval.methods.extension) { |
||||
adapters.addSingleVal("accept", "mimtype"); |
||||
adapters.addSingleVal("extension", "extension"); |
||||
} else { |
||||
// for backward compatibility, when the 'extension' validation method does not exist, such as with versions
|
||||
// of JQuery Validation plugin prior to 1.10, we should use the 'accept' method for
|
||||
// validating the extension, and ignore mime-type validations as they are not supported.
|
||||
adapters.addSingleVal("extension", "extension", "accept"); |
||||
} |
||||
|
||||
adapters.addSingleVal("regex", "pattern"); |
||||
adapters.addBool("creditcard").addBool("date").addBool("digits").addBool("email").addBool("number").addBool("url"); |
||||
adapters.addMinMax("length", "minlength", "maxlength", "rangelength").addMinMax("range", "min", "max", "range"); |
||||
adapters.addMinMax("minlength", "minlength").addMinMax("maxlength", "minlength", "maxlength"); |
||||
adapters.add("equalto", ["other"], function (options) { |
||||
var prefix = getModelPrefix(options.element.name), |
||||
other = options.params.other, |
||||
fullOtherName = appendModelPrefix(other, prefix), |
||||
element = $(options.form).find(":input").filter("[name='" + escapeAttributeValue(fullOtherName) + "']")[0]; |
||||
|
||||
setValidationValues(options, "equalTo", element); |
||||
}); |
||||
adapters.add("required", function (options) { |
||||
// jQuery Validate equates "required" with "mandatory" for checkbox elements
|
||||
if (options.element.tagName.toUpperCase() !== "INPUT" || options.element.type.toUpperCase() !== "CHECKBOX") { |
||||
setValidationValues(options, "required", true); |
||||
} |
||||
}); |
||||
adapters.add("remote", ["url", "type", "additionalfields"], function (options) { |
||||
var value = { |
||||
url: options.params.url, |
||||
type: options.params.type || "GET", |
||||
data: {} |
||||
}, |
||||
prefix = getModelPrefix(options.element.name); |
||||
|
||||
$.each(splitAndTrim(options.params.additionalfields || options.element.name), function (i, fieldName) { |
||||
var paramName = appendModelPrefix(fieldName, prefix); |
||||
value.data[paramName] = function () { |
||||
var field = $(options.form).find(":input").filter("[name='" + escapeAttributeValue(paramName) + "']"); |
||||
// For checkboxes and radio buttons, only pick up values from checked fields.
|
||||
if (field.is(":checkbox")) { |
||||
return field.filter(":checked").val() || field.filter(":hidden").val() || ''; |
||||
} |
||||
else if (field.is(":radio")) { |
||||
return field.filter(":checked").val() || ''; |
||||
} |
||||
return field.val(); |
||||
}; |
||||
}); |
||||
|
||||
setValidationValues(options, "remote", value); |
||||
}); |
||||
adapters.add("password", ["min", "nonalphamin", "regex"], function (options) { |
||||
if (options.params.min) { |
||||
setValidationValues(options, "minlength", options.params.min); |
||||
} |
||||
if (options.params.nonalphamin) { |
||||
setValidationValues(options, "nonalphamin", options.params.nonalphamin); |
||||
} |
||||
if (options.params.regex) { |
||||
setValidationValues(options, "regex", options.params.regex); |
||||
} |
||||
}); |
||||
adapters.add("fileextensions", ["extensions"], function (options) { |
||||
setValidationValues(options, "extension", options.params.extensions); |
||||
}); |
||||
|
||||
$(function () { |
||||
$jQval.unobtrusive.parse(document); |
||||
}); |
||||
|
||||
return $jQval.unobtrusive; |
||||
})); |
File diff suppressed because one or more lines are too long
@ -0,0 +1,22 @@
@@ -0,0 +1,22 @@
|
||||
The MIT License (MIT) |
||||
===================== |
||||
|
||||
Copyright Jörn Zaefferer |
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy |
||||
of this software and associated documentation files (the "Software"), to deal |
||||
in the Software without restriction, including without limitation the rights |
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
||||
copies of the Software, and to permit persons to whom the Software is |
||||
furnished to do so, subject to the following conditions: |
||||
|
||||
The above copyright notice and this permission notice shall be included in |
||||
all copies or substantial portions of the Software. |
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
||||
THE SOFTWARE. |
@ -0,0 +1,36 @@
@@ -0,0 +1,36 @@
|
||||
Copyright JS Foundation and other contributors, https://js.foundation/ |
||||
|
||||
This software consists of voluntary contributions made by many |
||||
individuals. For exact contribution history, see the revision history |
||||
available at https://github.com/jquery/jquery |
||||
|
||||
The following license applies to all parts of this software except as |
||||
documented below: |
||||
|
||||
==== |
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining |
||||
a copy of this software and associated documentation files (the |
||||
"Software"), to deal in the Software without restriction, including |
||||
without limitation the rights to use, copy, modify, merge, publish, |
||||
distribute, sublicense, and/or sell copies of the Software, and to |
||||
permit persons to whom the Software is furnished to do so, subject to |
||||
the following conditions: |
||||
|
||||
The above copyright notice and this permission notice shall be |
||||
included in all copies or substantial portions of the Software. |
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
||||
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE |
||||
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION |
||||
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
||||
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
||||
|
||||
==== |
||||
|
||||
All files located in the node_modules and external directories are |
||||
externally maintained libraries used by this software which have their |
||||
own licenses; we recommend you read them, as their terms may differ from |
||||
the terms above. |
Loading…
Reference in new issue