mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-11-01 19:07:51 +00:00
CNIP Code
Code
This commit is contained in:
25
software/cnip/cnip.sln
Normal file
25
software/cnip/cnip.sln
Normal file
@@ -0,0 +1,25 @@
|
||||
|
||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||
# Visual Studio 15
|
||||
VisualStudioVersion = 15.0.27703.2035
|
||||
MinimumVisualStudioVersion = 10.0.40219.1
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "cnip", "cnip\cnip.csproj", "{2C887228-E646-4C6F-9F6F-371CC0FDFC1C}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
Release|Any CPU = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||
{2C887228-E646-4C6F-9F6F-371CC0FDFC1C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{2C887228-E646-4C6F-9F6F-371CC0FDFC1C}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{2C887228-E646-4C6F-9F6F-371CC0FDFC1C}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{2C887228-E646-4C6F-9F6F-371CC0FDFC1C}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
EndGlobalSection
|
||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||
SolutionGuid = {CD3DCDFD-DC8B-48AB-A7CC-6763A817A580}
|
||||
EndGlobalSection
|
||||
EndGlobal
|
||||
30
software/cnip/cnip/App_Start/BundleConfig.cs
Normal file
30
software/cnip/cnip/App_Start/BundleConfig.cs
Normal file
@@ -0,0 +1,30 @@
|
||||
using System.Web;
|
||||
using System.Web.Optimization;
|
||||
|
||||
namespace cnip
|
||||
{
|
||||
public class BundleConfig
|
||||
{
|
||||
// For more information on bundling, visit https://go.microsoft.com/fwlink/?LinkId=301862
|
||||
public static void RegisterBundles(BundleCollection bundles)
|
||||
{
|
||||
bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
|
||||
"~/Scripts/jquery-{version}.js"));
|
||||
|
||||
bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
|
||||
"~/Scripts/jquery.validate*"));
|
||||
|
||||
// Use the development version of Modernizr to develop with and learn from. Then, when you're
|
||||
// ready for production, use the build tool at https://modernizr.com to pick only the tests you need.
|
||||
bundles.Add(new ScriptBundle("~/bundles/modernizr").Include(
|
||||
"~/Scripts/modernizr-*"));
|
||||
|
||||
bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include(
|
||||
"~/Scripts/bootstrap.js"));
|
||||
|
||||
bundles.Add(new StyleBundle("~/Content/css").Include(
|
||||
"~/Content/bootstrap.css",
|
||||
"~/Content/site.css"));
|
||||
}
|
||||
}
|
||||
}
|
||||
13
software/cnip/cnip/App_Start/FilterConfig.cs
Normal file
13
software/cnip/cnip/App_Start/FilterConfig.cs
Normal file
@@ -0,0 +1,13 @@
|
||||
using System.Web;
|
||||
using System.Web.Mvc;
|
||||
|
||||
namespace cnip
|
||||
{
|
||||
public class FilterConfig
|
||||
{
|
||||
public static void RegisterGlobalFilters(GlobalFilterCollection filters)
|
||||
{
|
||||
filters.Add(new HandleErrorAttribute());
|
||||
}
|
||||
}
|
||||
}
|
||||
23
software/cnip/cnip/App_Start/RouteConfig.cs
Normal file
23
software/cnip/cnip/App_Start/RouteConfig.cs
Normal file
@@ -0,0 +1,23 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Web;
|
||||
using System.Web.Mvc;
|
||||
using System.Web.Routing;
|
||||
|
||||
namespace cnip
|
||||
{
|
||||
public class RouteConfig
|
||||
{
|
||||
public static void RegisterRoutes(RouteCollection routes)
|
||||
{
|
||||
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
|
||||
|
||||
routes.MapRoute(
|
||||
name: "Default",
|
||||
url: "{controller}/{action}/{id}",
|
||||
defaults: new { controller = "Glavni", action = "Index", id = UrlParameter.Optional }
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
106
software/cnip/cnip/ApplicationInsights.config
Normal file
106
software/cnip/cnip/ApplicationInsights.config
Normal file
@@ -0,0 +1,106 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<ApplicationInsights xmlns="http://schemas.microsoft.com/ApplicationInsights/2013/Settings">
|
||||
<TelemetryInitializers>
|
||||
<Add Type="Microsoft.ApplicationInsights.DependencyCollector.HttpDependenciesParsingTelemetryInitializer, Microsoft.AI.DependencyCollector"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.AzureRoleEnvironmentTelemetryInitializer, Microsoft.AI.WindowsServer"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.AzureWebAppRoleEnvironmentTelemetryInitializer, Microsoft.AI.WindowsServer"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.BuildInfoConfigComponentVersionTelemetryInitializer, Microsoft.AI.WindowsServer"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.WebTestTelemetryInitializer, Microsoft.AI.Web"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.SyntheticUserAgentTelemetryInitializer, Microsoft.AI.Web">
|
||||
<!-- Extended list of bots:
|
||||
search|spider|crawl|Bot|Monitor|BrowserMob|BingPreview|PagePeeker|WebThumb|URL2PNG|ZooShot|GomezA|Google SketchUp|Read Later|KTXN|KHTE|Keynote|Pingdom|AlwaysOn|zao|borg|oegp|silk|Xenu|zeal|NING|htdig|lycos|slurp|teoma|voila|yahoo|Sogou|CiBra|Nutch|Java|JNLP|Daumoa|Genieo|ichiro|larbin|pompos|Scrapy|snappy|speedy|vortex|favicon|indexer|Riddler|scooter|scraper|scrubby|WhatWeb|WinHTTP|voyager|archiver|Icarus6j|mogimogi|Netvibes|altavista|charlotte|findlinks|Retreiver|TLSProber|WordPress|wsr-agent|http client|Python-urllib|AppEngine-Google|semanticdiscovery|facebookexternalhit|web/snippet|Google-HTTP-Java-Client-->
|
||||
<Filters>search|spider|crawl|Bot|Monitor|AlwaysOn</Filters>
|
||||
</Add>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.ClientIpHeaderTelemetryInitializer, Microsoft.AI.Web"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.OperationNameTelemetryInitializer, Microsoft.AI.Web"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.OperationCorrelationTelemetryInitializer, Microsoft.AI.Web"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.UserTelemetryInitializer, Microsoft.AI.Web"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.AuthenticatedUserIdTelemetryInitializer, Microsoft.AI.Web"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.AccountIdTelemetryInitializer, Microsoft.AI.Web"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.SessionTelemetryInitializer, Microsoft.AI.Web"/>
|
||||
</TelemetryInitializers>
|
||||
<TelemetryModules>
|
||||
<Add Type="Microsoft.ApplicationInsights.DependencyCollector.DependencyTrackingTelemetryModule, Microsoft.AI.DependencyCollector">
|
||||
<ExcludeComponentCorrelationHttpHeadersOnDomains>
|
||||
<!--
|
||||
Requests to the following hostnames will not be modified by adding correlation headers.
|
||||
Add entries here to exclude additional hostnames.
|
||||
NOTE: this configuration will be lost upon NuGet upgrade.
|
||||
-->
|
||||
<Add>core.windows.net</Add>
|
||||
<Add>core.chinacloudapi.cn</Add>
|
||||
<Add>core.cloudapi.de</Add>
|
||||
<Add>core.usgovcloudapi.net</Add>
|
||||
<Add>localhost</Add>
|
||||
<Add>127.0.0.1</Add>
|
||||
</ExcludeComponentCorrelationHttpHeadersOnDomains>
|
||||
<IncludeDiagnosticSourceActivities>
|
||||
<Add>Microsoft.Azure.EventHubs</Add>
|
||||
<Add>Microsoft.Azure.ServiceBus</Add>
|
||||
</IncludeDiagnosticSourceActivities>
|
||||
</Add>
|
||||
<Add Type="Microsoft.ApplicationInsights.Extensibility.PerfCounterCollector.PerformanceCollectorModule, Microsoft.AI.PerfCounterCollector">
|
||||
<!--
|
||||
Use the following syntax here to collect additional performance counters:
|
||||
|
||||
<Counters>
|
||||
<Add PerformanceCounter="\Process(??APP_WIN32_PROC??)\Handle Count" ReportAs="Process handle count" />
|
||||
...
|
||||
</Counters>
|
||||
|
||||
PerformanceCounter must be either \CategoryName(InstanceName)\CounterName or \CategoryName\CounterName
|
||||
|
||||
NOTE: performance counters configuration will be lost upon NuGet upgrade.
|
||||
|
||||
The following placeholders are supported as InstanceName:
|
||||
??APP_WIN32_PROC?? - instance name of the application process for Win32 counters.
|
||||
??APP_W3SVC_PROC?? - instance name of the application IIS worker process for IIS/ASP.NET counters.
|
||||
??APP_CLR_PROC?? - instance name of the application CLR process for .NET counters.
|
||||
-->
|
||||
</Add>
|
||||
<Add Type="Microsoft.ApplicationInsights.Extensibility.PerfCounterCollector.QuickPulse.QuickPulseTelemetryModule, Microsoft.AI.PerfCounterCollector"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.DeveloperModeWithDebuggerAttachedTelemetryModule, Microsoft.AI.WindowsServer"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.UnhandledExceptionTelemetryModule, Microsoft.AI.WindowsServer"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.UnobservedExceptionTelemetryModule, Microsoft.AI.WindowsServer">
|
||||
<!--</Add>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.FirstChanceExceptionStatisticsTelemetryModule, Microsoft.AI.WindowsServer">-->
|
||||
</Add>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.RequestTrackingTelemetryModule, Microsoft.AI.Web">
|
||||
<Handlers>
|
||||
<!--
|
||||
Add entries here to filter out additional handlers:
|
||||
|
||||
NOTE: handler configuration will be lost upon NuGet upgrade.
|
||||
-->
|
||||
<Add>Microsoft.VisualStudio.Web.PageInspector.Runtime.Tracing.RequestDataHttpHandler</Add>
|
||||
<Add>System.Web.StaticFileHandler</Add>
|
||||
<Add>System.Web.Handlers.AssemblyResourceLoader</Add>
|
||||
<Add>System.Web.Optimization.BundleHandler</Add>
|
||||
<Add>System.Web.Script.Services.ScriptHandlerFactory</Add>
|
||||
<Add>System.Web.Handlers.TraceHandler</Add>
|
||||
<Add>System.Web.Services.Discovery.DiscoveryRequestHandler</Add>
|
||||
<Add>System.Web.HttpDebugHandler</Add>
|
||||
</Handlers>
|
||||
</Add>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.ExceptionTrackingTelemetryModule, Microsoft.AI.Web"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Web.AspNetDiagnosticTelemetryModule, Microsoft.AI.Web"/>
|
||||
</TelemetryModules>
|
||||
<TelemetryProcessors>
|
||||
<Add Type="Microsoft.ApplicationInsights.Extensibility.PerfCounterCollector.QuickPulse.QuickPulseTelemetryProcessor, Microsoft.AI.PerfCounterCollector"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.Extensibility.AutocollectedMetricsExtractor, Microsoft.ApplicationInsights"/>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.TelemetryChannel.AdaptiveSamplingTelemetryProcessor, Microsoft.AI.ServerTelemetryChannel">
|
||||
<MaxTelemetryItemsPerSecond>5</MaxTelemetryItemsPerSecond>
|
||||
<ExcludedTypes>Event</ExcludedTypes>
|
||||
</Add>
|
||||
<Add Type="Microsoft.ApplicationInsights.WindowsServer.TelemetryChannel.AdaptiveSamplingTelemetryProcessor, Microsoft.AI.ServerTelemetryChannel">
|
||||
<MaxTelemetryItemsPerSecond>5</MaxTelemetryItemsPerSecond>
|
||||
<IncludedTypes>Event</IncludedTypes>
|
||||
</Add>
|
||||
</TelemetryProcessors>
|
||||
<TelemetryChannel Type="Microsoft.ApplicationInsights.WindowsServer.TelemetryChannel.ServerTelemetryChannel, Microsoft.AI.ServerTelemetryChannel"/>
|
||||
<!--
|
||||
Learn more about Application Insights configuration with ApplicationInsights.config here:
|
||||
http://go.microsoft.com/fwlink/?LinkID=513840
|
||||
|
||||
Note: If not present, please add <InstrumentationKey>Your Key</InstrumentationKey> to the top of this file.
|
||||
--></ApplicationInsights>
|
||||
4463
software/cnip/cnip/Content/all.css
Normal file
4463
software/cnip/cnip/Content/all.css
Normal file
File diff suppressed because it is too large
Load Diff
5
software/cnip/cnip/Content/all.min.css
vendored
Normal file
5
software/cnip/cnip/Content/all.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
587
software/cnip/cnip/Content/bootstrap-theme.css
vendored
Normal file
587
software/cnip/cnip/Content/bootstrap-theme.css
vendored
Normal file
@@ -0,0 +1,587 @@
|
||||
/*!
|
||||
* Bootstrap v3.3.7 (http://getbootstrap.com)
|
||||
* Copyright 2011-2016 Twitter, Inc.
|
||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||
*/
|
||||
.btn-default,
|
||||
.btn-primary,
|
||||
.btn-success,
|
||||
.btn-info,
|
||||
.btn-warning,
|
||||
.btn-danger {
|
||||
text-shadow: 0 -1px 0 rgba(0, 0, 0, .2);
|
||||
-webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .15), 0 1px 1px rgba(0, 0, 0, .075);
|
||||
box-shadow: inset 0 1px 0 rgba(255, 255, 255, .15), 0 1px 1px rgba(0, 0, 0, .075);
|
||||
}
|
||||
.btn-default:active,
|
||||
.btn-primary:active,
|
||||
.btn-success:active,
|
||||
.btn-info:active,
|
||||
.btn-warning:active,
|
||||
.btn-danger:active,
|
||||
.btn-default.active,
|
||||
.btn-primary.active,
|
||||
.btn-success.active,
|
||||
.btn-info.active,
|
||||
.btn-warning.active,
|
||||
.btn-danger.active {
|
||||
-webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
|
||||
box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
|
||||
}
|
||||
.btn-default.disabled,
|
||||
.btn-primary.disabled,
|
||||
.btn-success.disabled,
|
||||
.btn-info.disabled,
|
||||
.btn-warning.disabled,
|
||||
.btn-danger.disabled,
|
||||
.btn-default[disabled],
|
||||
.btn-primary[disabled],
|
||||
.btn-success[disabled],
|
||||
.btn-info[disabled],
|
||||
.btn-warning[disabled],
|
||||
.btn-danger[disabled],
|
||||
fieldset[disabled] .btn-default,
|
||||
fieldset[disabled] .btn-primary,
|
||||
fieldset[disabled] .btn-success,
|
||||
fieldset[disabled] .btn-info,
|
||||
fieldset[disabled] .btn-warning,
|
||||
fieldset[disabled] .btn-danger {
|
||||
-webkit-box-shadow: none;
|
||||
box-shadow: none;
|
||||
}
|
||||
.btn-default .badge,
|
||||
.btn-primary .badge,
|
||||
.btn-success .badge,
|
||||
.btn-info .badge,
|
||||
.btn-warning .badge,
|
||||
.btn-danger .badge {
|
||||
text-shadow: none;
|
||||
}
|
||||
.btn:active,
|
||||
.btn.active {
|
||||
background-image: none;
|
||||
}
|
||||
.btn-default {
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
background-image: -webkit-linear-gradient(top, #fff 0%, #e0e0e0 100%);
|
||||
background-image: -o-linear-gradient(top, #fff 0%, #e0e0e0 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#e0e0e0));
|
||||
background-image: linear-gradient(to bottom, #fff 0%, #e0e0e0 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#ffe0e0e0', GradientType=0);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #dbdbdb;
|
||||
border-color: #ccc;
|
||||
}
|
||||
.btn-default:hover,
|
||||
.btn-default:focus {
|
||||
background-color: #e0e0e0;
|
||||
background-position: 0 -15px;
|
||||
}
|
||||
.btn-default:active,
|
||||
.btn-default.active {
|
||||
background-color: #e0e0e0;
|
||||
border-color: #dbdbdb;
|
||||
}
|
||||
.btn-default.disabled,
|
||||
.btn-default[disabled],
|
||||
fieldset[disabled] .btn-default,
|
||||
.btn-default.disabled:hover,
|
||||
.btn-default[disabled]:hover,
|
||||
fieldset[disabled] .btn-default:hover,
|
||||
.btn-default.disabled:focus,
|
||||
.btn-default[disabled]:focus,
|
||||
fieldset[disabled] .btn-default:focus,
|
||||
.btn-default.disabled.focus,
|
||||
.btn-default[disabled].focus,
|
||||
fieldset[disabled] .btn-default.focus,
|
||||
.btn-default.disabled:active,
|
||||
.btn-default[disabled]:active,
|
||||
fieldset[disabled] .btn-default:active,
|
||||
.btn-default.disabled.active,
|
||||
.btn-default[disabled].active,
|
||||
fieldset[disabled] .btn-default.active {
|
||||
background-color: #e0e0e0;
|
||||
background-image: none;
|
||||
}
|
||||
.btn-primary {
|
||||
background-image: -webkit-linear-gradient(top, #337ab7 0%, #265a88 100%);
|
||||
background-image: -o-linear-gradient(top, #337ab7 0%, #265a88 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#337ab7), to(#265a88));
|
||||
background-image: linear-gradient(to bottom, #337ab7 0%, #265a88 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff337ab7', endColorstr='#ff265a88', GradientType=0);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #245580;
|
||||
}
|
||||
.btn-primary:hover,
|
||||
.btn-primary:focus {
|
||||
background-color: #265a88;
|
||||
background-position: 0 -15px;
|
||||
}
|
||||
.btn-primary:active,
|
||||
.btn-primary.active {
|
||||
background-color: #265a88;
|
||||
border-color: #245580;
|
||||
}
|
||||
.btn-primary.disabled,
|
||||
.btn-primary[disabled],
|
||||
fieldset[disabled] .btn-primary,
|
||||
.btn-primary.disabled:hover,
|
||||
.btn-primary[disabled]:hover,
|
||||
fieldset[disabled] .btn-primary:hover,
|
||||
.btn-primary.disabled:focus,
|
||||
.btn-primary[disabled]:focus,
|
||||
fieldset[disabled] .btn-primary:focus,
|
||||
.btn-primary.disabled.focus,
|
||||
.btn-primary[disabled].focus,
|
||||
fieldset[disabled] .btn-primary.focus,
|
||||
.btn-primary.disabled:active,
|
||||
.btn-primary[disabled]:active,
|
||||
fieldset[disabled] .btn-primary:active,
|
||||
.btn-primary.disabled.active,
|
||||
.btn-primary[disabled].active,
|
||||
fieldset[disabled] .btn-primary.active {
|
||||
background-color: #265a88;
|
||||
background-image: none;
|
||||
}
|
||||
.btn-success {
|
||||
background-image: -webkit-linear-gradient(top, #5cb85c 0%, #419641 100%);
|
||||
background-image: -o-linear-gradient(top, #5cb85c 0%, #419641 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#5cb85c), to(#419641));
|
||||
background-image: linear-gradient(to bottom, #5cb85c 0%, #419641 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5cb85c', endColorstr='#ff419641', GradientType=0);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #3e8f3e;
|
||||
}
|
||||
.btn-success:hover,
|
||||
.btn-success:focus {
|
||||
background-color: #419641;
|
||||
background-position: 0 -15px;
|
||||
}
|
||||
.btn-success:active,
|
||||
.btn-success.active {
|
||||
background-color: #419641;
|
||||
border-color: #3e8f3e;
|
||||
}
|
||||
.btn-success.disabled,
|
||||
.btn-success[disabled],
|
||||
fieldset[disabled] .btn-success,
|
||||
.btn-success.disabled:hover,
|
||||
.btn-success[disabled]:hover,
|
||||
fieldset[disabled] .btn-success:hover,
|
||||
.btn-success.disabled:focus,
|
||||
.btn-success[disabled]:focus,
|
||||
fieldset[disabled] .btn-success:focus,
|
||||
.btn-success.disabled.focus,
|
||||
.btn-success[disabled].focus,
|
||||
fieldset[disabled] .btn-success.focus,
|
||||
.btn-success.disabled:active,
|
||||
.btn-success[disabled]:active,
|
||||
fieldset[disabled] .btn-success:active,
|
||||
.btn-success.disabled.active,
|
||||
.btn-success[disabled].active,
|
||||
fieldset[disabled] .btn-success.active {
|
||||
background-color: #419641;
|
||||
background-image: none;
|
||||
}
|
||||
.btn-info {
|
||||
background-image: -webkit-linear-gradient(top, #5bc0de 0%, #2aabd2 100%);
|
||||
background-image: -o-linear-gradient(top, #5bc0de 0%, #2aabd2 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#5bc0de), to(#2aabd2));
|
||||
background-image: linear-gradient(to bottom, #5bc0de 0%, #2aabd2 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5bc0de', endColorstr='#ff2aabd2', GradientType=0);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #28a4c9;
|
||||
}
|
||||
.btn-info:hover,
|
||||
.btn-info:focus {
|
||||
background-color: #2aabd2;
|
||||
background-position: 0 -15px;
|
||||
}
|
||||
.btn-info:active,
|
||||
.btn-info.active {
|
||||
background-color: #2aabd2;
|
||||
border-color: #28a4c9;
|
||||
}
|
||||
.btn-info.disabled,
|
||||
.btn-info[disabled],
|
||||
fieldset[disabled] .btn-info,
|
||||
.btn-info.disabled:hover,
|
||||
.btn-info[disabled]:hover,
|
||||
fieldset[disabled] .btn-info:hover,
|
||||
.btn-info.disabled:focus,
|
||||
.btn-info[disabled]:focus,
|
||||
fieldset[disabled] .btn-info:focus,
|
||||
.btn-info.disabled.focus,
|
||||
.btn-info[disabled].focus,
|
||||
fieldset[disabled] .btn-info.focus,
|
||||
.btn-info.disabled:active,
|
||||
.btn-info[disabled]:active,
|
||||
fieldset[disabled] .btn-info:active,
|
||||
.btn-info.disabled.active,
|
||||
.btn-info[disabled].active,
|
||||
fieldset[disabled] .btn-info.active {
|
||||
background-color: #2aabd2;
|
||||
background-image: none;
|
||||
}
|
||||
.btn-warning {
|
||||
background-image: -webkit-linear-gradient(top, #f0ad4e 0%, #eb9316 100%);
|
||||
background-image: -o-linear-gradient(top, #f0ad4e 0%, #eb9316 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#f0ad4e), to(#eb9316));
|
||||
background-image: linear-gradient(to bottom, #f0ad4e 0%, #eb9316 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff0ad4e', endColorstr='#ffeb9316', GradientType=0);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #e38d13;
|
||||
}
|
||||
.btn-warning:hover,
|
||||
.btn-warning:focus {
|
||||
background-color: #eb9316;
|
||||
background-position: 0 -15px;
|
||||
}
|
||||
.btn-warning:active,
|
||||
.btn-warning.active {
|
||||
background-color: #eb9316;
|
||||
border-color: #e38d13;
|
||||
}
|
||||
.btn-warning.disabled,
|
||||
.btn-warning[disabled],
|
||||
fieldset[disabled] .btn-warning,
|
||||
.btn-warning.disabled:hover,
|
||||
.btn-warning[disabled]:hover,
|
||||
fieldset[disabled] .btn-warning:hover,
|
||||
.btn-warning.disabled:focus,
|
||||
.btn-warning[disabled]:focus,
|
||||
fieldset[disabled] .btn-warning:focus,
|
||||
.btn-warning.disabled.focus,
|
||||
.btn-warning[disabled].focus,
|
||||
fieldset[disabled] .btn-warning.focus,
|
||||
.btn-warning.disabled:active,
|
||||
.btn-warning[disabled]:active,
|
||||
fieldset[disabled] .btn-warning:active,
|
||||
.btn-warning.disabled.active,
|
||||
.btn-warning[disabled].active,
|
||||
fieldset[disabled] .btn-warning.active {
|
||||
background-color: #eb9316;
|
||||
background-image: none;
|
||||
}
|
||||
.btn-danger {
|
||||
background-image: -webkit-linear-gradient(top, #d9534f 0%, #c12e2a 100%);
|
||||
background-image: -o-linear-gradient(top, #d9534f 0%, #c12e2a 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#d9534f), to(#c12e2a));
|
||||
background-image: linear-gradient(to bottom, #d9534f 0%, #c12e2a 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9534f', endColorstr='#ffc12e2a', GradientType=0);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #b92c28;
|
||||
}
|
||||
.btn-danger:hover,
|
||||
.btn-danger:focus {
|
||||
background-color: #c12e2a;
|
||||
background-position: 0 -15px;
|
||||
}
|
||||
.btn-danger:active,
|
||||
.btn-danger.active {
|
||||
background-color: #c12e2a;
|
||||
border-color: #b92c28;
|
||||
}
|
||||
.btn-danger.disabled,
|
||||
.btn-danger[disabled],
|
||||
fieldset[disabled] .btn-danger,
|
||||
.btn-danger.disabled:hover,
|
||||
.btn-danger[disabled]:hover,
|
||||
fieldset[disabled] .btn-danger:hover,
|
||||
.btn-danger.disabled:focus,
|
||||
.btn-danger[disabled]:focus,
|
||||
fieldset[disabled] .btn-danger:focus,
|
||||
.btn-danger.disabled.focus,
|
||||
.btn-danger[disabled].focus,
|
||||
fieldset[disabled] .btn-danger.focus,
|
||||
.btn-danger.disabled:active,
|
||||
.btn-danger[disabled]:active,
|
||||
fieldset[disabled] .btn-danger:active,
|
||||
.btn-danger.disabled.active,
|
||||
.btn-danger[disabled].active,
|
||||
fieldset[disabled] .btn-danger.active {
|
||||
background-color: #c12e2a;
|
||||
background-image: none;
|
||||
}
|
||||
.thumbnail,
|
||||
.img-thumbnail {
|
||||
-webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, .075);
|
||||
box-shadow: 0 1px 2px rgba(0, 0, 0, .075);
|
||||
}
|
||||
.dropdown-menu > li > a:hover,
|
||||
.dropdown-menu > li > a:focus {
|
||||
background-color: #e8e8e8;
|
||||
background-image: -webkit-linear-gradient(top, #f5f5f5 0%, #e8e8e8 100%);
|
||||
background-image: -o-linear-gradient(top, #f5f5f5 0%, #e8e8e8 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#f5f5f5), to(#e8e8e8));
|
||||
background-image: linear-gradient(to bottom, #f5f5f5 0%, #e8e8e8 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff5f5f5', endColorstr='#ffe8e8e8', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.dropdown-menu > .active > a,
|
||||
.dropdown-menu > .active > a:hover,
|
||||
.dropdown-menu > .active > a:focus {
|
||||
background-color: #2e6da4;
|
||||
background-image: -webkit-linear-gradient(top, #337ab7 0%, #2e6da4 100%);
|
||||
background-image: -o-linear-gradient(top, #337ab7 0%, #2e6da4 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#337ab7), to(#2e6da4));
|
||||
background-image: linear-gradient(to bottom, #337ab7 0%, #2e6da4 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff337ab7', endColorstr='#ff2e6da4', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.navbar-default {
|
||||
background-image: -webkit-linear-gradient(top, #fff 0%, #f8f8f8 100%);
|
||||
background-image: -o-linear-gradient(top, #fff 0%, #f8f8f8 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#f8f8f8));
|
||||
background-image: linear-gradient(to bottom, #fff 0%, #f8f8f8 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#fff8f8f8', GradientType=0);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
|
||||
background-repeat: repeat-x;
|
||||
border-radius: 4px;
|
||||
-webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .15), 0 1px 5px rgba(0, 0, 0, .075);
|
||||
box-shadow: inset 0 1px 0 rgba(255, 255, 255, .15), 0 1px 5px rgba(0, 0, 0, .075);
|
||||
}
|
||||
.navbar-default .navbar-nav > .open > a,
|
||||
.navbar-default .navbar-nav > .active > a {
|
||||
background-image: -webkit-linear-gradient(top, #dbdbdb 0%, #e2e2e2 100%);
|
||||
background-image: -o-linear-gradient(top, #dbdbdb 0%, #e2e2e2 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#dbdbdb), to(#e2e2e2));
|
||||
background-image: linear-gradient(to bottom, #dbdbdb 0%, #e2e2e2 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffdbdbdb', endColorstr='#ffe2e2e2', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
-webkit-box-shadow: inset 0 3px 9px rgba(0, 0, 0, .075);
|
||||
box-shadow: inset 0 3px 9px rgba(0, 0, 0, .075);
|
||||
}
|
||||
.navbar-brand,
|
||||
.navbar-nav > li > a {
|
||||
text-shadow: 0 1px 0 rgba(255, 255, 255, .25);
|
||||
}
|
||||
.navbar-inverse {
|
||||
background-image: -webkit-linear-gradient(top, #3c3c3c 0%, #222 100%);
|
||||
background-image: -o-linear-gradient(top, #3c3c3c 0%, #222 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#3c3c3c), to(#222));
|
||||
background-image: linear-gradient(to bottom, #3c3c3c 0%, #222 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff3c3c3c', endColorstr='#ff222222', GradientType=0);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
|
||||
background-repeat: repeat-x;
|
||||
border-radius: 4px;
|
||||
}
|
||||
.navbar-inverse .navbar-nav > .open > a,
|
||||
.navbar-inverse .navbar-nav > .active > a {
|
||||
background-image: -webkit-linear-gradient(top, #080808 0%, #0f0f0f 100%);
|
||||
background-image: -o-linear-gradient(top, #080808 0%, #0f0f0f 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#080808), to(#0f0f0f));
|
||||
background-image: linear-gradient(to bottom, #080808 0%, #0f0f0f 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff080808', endColorstr='#ff0f0f0f', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
-webkit-box-shadow: inset 0 3px 9px rgba(0, 0, 0, .25);
|
||||
box-shadow: inset 0 3px 9px rgba(0, 0, 0, .25);
|
||||
}
|
||||
.navbar-inverse .navbar-brand,
|
||||
.navbar-inverse .navbar-nav > li > a {
|
||||
text-shadow: 0 -1px 0 rgba(0, 0, 0, .25);
|
||||
}
|
||||
.navbar-static-top,
|
||||
.navbar-fixed-top,
|
||||
.navbar-fixed-bottom {
|
||||
border-radius: 0;
|
||||
}
|
||||
@media (max-width: 767px) {
|
||||
.navbar .navbar-nav .open .dropdown-menu > .active > a,
|
||||
.navbar .navbar-nav .open .dropdown-menu > .active > a:hover,
|
||||
.navbar .navbar-nav .open .dropdown-menu > .active > a:focus {
|
||||
color: #fff;
|
||||
background-image: -webkit-linear-gradient(top, #337ab7 0%, #2e6da4 100%);
|
||||
background-image: -o-linear-gradient(top, #337ab7 0%, #2e6da4 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#337ab7), to(#2e6da4));
|
||||
background-image: linear-gradient(to bottom, #337ab7 0%, #2e6da4 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff337ab7', endColorstr='#ff2e6da4', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
}
|
||||
.alert {
|
||||
text-shadow: 0 1px 0 rgba(255, 255, 255, .2);
|
||||
-webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .25), 0 1px 2px rgba(0, 0, 0, .05);
|
||||
box-shadow: inset 0 1px 0 rgba(255, 255, 255, .25), 0 1px 2px rgba(0, 0, 0, .05);
|
||||
}
|
||||
.alert-success {
|
||||
background-image: -webkit-linear-gradient(top, #dff0d8 0%, #c8e5bc 100%);
|
||||
background-image: -o-linear-gradient(top, #dff0d8 0%, #c8e5bc 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#dff0d8), to(#c8e5bc));
|
||||
background-image: linear-gradient(to bottom, #dff0d8 0%, #c8e5bc 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffdff0d8', endColorstr='#ffc8e5bc', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #b2dba1;
|
||||
}
|
||||
.alert-info {
|
||||
background-image: -webkit-linear-gradient(top, #d9edf7 0%, #b9def0 100%);
|
||||
background-image: -o-linear-gradient(top, #d9edf7 0%, #b9def0 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#d9edf7), to(#b9def0));
|
||||
background-image: linear-gradient(to bottom, #d9edf7 0%, #b9def0 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9edf7', endColorstr='#ffb9def0', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #9acfea;
|
||||
}
|
||||
.alert-warning {
|
||||
background-image: -webkit-linear-gradient(top, #fcf8e3 0%, #f8efc0 100%);
|
||||
background-image: -o-linear-gradient(top, #fcf8e3 0%, #f8efc0 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#fcf8e3), to(#f8efc0));
|
||||
background-image: linear-gradient(to bottom, #fcf8e3 0%, #f8efc0 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffcf8e3', endColorstr='#fff8efc0', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #f5e79e;
|
||||
}
|
||||
.alert-danger {
|
||||
background-image: -webkit-linear-gradient(top, #f2dede 0%, #e7c3c3 100%);
|
||||
background-image: -o-linear-gradient(top, #f2dede 0%, #e7c3c3 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#f2dede), to(#e7c3c3));
|
||||
background-image: linear-gradient(to bottom, #f2dede 0%, #e7c3c3 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2dede', endColorstr='#ffe7c3c3', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #dca7a7;
|
||||
}
|
||||
.progress {
|
||||
background-image: -webkit-linear-gradient(top, #ebebeb 0%, #f5f5f5 100%);
|
||||
background-image: -o-linear-gradient(top, #ebebeb 0%, #f5f5f5 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#ebebeb), to(#f5f5f5));
|
||||
background-image: linear-gradient(to bottom, #ebebeb 0%, #f5f5f5 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffebebeb', endColorstr='#fff5f5f5', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.progress-bar {
|
||||
background-image: -webkit-linear-gradient(top, #337ab7 0%, #286090 100%);
|
||||
background-image: -o-linear-gradient(top, #337ab7 0%, #286090 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#337ab7), to(#286090));
|
||||
background-image: linear-gradient(to bottom, #337ab7 0%, #286090 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff337ab7', endColorstr='#ff286090', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.progress-bar-success {
|
||||
background-image: -webkit-linear-gradient(top, #5cb85c 0%, #449d44 100%);
|
||||
background-image: -o-linear-gradient(top, #5cb85c 0%, #449d44 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#5cb85c), to(#449d44));
|
||||
background-image: linear-gradient(to bottom, #5cb85c 0%, #449d44 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5cb85c', endColorstr='#ff449d44', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.progress-bar-info {
|
||||
background-image: -webkit-linear-gradient(top, #5bc0de 0%, #31b0d5 100%);
|
||||
background-image: -o-linear-gradient(top, #5bc0de 0%, #31b0d5 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#5bc0de), to(#31b0d5));
|
||||
background-image: linear-gradient(to bottom, #5bc0de 0%, #31b0d5 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5bc0de', endColorstr='#ff31b0d5', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.progress-bar-warning {
|
||||
background-image: -webkit-linear-gradient(top, #f0ad4e 0%, #ec971f 100%);
|
||||
background-image: -o-linear-gradient(top, #f0ad4e 0%, #ec971f 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#f0ad4e), to(#ec971f));
|
||||
background-image: linear-gradient(to bottom, #f0ad4e 0%, #ec971f 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff0ad4e', endColorstr='#ffec971f', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.progress-bar-danger {
|
||||
background-image: -webkit-linear-gradient(top, #d9534f 0%, #c9302c 100%);
|
||||
background-image: -o-linear-gradient(top, #d9534f 0%, #c9302c 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#d9534f), to(#c9302c));
|
||||
background-image: linear-gradient(to bottom, #d9534f 0%, #c9302c 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9534f', endColorstr='#ffc9302c', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.progress-bar-striped {
|
||||
background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
|
||||
background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
|
||||
background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
|
||||
}
|
||||
.list-group {
|
||||
border-radius: 4px;
|
||||
-webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, .075);
|
||||
box-shadow: 0 1px 2px rgba(0, 0, 0, .075);
|
||||
}
|
||||
.list-group-item.active,
|
||||
.list-group-item.active:hover,
|
||||
.list-group-item.active:focus {
|
||||
text-shadow: 0 -1px 0 #286090;
|
||||
background-image: -webkit-linear-gradient(top, #337ab7 0%, #2b669a 100%);
|
||||
background-image: -o-linear-gradient(top, #337ab7 0%, #2b669a 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#337ab7), to(#2b669a));
|
||||
background-image: linear-gradient(to bottom, #337ab7 0%, #2b669a 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff337ab7', endColorstr='#ff2b669a', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #2b669a;
|
||||
}
|
||||
.list-group-item.active .badge,
|
||||
.list-group-item.active:hover .badge,
|
||||
.list-group-item.active:focus .badge {
|
||||
text-shadow: none;
|
||||
}
|
||||
.panel {
|
||||
-webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, .05);
|
||||
box-shadow: 0 1px 2px rgba(0, 0, 0, .05);
|
||||
}
|
||||
.panel-default > .panel-heading {
|
||||
background-image: -webkit-linear-gradient(top, #f5f5f5 0%, #e8e8e8 100%);
|
||||
background-image: -o-linear-gradient(top, #f5f5f5 0%, #e8e8e8 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#f5f5f5), to(#e8e8e8));
|
||||
background-image: linear-gradient(to bottom, #f5f5f5 0%, #e8e8e8 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff5f5f5', endColorstr='#ffe8e8e8', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.panel-primary > .panel-heading {
|
||||
background-image: -webkit-linear-gradient(top, #337ab7 0%, #2e6da4 100%);
|
||||
background-image: -o-linear-gradient(top, #337ab7 0%, #2e6da4 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#337ab7), to(#2e6da4));
|
||||
background-image: linear-gradient(to bottom, #337ab7 0%, #2e6da4 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff337ab7', endColorstr='#ff2e6da4', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.panel-success > .panel-heading {
|
||||
background-image: -webkit-linear-gradient(top, #dff0d8 0%, #d0e9c6 100%);
|
||||
background-image: -o-linear-gradient(top, #dff0d8 0%, #d0e9c6 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#dff0d8), to(#d0e9c6));
|
||||
background-image: linear-gradient(to bottom, #dff0d8 0%, #d0e9c6 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffdff0d8', endColorstr='#ffd0e9c6', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.panel-info > .panel-heading {
|
||||
background-image: -webkit-linear-gradient(top, #d9edf7 0%, #c4e3f3 100%);
|
||||
background-image: -o-linear-gradient(top, #d9edf7 0%, #c4e3f3 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#d9edf7), to(#c4e3f3));
|
||||
background-image: linear-gradient(to bottom, #d9edf7 0%, #c4e3f3 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9edf7', endColorstr='#ffc4e3f3', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.panel-warning > .panel-heading {
|
||||
background-image: -webkit-linear-gradient(top, #fcf8e3 0%, #faf2cc 100%);
|
||||
background-image: -o-linear-gradient(top, #fcf8e3 0%, #faf2cc 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#fcf8e3), to(#faf2cc));
|
||||
background-image: linear-gradient(to bottom, #fcf8e3 0%, #faf2cc 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffcf8e3', endColorstr='#fffaf2cc', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.panel-danger > .panel-heading {
|
||||
background-image: -webkit-linear-gradient(top, #f2dede 0%, #ebcccc 100%);
|
||||
background-image: -o-linear-gradient(top, #f2dede 0%, #ebcccc 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#f2dede), to(#ebcccc));
|
||||
background-image: linear-gradient(to bottom, #f2dede 0%, #ebcccc 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2dede', endColorstr='#ffebcccc', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
}
|
||||
.well {
|
||||
background-image: -webkit-linear-gradient(top, #e8e8e8 0%, #f5f5f5 100%);
|
||||
background-image: -o-linear-gradient(top, #e8e8e8 0%, #f5f5f5 100%);
|
||||
background-image: -webkit-gradient(linear, left top, left bottom, from(#e8e8e8), to(#f5f5f5));
|
||||
background-image: linear-gradient(to bottom, #e8e8e8 0%, #f5f5f5 100%);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffe8e8e8', endColorstr='#fff5f5f5', GradientType=0);
|
||||
background-repeat: repeat-x;
|
||||
border-color: #dcdcdc;
|
||||
-webkit-box-shadow: inset 0 1px 3px rgba(0, 0, 0, .05), 0 1px 0 rgba(255, 255, 255, .1);
|
||||
box-shadow: inset 0 1px 3px rgba(0, 0, 0, .05), 0 1px 0 rgba(255, 255, 255, .1);
|
||||
}
|
||||
/*# sourceMappingURL=bootstrap-theme.css.map */
|
||||
1
software/cnip/cnip/Content/bootstrap-theme.css.map
Normal file
1
software/cnip/cnip/Content/bootstrap-theme.css.map
Normal file
File diff suppressed because one or more lines are too long
6
software/cnip/cnip/Content/bootstrap-theme.min.css
vendored
Normal file
6
software/cnip/cnip/Content/bootstrap-theme.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
1
software/cnip/cnip/Content/bootstrap-theme.min.css.map
Normal file
1
software/cnip/cnip/Content/bootstrap-theme.min.css.map
Normal file
File diff suppressed because one or more lines are too long
6757
software/cnip/cnip/Content/bootstrap.css
vendored
Normal file
6757
software/cnip/cnip/Content/bootstrap.css
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1
software/cnip/cnip/Content/bootstrap.css.map
Normal file
1
software/cnip/cnip/Content/bootstrap.css.map
Normal file
File diff suppressed because one or more lines are too long
6
software/cnip/cnip/Content/bootstrap.min.css
vendored
Normal file
6
software/cnip/cnip/Content/bootstrap.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
1
software/cnip/cnip/Content/bootstrap.min.css.map
Normal file
1
software/cnip/cnip/Content/bootstrap.min.css.map
Normal file
File diff suppressed because one or more lines are too long
95
software/cnip/cnip/Content/cnip/acc.css
Normal file
95
software/cnip/cnip/Content/cnip/acc.css
Normal file
@@ -0,0 +1,95 @@
|
||||
@import "root.css";
|
||||
|
||||
html, body {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
height: 100%;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
* {
|
||||
font-family: "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif;
|
||||
font-weight: lighter;
|
||||
}
|
||||
|
||||
.navbar {
|
||||
border: none;
|
||||
background: none;
|
||||
}
|
||||
|
||||
.navbar-header {
|
||||
background: none;
|
||||
}
|
||||
|
||||
.navbar-nav {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.navbar-right {
|
||||
margin-right: 0;
|
||||
}
|
||||
|
||||
#userGuide {
|
||||
background-color: transparent;
|
||||
border: none;
|
||||
color: var(--fontcolor);
|
||||
left: -7px;
|
||||
width: 120px;
|
||||
}
|
||||
|
||||
.container {
|
||||
height: 100%;
|
||||
align-content: center;
|
||||
}
|
||||
|
||||
.card {
|
||||
height: 440px;
|
||||
margin-top: -75px;
|
||||
margin-bottom: auto;
|
||||
width: 400px;
|
||||
border-color: var(--bordercolor) !important;
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.card-header {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.card-footer {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
border-top: none;
|
||||
}
|
||||
|
||||
.input-group-prepend span {
|
||||
width: 50px;
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
border: 0 !important;
|
||||
}
|
||||
|
||||
input:focus {
|
||||
outline: 0 0 0 0 !important;
|
||||
box-shadow: 0 0 0 0 !important;
|
||||
}
|
||||
|
||||
.login_btn {
|
||||
background-color: rgba(30,144,255,1);
|
||||
color: var(--backcolor);
|
||||
width: 100px;
|
||||
}
|
||||
|
||||
.login_btn:hover {
|
||||
color: var(--backcolor);
|
||||
background-color: rgba(30,144,255,0.7);
|
||||
}
|
||||
|
||||
.links {
|
||||
color: var(--backcolor);
|
||||
}
|
||||
|
||||
.links a {
|
||||
margin-left: 4px;
|
||||
}
|
||||
542
software/cnip/cnip/Content/cnip/cnip.css
Normal file
542
software/cnip/cnip/Content/cnip/cnip.css
Normal file
@@ -0,0 +1,542 @@
|
||||
@import "root.css";
|
||||
@import "../../Scripts/nouislider.min.css";
|
||||
|
||||
* {
|
||||
box-sizing: border-box;
|
||||
font-weight: lighter;
|
||||
font-family: "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif;
|
||||
}
|
||||
|
||||
/* single slider client user control */
|
||||
.noUi-horizontal {
|
||||
height: 4px;
|
||||
}
|
||||
|
||||
.noUi-target {
|
||||
border: none;
|
||||
border-radius: 0;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
.noUi-connects {
|
||||
background-color: var(--bordercolor);
|
||||
}
|
||||
|
||||
.noUi-connect {
|
||||
background-color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.noUi-handle {
|
||||
height: 12px !important;
|
||||
width: 12px !important;
|
||||
top: -4px !important;
|
||||
left: 50% !important;
|
||||
background-color: var(--fontcolor);
|
||||
border: none;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
.noUi-handle:hover {
|
||||
background-color: var(--hovercolor);
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.noUi-handle:after, .noUi-handle:before {
|
||||
height: 0;
|
||||
width: 0;
|
||||
}
|
||||
|
||||
.noUi-handle.noUi-handle-lower, .noUi-handle.noUi-handle-upper {
|
||||
margin-left: 7px !important;
|
||||
outline: none;
|
||||
border: none;
|
||||
}
|
||||
|
||||
.noUi-pips-horizontal {
|
||||
top: -5px !important;
|
||||
height: 30px !important;
|
||||
}
|
||||
|
||||
.noUi-marker.noUi-marker-horizontal.noUi-marker-normal {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.noUi-marker.noUi-marker-horizontal.noUi-marker-large {
|
||||
height: 5px;
|
||||
width: 1px;
|
||||
}
|
||||
|
||||
.noUi-value.noUi-value-horizontal.noUi-value-large {
|
||||
font-weight: lighter;
|
||||
font-size: xx-small;
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
/*customized checkbox styling*/
|
||||
[type="checkbox"]:not(:checked),
|
||||
[type="checkbox"]:checked {
|
||||
position: absolute;
|
||||
left: -9999px;
|
||||
}
|
||||
|
||||
[type="checkbox"]:not(:checked) + label,
|
||||
[type="checkbox"]:checked + label {
|
||||
position: relative;
|
||||
padding-left: 1.95em;
|
||||
cursor: pointer;
|
||||
font-weight: lighter;
|
||||
}
|
||||
|
||||
/* checkbox aspect */
|
||||
[type="checkbox"]:not(:checked) + label:before,
|
||||
[type="checkbox"]:checked + label:before {
|
||||
content: '';
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
width: 1.25em;
|
||||
height: 1.25em;
|
||||
border: 2px solid var(--bordercolor);
|
||||
background-color: var(--facecolor);
|
||||
border-radius: 1px;
|
||||
/*box-shadow: inset 0 1px 3px rgba(0,0,0,.1);*/
|
||||
}
|
||||
/* checked mark aspect */
|
||||
[type="checkbox"]:not(:checked) + label:after,
|
||||
[type="checkbox"]:checked + label:after {
|
||||
content: '\2713\0020';
|
||||
position: absolute;
|
||||
top: .15em;
|
||||
left: .22em;
|
||||
font-size: 1.3em;
|
||||
line-height: 0.8;
|
||||
color: var(--checkcolor);
|
||||
transition: all .2s;
|
||||
}
|
||||
/* checked mark aspect changes */
|
||||
[type="checkbox"]:not(:checked) + label:after {
|
||||
opacity: 0;
|
||||
transform: scale(0);
|
||||
}
|
||||
|
||||
[type="checkbox"]:checked + label:after {
|
||||
opacity: 1;
|
||||
transform: scale(1);
|
||||
}
|
||||
/* disabled checkbox */
|
||||
[type="checkbox"]:disabled:not(:checked) + label:before,
|
||||
[type="checkbox"]:disabled:checked + label:before {
|
||||
box-shadow: none;
|
||||
border-color: var(--disabledfontcolor);
|
||||
background-color: var(--disabledbackcolor);
|
||||
}
|
||||
|
||||
[type="checkbox"]:disabled:checked + label:after {
|
||||
color: var(--disabledfontcolor);
|
||||
}
|
||||
|
||||
[type="checkbox"]:disabled + label {
|
||||
color: var(--disabledfontcolor);
|
||||
}
|
||||
/* accessibility */
|
||||
[type="checkbox"]:checked:focus + label:before,
|
||||
[type="checkbox"]:not(:checked):focus + label:before {
|
||||
border: 2px solid var(--checkcolor);
|
||||
}
|
||||
|
||||
/* hover style */
|
||||
label:hover:before {
|
||||
border: 2px solid var(--checkcolor) !important;
|
||||
}
|
||||
|
||||
/* radio button styling*/
|
||||
[type="radio"]:checked,
|
||||
[type="radio"]:not(:checked) {
|
||||
position: absolute;
|
||||
left: -9999px;
|
||||
}
|
||||
|
||||
[type="radio"]:checked + label,
|
||||
[type="radio"]:not(:checked) + label {
|
||||
position: relative;
|
||||
padding-left: 28px;
|
||||
cursor: pointer;
|
||||
line-height: 20px;
|
||||
display: inline-block;
|
||||
font-weight: lighter;
|
||||
}
|
||||
|
||||
[type="radio"]:checked + label:before,
|
||||
[type="radio"]:not(:checked) + label:before {
|
||||
content: '';
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
width: 18px;
|
||||
height: 18px;
|
||||
border: 2px solid var(--bordercolor);
|
||||
border-radius: 100%;
|
||||
background-color: var(--facecolor);
|
||||
}
|
||||
|
||||
[type="radio"]:checked + label:after,
|
||||
[type="radio"]:not(:checked) + label:after {
|
||||
content: '';
|
||||
width: 10px;
|
||||
height: 10px;
|
||||
background-color: var(--checkcolor);
|
||||
position: absolute;
|
||||
top: 4px;
|
||||
left: 4px;
|
||||
border-radius: 100%;
|
||||
-webkit-transition: all 0.2s ease;
|
||||
transition: all 0.2s ease;
|
||||
}
|
||||
|
||||
[type="radio"]:not(:checked) + label:after {
|
||||
opacity: 0;
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0);
|
||||
}
|
||||
|
||||
[type="radio"]:checked + label:after {
|
||||
opacity: 1;
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1);
|
||||
}
|
||||
|
||||
.label {
|
||||
font-weight: lighter
|
||||
}
|
||||
|
||||
.toolsButton {
|
||||
background-color: var(--backcolor);
|
||||
border: 1px solid var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
cursor: pointer;
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
padding: 0 0;
|
||||
margin: 0 0;
|
||||
outline: none;
|
||||
}
|
||||
|
||||
.toolsButton:hover {
|
||||
color: var(--hovercolor);
|
||||
}
|
||||
|
||||
.toolsButton > * {
|
||||
font-size: 18px !important;
|
||||
}
|
||||
|
||||
.textInput {
|
||||
border: 1px solid var(--bordercolor);
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
border-radius: 4px !important;
|
||||
cursor: pointer;
|
||||
height: 1.971428571em;
|
||||
text-align: left;
|
||||
outline: none;
|
||||
padding: 3px;
|
||||
width: 100%;
|
||||
margin-top: 3px;
|
||||
margin-bottom: 5px;
|
||||
}
|
||||
|
||||
.textInput:hover {
|
||||
color: var(--hovercolor);
|
||||
font-weight: 900;
|
||||
}
|
||||
|
||||
.textInput:disabled {
|
||||
color: var(--disabledfontcolor);
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
/*visual collapsible bar*/
|
||||
.visualBar {
|
||||
color: dodgerblue;
|
||||
cursor: pointer;
|
||||
height: 35px;
|
||||
width: 100%;
|
||||
border: none;
|
||||
text-align: left;
|
||||
outline: none;
|
||||
background-color: var(--facecolor);
|
||||
margin-bottom: 2px;
|
||||
margin-top: 2px;
|
||||
}
|
||||
|
||||
.visualBar.collapsed {
|
||||
background-color: var(--facecolor);
|
||||
}
|
||||
|
||||
.visualBar:active, .visualBar:hover {
|
||||
color: var(--hovercolor);
|
||||
font-weight: 900;
|
||||
}
|
||||
|
||||
.visualBar:after {
|
||||
content: '\2212';
|
||||
float: right;
|
||||
}
|
||||
|
||||
.visualBar.collapsed:after {
|
||||
content: '\002B';
|
||||
float: right;
|
||||
}
|
||||
|
||||
.visualBar:disabled {
|
||||
background-color: var(--disabledbackcolor);
|
||||
color: var(--disabledfontcolor);
|
||||
}
|
||||
|
||||
.visualDiv {
|
||||
background-color: var(--menucolor);
|
||||
padding: 0 5px;
|
||||
margin-top: 5px;
|
||||
}
|
||||
|
||||
.visualUl {
|
||||
list-style-type: none;
|
||||
margin: 0;
|
||||
padding: 0 10px;
|
||||
}
|
||||
|
||||
.visualLi {
|
||||
color: var(--fontcolor);
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.visualLi:hover {
|
||||
color: var(--hovercolor);
|
||||
}
|
||||
|
||||
/* visual button*/
|
||||
.visualButton {
|
||||
background-color: var(--facecolor);
|
||||
cursor: pointer;
|
||||
height: 70px;
|
||||
width: 79px;
|
||||
text-align: center;
|
||||
border-radius: 2px;
|
||||
border-color: var(--bordercolor);
|
||||
border-style: solid;
|
||||
border-width: thin;
|
||||
border: none;
|
||||
outline: none;
|
||||
font-size: x-small;
|
||||
vertical-align: middle;
|
||||
margin-bottom: 3px;
|
||||
}
|
||||
|
||||
.visualButton:hover {
|
||||
color: var(--hovercolor);
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
.visualButton:disabled {
|
||||
background-color: var(--disabledbackcolor);
|
||||
color: var(--disabledfontcolor);
|
||||
}
|
||||
|
||||
/* select bar user control*/
|
||||
.selectBar {
|
||||
border: 1px solid var(--bordercolor);
|
||||
border-radius: 4px;
|
||||
background-color: var(--facecolor);
|
||||
cursor: pointer;
|
||||
height: 1.971428571em;
|
||||
width: 100%;
|
||||
text-align: left;
|
||||
outline: none;
|
||||
margin-top: 3px;
|
||||
margin-bottom: 3px;
|
||||
}
|
||||
|
||||
.selectBar.collapsed {
|
||||
background-color: var(--facecolor);
|
||||
}
|
||||
|
||||
.selectBar:active, .selectBar:hover {
|
||||
color: var(--hovercolor);
|
||||
font-weight: 900;
|
||||
}
|
||||
|
||||
.selectBar:disabled {
|
||||
background-color: var(--disabledbackcolor);
|
||||
color: var(--disabledfontcolor);
|
||||
}
|
||||
|
||||
.selectDiv {
|
||||
margin-top: -1px;
|
||||
width: 100%;
|
||||
border: 1px solid var(--bordercolor);
|
||||
border-radius: 1px;
|
||||
display: none;
|
||||
padding: 0;
|
||||
position: absolute;
|
||||
z-index: 1000;
|
||||
}
|
||||
|
||||
.selectList {
|
||||
background-color: var(--menucolor);
|
||||
cursor: pointer;
|
||||
height: 1.971428571em;
|
||||
border: none;
|
||||
text-align: left;
|
||||
outline: none;
|
||||
padding: 0 5px;
|
||||
}
|
||||
|
||||
.selectList:hover {
|
||||
color: var(--hovercolor);
|
||||
font-weight: 900;
|
||||
}
|
||||
|
||||
.pageTabLink {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
float: left;
|
||||
border: none;
|
||||
outline: none;
|
||||
cursor: pointer;
|
||||
padding: 5px 16px;
|
||||
font-size: 14px;
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.pageTabLink:hover {
|
||||
background-color: #555;
|
||||
color: white;
|
||||
}
|
||||
|
||||
.pageTabContent {
|
||||
color: var(--fontcolor);
|
||||
background-color: var(--backcolor);
|
||||
display: none;
|
||||
padding: 15px 10px;
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.pageTopButton {
|
||||
float: right;
|
||||
border: none;
|
||||
outline: none;
|
||||
cursor: pointer;
|
||||
font-size: large;
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.pageTopButton:hover {
|
||||
color: var(--hovercolor);
|
||||
}
|
||||
|
||||
.pageTopButton > * {
|
||||
font-size: 18px !important;
|
||||
}
|
||||
|
||||
.pageBottomButton {
|
||||
position: absolute;
|
||||
bottom: 10px;
|
||||
border: none;
|
||||
outline: none;
|
||||
cursor: pointer;
|
||||
font-size: large;
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.pageBottomButton:hover {
|
||||
color: var(--hovercolor);
|
||||
}
|
||||
|
||||
.pageBottomButton > * {
|
||||
font-size: 18px !important;
|
||||
}
|
||||
|
||||
.panel-heading {
|
||||
border: none;
|
||||
color: var(--facecolor) !important;
|
||||
background-color: var(--barcolor) !important;
|
||||
padding: 7px 7px;
|
||||
border-top-right-radius: 0;
|
||||
border-top-left-radius: 0;
|
||||
}
|
||||
|
||||
.panel-action {
|
||||
border: none;
|
||||
color: var(--facecolor);
|
||||
background-color: var(--barcolor);
|
||||
padding: 7px 7px;
|
||||
width: 32.4px;
|
||||
height: 34px;
|
||||
}
|
||||
|
||||
.panel-action-button {
|
||||
border: none;
|
||||
outline: none;
|
||||
color: var(--facecolor);
|
||||
background: none;
|
||||
cursor: pointer;
|
||||
padding: 0 0;
|
||||
font-size: large;
|
||||
}
|
||||
|
||||
.panel-action-button:hover {
|
||||
color: var(--hovercolor);
|
||||
}
|
||||
|
||||
.panel-body {
|
||||
padding: 0 0 0 0;
|
||||
overflow: hidden;
|
||||
background-color: white;
|
||||
margin: 0 0 0 0;
|
||||
}
|
||||
|
||||
.draggable-handler {
|
||||
cursor: move;
|
||||
z-index: 200;
|
||||
}
|
||||
|
||||
.draggable {
|
||||
position: absolute;
|
||||
z-index: 199;
|
||||
}
|
||||
|
||||
.dragging {
|
||||
z-index: 999 !important
|
||||
}
|
||||
|
||||
hr {
|
||||
margin: 0 0 0 0 !important;
|
||||
padding: 0 0 0 0 !important;
|
||||
background-color: var(--bordercolor);
|
||||
width: 100%;
|
||||
height: 1px;
|
||||
border: none;
|
||||
}
|
||||
|
||||
table {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
td {
|
||||
vertical-align: top;
|
||||
}
|
||||
|
||||
.btn {
|
||||
border-color: var(--bordercolor) !important;
|
||||
color: var(--fontcolor) !important;
|
||||
background-color: var(--backcolor) !important;
|
||||
padding: 3px 12px;
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
.btn:hover {
|
||||
background-color: var(--backcolor) !important;
|
||||
color: var(--hovercolor) !important;
|
||||
font-weight: 600;
|
||||
}
|
||||
14
software/cnip/cnip/Content/cnip/root.css
Normal file
14
software/cnip/cnip/Content/cnip/root.css
Normal file
@@ -0,0 +1,14 @@
|
||||
:root {
|
||||
--hovercolor: rgba(49,52,53,1);
|
||||
--fontcolor: rgba(114,119,122,1);
|
||||
--backcolor: rgba(255, 255, 255, 1);
|
||||
--opfontcolor: rgba(20, 30, 40,1);
|
||||
--opbackcolor: rgba(255, 255, 255, 1);
|
||||
--disabledbackcolor: rgba(233,236,239,1);
|
||||
--disabledfontcolor: rgba(165,142,150,1);
|
||||
--checkcolor: rgba(102,102,102,1);
|
||||
--bordercolor: rgba(206,212,218,1);
|
||||
--menucolor: rgb(255, 255, 255);
|
||||
--facecolor: rgb(255, 255, 255);
|
||||
--barcolor: rgba(30, 144, 255,0.7);
|
||||
}
|
||||
508
software/cnip/cnip/Content/cnip/webui.css
Normal file
508
software/cnip/cnip/Content/cnip/webui.css
Normal file
@@ -0,0 +1,508 @@
|
||||
body {
|
||||
height: 100%;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.fullscreen:-moz-full-screen {
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.fullscreen:-webkit-full-screen {
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.fullscreen:-ms-fullscreen {
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.fullscreen:fullscreen {
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.fullscreen {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
#myMap {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
z-index: 1;
|
||||
top: 0;
|
||||
bottom: 0;
|
||||
position: absolute;
|
||||
float: left;
|
||||
background-color: black;
|
||||
}
|
||||
|
||||
.sidebar {
|
||||
width: 350px;
|
||||
}
|
||||
|
||||
.sidebar-tabs {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.sidebar-tabs > ul > li.active {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.sidebar-tabs > ul > li:hover,
|
||||
.sidebar-tabs > ul > li:focus {
|
||||
background-color: var(--backcolor);
|
||||
}
|
||||
|
||||
.sidebar-tabs > ul > li > a > i {
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.sidebar-tabs > ul > li > a > i:hover,
|
||||
.sidebar-tabs > ul > li > a > i:focus {
|
||||
color: var(--hovercolor);
|
||||
}
|
||||
|
||||
.sidebar-header {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.sidebar-content {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.layer-switcher {
|
||||
position: initial;
|
||||
}
|
||||
|
||||
.layer-switcher li.group > label {
|
||||
margin-left: 6px;
|
||||
font-weight: lighter;
|
||||
}
|
||||
|
||||
.layer-switcher li.layer {
|
||||
margin-left: -18px;
|
||||
}
|
||||
|
||||
.layer-switcher li.group {
|
||||
margin-left: -18px;
|
||||
}
|
||||
|
||||
.layer-switcher .group button {
|
||||
background-color: var(--menucolor);
|
||||
background-image: url('')
|
||||
}
|
||||
|
||||
#about {
|
||||
z-index: 99;
|
||||
position: absolute;
|
||||
bottom: 33px;
|
||||
right: 151px;
|
||||
}
|
||||
|
||||
#activeInteraction {
|
||||
z-index: 99;
|
||||
position: absolute;
|
||||
top: 11px;
|
||||
left: calc(50vw + (/* width */160px / 2));
|
||||
height: 22px;
|
||||
width: 22px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: rgba(255,152,0,0.7);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
opacity: 1;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
#featureInfo {
|
||||
z-index: 99;
|
||||
position: absolute;
|
||||
right: 4px;
|
||||
bottom: 70px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
/*#featureTip {
|
||||
z-index: 99;
|
||||
position: absolute;
|
||||
left: 1px;
|
||||
bottom: 1px;
|
||||
width: 1px;
|
||||
height: 1px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
opacity: 1;
|
||||
}*/
|
||||
|
||||
#noteInfo {
|
||||
z-index: 99;
|
||||
max-width: 172.98px;
|
||||
min-width: 172.98px;
|
||||
position: absolute;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: #fff7d1;
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
opacity: 1;
|
||||
font-size: smaller;
|
||||
overflow: auto;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
#locationInfo {
|
||||
z-index: 99;
|
||||
position: absolute;
|
||||
left: calc(50vw - (/* width */150px / 2));
|
||||
bottom: 10px;
|
||||
width: 260px;
|
||||
height: auto;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
opacity: 1;
|
||||
font-size: smaller;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
#progressBar {
|
||||
position: absolute;
|
||||
left: calc(50vw - (/* width */403px / 2));
|
||||
top: calc(50vh - (/* height */203px / 2));
|
||||
width: 403px;
|
||||
height: 203px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--backcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
#siteOptions {
|
||||
position: absolute;
|
||||
left: calc(50vw - (/* width */651px / 2));
|
||||
top: calc(50vh - (/* height */432px / 2));
|
||||
width: 651px;
|
||||
height: 432px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
#polyOptions {
|
||||
position: absolute;
|
||||
left: calc(50vw - (351px / 2));
|
||||
top: calc(50vh - (236px / 2));
|
||||
width: 351px;
|
||||
height: 236px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
#noteOptions {
|
||||
position: absolute;
|
||||
left: calc(50vw - (451px / 2));
|
||||
top: calc(50vh - (236px / 2));
|
||||
width: 451px;
|
||||
height: 236px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
#linkOptions {
|
||||
position: absolute;
|
||||
left: calc(50vw - (/* width */651px / 2));
|
||||
top: calc(50vh - (/* height */432px / 2));
|
||||
width: 651px;
|
||||
height: 432px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
#linkProfile {
|
||||
position: absolute;
|
||||
left: calc(60vw - (1103px / 2));
|
||||
bottom: 70px;
|
||||
width: 1103px;
|
||||
height: 333px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.datasheet {
|
||||
position: absolute;
|
||||
left: calc(50vw - (/* width */651px / 2));
|
||||
top: calc(50vh - (/* height */432px / 2));
|
||||
width: 651px;
|
||||
height: 432px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
.ol-control button {
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
}
|
||||
|
||||
.ol-control button:hover,
|
||||
.ol-control button:focus {
|
||||
background-color: var(--backcolor);
|
||||
color: var(--hovercolor);
|
||||
}
|
||||
|
||||
.ol-control.ol-bar .ol-toggle.ol-active button:hover,
|
||||
.ol-control.ol-bar .ol-toggle.ol-active > button {
|
||||
background-color: var(--opbackcolor);
|
||||
}
|
||||
|
||||
.ol-searchgps.ol-search.ol-unselectable.ol-control.ol-collapsed {
|
||||
width: 27.94px;
|
||||
height: 27.94px;
|
||||
}
|
||||
|
||||
.ol-search {
|
||||
right: 4px;
|
||||
left: auto;
|
||||
}
|
||||
|
||||
.ol-control.ol-legend {
|
||||
left: auto;
|
||||
right: 4px;
|
||||
top: 100px;
|
||||
bottom: auto;
|
||||
}
|
||||
|
||||
.ol-control.ol-legend button.ol-closebox {
|
||||
left: 1px;
|
||||
}
|
||||
|
||||
.ol-control.ol-legend button.ol-closebox:before {
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.ol-legend.ol-unselectable.ol-control {
|
||||
max-height: calc(77vh);
|
||||
}
|
||||
|
||||
.ol-legend ul li {
|
||||
color: var(--fontcolor);
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.ol-legend ul li.ol-title {
|
||||
background-color: var(--facecolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.ol-legend ul li.ol-title div {
|
||||
background-color: var(--facecolor);
|
||||
color: var(--fontcolor);
|
||||
}
|
||||
|
||||
.ol-scale-line {
|
||||
left: auto;
|
||||
right: 4px;
|
||||
top: auto;
|
||||
bottom: 40px;
|
||||
color: var(--opfontcolor);
|
||||
background-color: var(--opbackcolor);
|
||||
}
|
||||
|
||||
.ol-scale-line-inner {
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
border-top: none;
|
||||
border-left: 1px solid var(--opfontcolor);
|
||||
border-right: 1px solid var(--opfontcolor);
|
||||
border-bottom: 1px solid var(--opfontcolor);
|
||||
}
|
||||
|
||||
.ol-rotate {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.ol-zoom {
|
||||
left: auto;
|
||||
right: 4px;
|
||||
top: 40px;
|
||||
}
|
||||
|
||||
.tooltip.in {
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
.tooltip.top .tooltip-arrow {
|
||||
border-top-color: white;
|
||||
}
|
||||
|
||||
.tooltip-inner {
|
||||
white-space: nowrap;
|
||||
border: 2px solid var(--bordercolor);
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
}
|
||||
|
||||
.hidden-content {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.page-disabler {
|
||||
position: fixed;
|
||||
z-index: 3000;
|
||||
background-color: rgba(0,0,0,.25);
|
||||
width: 100vw;
|
||||
height: 100vh;
|
||||
top: 0;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.page-enabler {
|
||||
position: absolute;
|
||||
z-index: 3100;
|
||||
}
|
||||
|
||||
#messageBoxBar {
|
||||
z-index: 200;
|
||||
position: absolute;
|
||||
left: calc(50vw - (/* width */403px / 2));
|
||||
top: calc(50vh - (/* height */203px / 2));
|
||||
width: 403px;
|
||||
height: 203px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--backcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: block;
|
||||
text-align: center;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
.predictSites {
|
||||
position: absolute;
|
||||
left: calc(50vw - (351px / 2));
|
||||
top: calc(50vh - (236px / 2));
|
||||
width: 351px;
|
||||
height: 236px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
.predictBestCan {
|
||||
position: absolute;
|
||||
left: calc(50vw - (521px / 2));
|
||||
top: calc(50vh - (293px / 2));
|
||||
width: 521px;
|
||||
height: 293px;
|
||||
border: 3px solid transparent;
|
||||
border-radius: 4px;
|
||||
margin: 0;
|
||||
background-color: var(--opbackcolor);
|
||||
color: var(--opfontcolor);
|
||||
transition: opacity 100ms ease-in;
|
||||
display: none;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
.transferContainer {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
.transferButtons {
|
||||
margin-right: 30px;
|
||||
margin-left: 30px;
|
||||
float: left;
|
||||
align-self: center;
|
||||
}
|
||||
|
||||
.listBox {
|
||||
height: 86px !important;
|
||||
width: 200px;
|
||||
background-color: var(--backcolor);
|
||||
color: var(--fontcolor);
|
||||
border: 1px solid var(--bordercolor);
|
||||
border-radius: 4px;
|
||||
cursor: pointer;
|
||||
text-align: left;
|
||||
outline: none;
|
||||
}
|
||||
|
||||
.listBox:active, .listBox:hover {
|
||||
color: var(--hovercolor);
|
||||
font-weight: 900;
|
||||
}
|
||||
|
||||
.listBox:disabled {
|
||||
background-color: var(--disabledbackcolor);
|
||||
color: var(--disabledfontcolor);
|
||||
}
|
||||
36
software/cnip/cnip/Controllers/GlavniController.cs
Normal file
36
software/cnip/cnip/Controllers/GlavniController.cs
Normal file
@@ -0,0 +1,36 @@
|
||||
using System.Data;
|
||||
using System.Web.Mvc;
|
||||
using static cnip.Models.pgsql;
|
||||
namespace cnip.Controllers
|
||||
{
|
||||
public class GlavniController : Controller
|
||||
{
|
||||
public ActionResult Index()
|
||||
{
|
||||
string puid = (string)Session["uid"];
|
||||
string pukey = (string)Session["ukey"];
|
||||
// check if ukey is valid
|
||||
if (!(puid is null) && !(pukey is null) && puid != "" && pukey != "")
|
||||
{
|
||||
DataTable dt = GetDataTableFromQuery(
|
||||
"SELECT ukey FROM pusers WHERE uid='" + puid + "';");
|
||||
if (dt.Rows.Count > 0)
|
||||
{
|
||||
if ((string)dt.Rows[0][0] == pukey)
|
||||
{
|
||||
//user s already logged in
|
||||
if (puid == "99999999")
|
||||
{
|
||||
ViewBag.Data = "redirecttowebadmin";
|
||||
}
|
||||
else
|
||||
{
|
||||
ViewBag.Data = "redirecttowebui";
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return View();
|
||||
}
|
||||
}
|
||||
}
|
||||
12
software/cnip/cnip/Controllers/HomeController.cs
Normal file
12
software/cnip/cnip/Controllers/HomeController.cs
Normal file
@@ -0,0 +1,12 @@
|
||||
using System.Web.Mvc;
|
||||
|
||||
namespace cnip.Controllers
|
||||
{
|
||||
public class HomeController : Controller
|
||||
{
|
||||
public ActionResult Index()
|
||||
{
|
||||
return View();
|
||||
}
|
||||
}
|
||||
}
|
||||
215
software/cnip/cnip/GdalConfiguration.cs
Normal file
215
software/cnip/cnip/GdalConfiguration.cs
Normal file
@@ -0,0 +1,215 @@
|
||||
/******************************************************************************
|
||||
*
|
||||
* Name: GdalConfiguration.cs.pp
|
||||
* Project: GDAL CSharp Interface
|
||||
* Purpose: A static configuration utility class to enable GDAL/OGR.
|
||||
* Author: Felix Obermaier
|
||||
*
|
||||
******************************************************************************
|
||||
* Copyright (c) 2012-2018, Felix Obermaier
|
||||
*
|
||||
* 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.
|
||||
*****************************************************************************/
|
||||
|
||||
using System;
|
||||
using System.Diagnostics;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Runtime.InteropServices;
|
||||
using Gdal = OSGeo.GDAL.Gdal;
|
||||
using Ogr = OSGeo.OGR.Ogr;
|
||||
|
||||
namespace cnip
|
||||
{
|
||||
public static partial class GdalConfiguration
|
||||
{
|
||||
private static volatile bool _configuredOgr;
|
||||
private static volatile bool _configuredGdal;
|
||||
private static volatile bool _usable;
|
||||
|
||||
[DllImport("kernel32", CharSet = CharSet.Auto, SetLastError = true)]
|
||||
static extern bool SetDefaultDllDirectories(uint directoryFlags);
|
||||
// LOAD_LIBRARY_SEARCH_USER_DIRS | LOAD_LIBRARY_SEARCH_SYSTEM32
|
||||
private const uint DllSearchFlags = 0x00000400 | 0x00000800;
|
||||
|
||||
[DllImport("kernel32.dll", CharSet = CharSet.Unicode, SetLastError = true)]
|
||||
[return: MarshalAs(UnmanagedType.Bool)]
|
||||
static extern bool AddDllDirectory(string lpPathName);
|
||||
|
||||
/// <summary>
|
||||
/// Construction of Gdal/Ogr
|
||||
/// </summary>
|
||||
static GdalConfiguration()
|
||||
{
|
||||
string executingDirectory = null, gdalPath = null, nativePath = null;
|
||||
try
|
||||
{
|
||||
if (!IsWindows)
|
||||
{
|
||||
const string notSet = "_Not_set_";
|
||||
string tmp = Gdal.GetConfigOption("GDAL_DATA", notSet);
|
||||
_usable = tmp != notSet;
|
||||
return;
|
||||
}
|
||||
|
||||
string executingAssemblyFile = new Uri(Assembly.GetExecutingAssembly().GetName().CodeBase).LocalPath;
|
||||
executingDirectory = Path.GetDirectoryName(executingAssemblyFile);
|
||||
|
||||
if (string.IsNullOrEmpty(executingDirectory))
|
||||
throw new InvalidOperationException("cannot get executing directory");
|
||||
|
||||
|
||||
// modify search place and order
|
||||
SetDefaultDllDirectories(DllSearchFlags);
|
||||
|
||||
gdalPath = Path.Combine(executingDirectory, "gdal");
|
||||
nativePath = Path.Combine(gdalPath, GetPlatform());
|
||||
if (!Directory.Exists(nativePath))
|
||||
throw new DirectoryNotFoundException($"GDAL native directory not found at '{nativePath}'");
|
||||
if (!File.Exists(Path.Combine(nativePath, "gdal_wrap.dll")))
|
||||
throw new FileNotFoundException(
|
||||
$"GDAL native wrapper file not found at '{Path.Combine(nativePath, "gdal_wrap.dll")}'");
|
||||
|
||||
// Add directories
|
||||
AddDllDirectory(nativePath);
|
||||
AddDllDirectory(Path.Combine(nativePath, "plugins"));
|
||||
|
||||
// Set the additional GDAL environment variables.
|
||||
string gdalData = Path.Combine(gdalPath, "data");
|
||||
Environment.SetEnvironmentVariable("GDAL_DATA", gdalData);
|
||||
Gdal.SetConfigOption("GDAL_DATA", gdalData);
|
||||
|
||||
string driverPath = Path.Combine(nativePath, "plugins");
|
||||
Environment.SetEnvironmentVariable("GDAL_DRIVER_PATH", driverPath);
|
||||
Gdal.SetConfigOption("GDAL_DRIVER_PATH", driverPath);
|
||||
|
||||
Environment.SetEnvironmentVariable("GEOTIFF_CSV", gdalData);
|
||||
Gdal.SetConfigOption("GEOTIFF_CSV", gdalData);
|
||||
|
||||
string projSharePath = Path.Combine(gdalPath, "share");
|
||||
Environment.SetEnvironmentVariable("PROJ_LIB", projSharePath);
|
||||
Gdal.SetConfigOption("PROJ_LIB", projSharePath);
|
||||
|
||||
_usable = true;
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
_usable = false;
|
||||
Trace.WriteLine(e, "error");
|
||||
Trace.WriteLine($"Executing directory: {executingDirectory}", "error");
|
||||
Trace.WriteLine($"gdal directory: {gdalPath}", "error");
|
||||
Trace.WriteLine($"native directory: {nativePath}", "error");
|
||||
|
||||
//throw;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value indicating if the GDAL package is set up properly.
|
||||
/// </summary>
|
||||
public static bool Usable
|
||||
{
|
||||
get { return _usable; }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Method to ensure the static constructor is being called.
|
||||
/// </summary>
|
||||
/// <remarks>Be sure to call this function before using Gdal/Ogr/Osr</remarks>
|
||||
public static void ConfigureOgr()
|
||||
{
|
||||
if (!_usable) return;
|
||||
if (_configuredOgr) return;
|
||||
|
||||
// Register drivers
|
||||
Ogr.RegisterAll();
|
||||
_configuredOgr = true;
|
||||
|
||||
PrintDriversOgr();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Method to ensure the static constructor is being called.
|
||||
/// </summary>
|
||||
/// <remarks>Be sure to call this function before using Gdal/Ogr/Osr</remarks>
|
||||
public static void ConfigureGdal()
|
||||
{
|
||||
if (!_usable) return;
|
||||
if (_configuredGdal) return;
|
||||
|
||||
// Register drivers
|
||||
Gdal.AllRegister();
|
||||
_configuredGdal = true;
|
||||
|
||||
PrintDriversGdal();
|
||||
}
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// Function to determine which platform we're on
|
||||
/// </summary>
|
||||
private static string GetPlatform()
|
||||
{
|
||||
return Environment.Is64BitProcess ? "x64" : "x86";
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets a value indicating if we are on a windows platform
|
||||
/// </summary>
|
||||
private static bool IsWindows
|
||||
{
|
||||
get
|
||||
{
|
||||
var res = !(Environment.OSVersion.Platform == PlatformID.Unix ||
|
||||
Environment.OSVersion.Platform == PlatformID.MacOSX);
|
||||
|
||||
return res;
|
||||
}
|
||||
}
|
||||
private static void PrintDriversOgr()
|
||||
{
|
||||
#if DEBUG
|
||||
if (_usable)
|
||||
{
|
||||
var num = Ogr.GetDriverCount();
|
||||
for (var i = 0; i < num; i++)
|
||||
{
|
||||
var driver = Ogr.GetDriver(i);
|
||||
Trace.WriteLine($"OGR {i}: {driver.GetName()}", "Debug");
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
private static void PrintDriversGdal()
|
||||
{
|
||||
#if DEBUG
|
||||
if (_usable)
|
||||
{
|
||||
var num = Gdal.GetDriverCount();
|
||||
for (var i = 0; i < num; i++)
|
||||
{
|
||||
var driver = Gdal.GetDriver(i);
|
||||
Trace.WriteLine($"GDAL {i}: {driver.ShortName}-{driver.LongName}");
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
}
|
||||
}
|
||||
218
software/cnip/cnip/GdalConfiguration.vb
Normal file
218
software/cnip/cnip/GdalConfiguration.vb
Normal file
@@ -0,0 +1,218 @@
|
||||
'******************************************************************************
|
||||
'*
|
||||
'* Name: GdalConfiguration.vb.pp
|
||||
'* Project: GDAL VB.NET Interface
|
||||
'* Purpose: A static configuration utility class to enable GDAL/OGR.
|
||||
'* Author: Felix Obermaier
|
||||
'*
|
||||
'******************************************************************************
|
||||
'* Copyright (c) 2012-2018, Felix Obermaier
|
||||
'*
|
||||
'* 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.
|
||||
'*****************************************************************************/
|
||||
|
||||
Option Infer On
|
||||
|
||||
Imports System
|
||||
Imports System.Diagnostics
|
||||
Imports System.IO
|
||||
Imports System.Reflection
|
||||
Imports System.Runtime.InteropServices
|
||||
Imports Gdal = OSGeo.GDAL.Gdal
|
||||
Imports Ogr = OSGeo.OGR.Ogr
|
||||
|
||||
Namespace cnip
|
||||
''' <summary>
|
||||
''' Configuration class for GDAL/OGR
|
||||
''' </summary>
|
||||
Public Partial Class GdalConfiguration
|
||||
Private Shared _configuredOgr As Boolean
|
||||
Private Shared _configuredGdal As Boolean
|
||||
Private Shared _usable As Boolean
|
||||
|
||||
<DllImport("kernel32.dll", CharSet:=CharSet.Auto, SetLastError:=True)>
|
||||
Public Shared Function SetDefaultDllDirectories(ByVal directoryFlags As UInteger) As Boolean
|
||||
|
||||
End Function
|
||||
|
||||
' LOAD_LIBRARY_SEARCH_USER_DIRS | LOAD_LIBRARY_SEARCH_SYSTEM32
|
||||
Private Const DllSearchFlags As UInteger = &H400 Or &H800
|
||||
|
||||
<DllImport("kernel32.dll", CharSet:=CharSet.Unicode, SetLastError:=True)>
|
||||
Public Shared Function AddDllDirectory(ByVal lpPathName As String) As <MarshalAs(UnmanagedType.Bool)> Boolean
|
||||
|
||||
End Function
|
||||
|
||||
''' <summary>
|
||||
''' Construction of Gdal/Ogr
|
||||
''' </summary>
|
||||
Shared Sub New()
|
||||
Dim nativePath As String = Nothing
|
||||
Dim executingDirectory As String = Nothing
|
||||
Dim gdalPath As String = Nothing
|
||||
Try
|
||||
If Not IsWindows Then
|
||||
Const notSet As String = "_Not_set_"
|
||||
Dim tmp As String = Gdal.GetConfigOption("GDAL_DATA", notSet)
|
||||
_usable = (tmp <> notSet)
|
||||
Return
|
||||
End If
|
||||
|
||||
Dim executingAssemblyFile As String = New Uri(Assembly.GetExecutingAssembly.GetName.CodeBase).LocalPath
|
||||
executingDirectory = Path.GetDirectoryName(executingAssemblyFile)
|
||||
If String.IsNullOrEmpty(executingDirectory) Then
|
||||
Throw New InvalidOperationException("cannot get executing directory")
|
||||
End If
|
||||
|
||||
SetDefaultDllDirectories(DllSearchFlags)
|
||||
gdalPath = Path.Combine(executingDirectory, "gdal")
|
||||
nativePath = Path.Combine(gdalPath, GetPlatform())
|
||||
If Not Directory.Exists(nativePath) Then
|
||||
Throw New DirectoryNotFoundException($"GDAL native directory not found at '{nativePath}'")
|
||||
End If
|
||||
|
||||
If Not File.Exists(Path.Combine(nativePath, "gdal_wrap.dll")) Then
|
||||
Throw New FileNotFoundException($"GDAL native wrapper file not found at '{Path.Combine(nativePath, ", gdal_wrap.dll, ")}'")
|
||||
End If
|
||||
|
||||
AddDllDirectory(nativePath)
|
||||
AddDllDirectory(Path.Combine(nativePath, "plugins"))
|
||||
' Set the additional GDAL environment variables.
|
||||
Dim gdalData As String = Path.Combine(gdalPath, "data")
|
||||
Environment.SetEnvironmentVariable("GDAL_DATA", gdalData)
|
||||
Gdal.SetConfigOption("GDAL_DATA", gdalData)
|
||||
Dim driverPath As String = Path.Combine(nativePath, "plugins")
|
||||
Environment.SetEnvironmentVariable("GDAL_DRIVER_PATH", driverPath)
|
||||
Gdal.SetConfigOption("GDAL_DRIVER_PATH", driverPath)
|
||||
Environment.SetEnvironmentVariable("GEOTIFF_CSV", gdalData)
|
||||
Gdal.SetConfigOption("GEOTIFF_CSV", gdalData)
|
||||
Dim projSharePath As String = Path.Combine(gdalPath, "share")
|
||||
Environment.SetEnvironmentVariable("PROJ_LIB", projSharePath)
|
||||
Gdal.SetConfigOption("PROJ_LIB", projSharePath)
|
||||
_usable = True
|
||||
Catch e As Exception
|
||||
_usable = False
|
||||
Trace.WriteLine(e, "error")
|
||||
Trace.WriteLine($"Executing directory: {executingDirectory}", "error")
|
||||
Trace.WriteLine($"gdal directory: {gdalPath}", "error")
|
||||
Trace.WriteLine($"native directory: {nativePath}", "error")
|
||||
'throw;
|
||||
End Try
|
||||
|
||||
End Sub
|
||||
|
||||
''' <summary>
|
||||
''' Gets a value indicating if the GDAL package is set up properly.
|
||||
''' </summary>
|
||||
Public Shared ReadOnly Property Usable As Boolean
|
||||
Get
|
||||
Return _usable
|
||||
End Get
|
||||
End Property
|
||||
|
||||
''' <summary>
|
||||
''' Method to ensure the static constructor is being called.
|
||||
''' </summary>
|
||||
''' <remarks>Be sure to call this function before using Gdal/Ogr/Osr</remarks>
|
||||
Public Shared Sub ConfigureOgr()
|
||||
If Not _usable Then
|
||||
Return
|
||||
End If
|
||||
|
||||
If _configuredOgr Then
|
||||
Return
|
||||
End If
|
||||
|
||||
' Register drivers
|
||||
Ogr.RegisterAll
|
||||
_configuredOgr = True
|
||||
PrintDriversOgr()
|
||||
End Sub
|
||||
|
||||
''' <summary>
|
||||
''' Method to ensure the static constructor is being called.
|
||||
''' </summary>
|
||||
''' <remarks>Be sure to call this function before using Gdal/Ogr/Osr</remarks>
|
||||
Public Shared Sub ConfigureGdal()
|
||||
If Not _usable Then
|
||||
Return
|
||||
End If
|
||||
|
||||
If _configuredGdal Then
|
||||
Return
|
||||
End If
|
||||
|
||||
' Register drivers
|
||||
Gdal.AllRegister
|
||||
_configuredGdal = True
|
||||
PrintDriversGdal()
|
||||
End Sub
|
||||
|
||||
''' <summary>
|
||||
''' Function to determine which platform we're on
|
||||
''' </summary>
|
||||
Private Shared Function GetPlatform() As String
|
||||
If (Environment.Is64BitProcess) Then Return "x64"
|
||||
return "x86"
|
||||
End Function
|
||||
|
||||
''' <summary>
|
||||
''' Gets a value indicating if we are on a windows platform
|
||||
''' </summary>
|
||||
Private Shared ReadOnly Property IsWindows As Boolean
|
||||
Get
|
||||
Dim res = Not ((Environment.OSVersion.Platform = PlatformID.Unix) _
|
||||
OrElse (Environment.OSVersion.Platform = PlatformID.MacOSX))
|
||||
Return res
|
||||
End Get
|
||||
End Property
|
||||
|
||||
Private Shared Sub PrintDriversOgr()
|
||||
#if (DEBUG)
|
||||
If _usable Then
|
||||
Dim num = Ogr.GetDriverCount
|
||||
Dim i = 0
|
||||
Do While (i < num)
|
||||
Dim driver = Ogr.GetDriver(i)
|
||||
Trace.WriteLine($"OGR {i}: {driver.GetName()}", "Debug")
|
||||
i = (i + 1)
|
||||
Loop
|
||||
|
||||
End If
|
||||
|
||||
#End If
|
||||
End Sub
|
||||
|
||||
Private Shared Sub PrintDriversGdal()
|
||||
#if (DEBUG)
|
||||
If _usable Then
|
||||
Dim num = Gdal.GetDriverCount
|
||||
Dim i = 0
|
||||
Do While (i < num)
|
||||
Dim driver = Gdal.GetDriver(i)
|
||||
Trace.WriteLine($"GDAL {i}: {driver.ShortName}-{driver.LongName}")
|
||||
i = (i + 1)
|
||||
Loop
|
||||
|
||||
End If
|
||||
|
||||
#End If
|
||||
End Sub
|
||||
End Class
|
||||
End Namespace
|
||||
1
software/cnip/cnip/Global.asax
Normal file
1
software/cnip/cnip/Global.asax
Normal file
@@ -0,0 +1 @@
|
||||
<%@ Application Codebehind="Global.asax.cs" Inherits="cnip.MvcApplication" Language="C#" %>
|
||||
44
software/cnip/cnip/Global.asax.cs
Normal file
44
software/cnip/cnip/Global.asax.cs
Normal file
@@ -0,0 +1,44 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Drawing;
|
||||
using System.Drawing.Imaging;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Runtime.InteropServices;
|
||||
using System.Web;
|
||||
using System.Web.Mvc;
|
||||
using System.Web.Optimization;
|
||||
using System.Web.Routing;
|
||||
using System.Web.Security;
|
||||
using System.Web.SessionState;
|
||||
using OSGeo.GDAL;
|
||||
using OSGeo.OGR;
|
||||
using OSGeo.OSR;
|
||||
using cnip.Models;
|
||||
using System.Data;
|
||||
using System.Web.UI;
|
||||
using System.Web.Services;
|
||||
using System.Xml;
|
||||
using Newtonsoft;
|
||||
using Newtonsoft.Json;
|
||||
using Newtonsoft.Json.Linq;
|
||||
using System.Diagnostics;
|
||||
using System.Text;
|
||||
|
||||
namespace cnip
|
||||
{
|
||||
public class MvcApplication : System.Web.HttpApplication
|
||||
{
|
||||
protected void Application_Start()
|
||||
{
|
||||
Application["Name"] = "CNIP";
|
||||
AreaRegistration.RegisterAllAreas();
|
||||
FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
|
||||
RouteConfig.RegisterRoutes(RouteTable.Routes);
|
||||
BundleTable.EnableOptimizations = true;
|
||||
BundleConfig.RegisterBundles(BundleTable.Bundles);
|
||||
GdalConfiguration.ConfigureGdal();
|
||||
GdalConfiguration.ConfigureOgr();
|
||||
}
|
||||
}
|
||||
}
|
||||
80
software/cnip/cnip/Models/bfspbvg.cs
Normal file
80
software/cnip/cnip/Models/bfspbvg.cs
Normal file
@@ -0,0 +1,80 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
//https://www.geeksforgeeks.org/find-if-there-is-a-path-between-two-vertices-in-a-given-graph/
|
||||
|
||||
// modified for undirected graph
|
||||
|
||||
public static class bfspbvg
|
||||
{
|
||||
public class Graph
|
||||
{
|
||||
private readonly int V; // No. of vertices
|
||||
private readonly List<int>[] adj; // An array containing adjacency lists
|
||||
public Graph(int V) // Constructor
|
||||
{
|
||||
this.V = V;
|
||||
adj = new List<int>[V];
|
||||
for (int i = 0; i < V; i++)
|
||||
{
|
||||
adj[i] = new List<int>();
|
||||
}
|
||||
}
|
||||
public void AddEdge(int v, int w) // function to add an edge to graph
|
||||
{
|
||||
adj[v].Add(w);
|
||||
adj[w].Add(v);
|
||||
}
|
||||
// A BFS based function to check whether d is reachable from s.
|
||||
public bool IsReachable(int s, int d)
|
||||
{
|
||||
// Base case
|
||||
if (s == d)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
// Mark all the vertices as not visited
|
||||
bool[] visited = new bool[V];
|
||||
for (int i = 0; i < V; i++)
|
||||
{
|
||||
visited[i] = false;
|
||||
}
|
||||
// Create a queue for BFS
|
||||
List<int> queue = new List<int>();
|
||||
// Mark the current node as visited and enqueue it
|
||||
visited[s] = true;
|
||||
queue.Add(s);
|
||||
// it will be used to get all adjacent vertices of a vertex
|
||||
List<int>.Enumerator j;
|
||||
while (queue.Count > 0)
|
||||
{
|
||||
// Dequeue a vertex from queue
|
||||
s = queue.First();
|
||||
queue.Remove(queue.First());
|
||||
// Get all adjacent vertices of the dequeued vertex s
|
||||
// If a adjacent has not been visited, then mark it visited
|
||||
// and enqueue it
|
||||
for (j = adj[s].GetEnumerator(); j.MoveNext();)
|
||||
{
|
||||
// If this adjacent node is the destination node, then
|
||||
// return true
|
||||
if (j.Current == d)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
// Else, continue to do BFS
|
||||
if (!visited[j.Current])
|
||||
{
|
||||
visited[j.Current] = true;
|
||||
queue.Add(j.Current);
|
||||
}
|
||||
}
|
||||
}
|
||||
// If BFS is complete without visiting d
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
191
software/cnip/cnip/Models/gdalext.cs
Normal file
191
software/cnip/cnip/Models/gdalext.cs
Normal file
@@ -0,0 +1,191 @@
|
||||
using System;
|
||||
using System.Runtime.InteropServices;
|
||||
using OSGeo.GDAL;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
public static class gdalext
|
||||
{
|
||||
public struct GdalInfo
|
||||
{
|
||||
// GDAL affine transform coefficients
|
||||
// GT[0], X Min
|
||||
// GT[1], X Pixel Size
|
||||
// GT[2], X Coefficients
|
||||
// GT[3], Y Max
|
||||
// GT[4], Y Coefficients
|
||||
// GT[5], Y Pixel size
|
||||
public double XMin { get; set; }
|
||||
public double XPixelSize { get; set; }
|
||||
public double XCoefficient { get; set; }
|
||||
public double YMax { get; set; }
|
||||
public double YCoefficient { get; set; }
|
||||
public double YPixelSize { get; set; }
|
||||
public double XMax { get; set; } // extended properties
|
||||
public double YMin { get; set; } // extended properties
|
||||
public double XRasterSize { get; set; } // extended properties
|
||||
public double YRasterSize { get; set; } // extended properties
|
||||
public GdalInfo(
|
||||
double xmin,
|
||||
double xpixelsize,
|
||||
double ymax,
|
||||
double ypixelsize)
|
||||
{
|
||||
XMin = xmin;
|
||||
XPixelSize = xpixelsize;
|
||||
YMax = ymax;
|
||||
YPixelSize = ypixelsize;
|
||||
XRasterSize = 0;
|
||||
YRasterSize = 0;
|
||||
XCoefficient = 0;
|
||||
YCoefficient = 0;
|
||||
XMax = 0;
|
||||
YMin = 0;
|
||||
}
|
||||
}
|
||||
public static bool Pgsql2Json(
|
||||
string pgSqlConn, string jsonFile, string[] options)
|
||||
{
|
||||
using (Dataset inputds = Gdal.OpenEx(
|
||||
pgSqlConn, (uint)GdalConst.OF_VECTOR, null, null, null))
|
||||
{
|
||||
if (inputds == null) { return false; }
|
||||
try
|
||||
{
|
||||
Dataset test = Gdal.wrapper_GDALVectorTranslateDestName(
|
||||
jsonFile, inputds,
|
||||
new GDALVectorTranslateOptions(options), null, null);
|
||||
if (test == null)
|
||||
{
|
||||
inputds.Dispose();
|
||||
return false;
|
||||
}
|
||||
test.Dispose();
|
||||
}
|
||||
catch (Exception) { return false; }
|
||||
finally
|
||||
{
|
||||
inputds.Dispose();
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
public static bool Json2Pgsql(
|
||||
string jsonFile, string pgSqlConn, string[] options)
|
||||
{
|
||||
using (Dataset inputds = Gdal.OpenEx(
|
||||
jsonFile, (uint)GdalConst.OF_READONLY, null, null, null))
|
||||
{
|
||||
if (inputds == null) { return false; }
|
||||
Dataset outputds = Gdal.OpenEx(
|
||||
pgSqlConn, (uint)(GdalConst.OF_VECTOR), null, null, null);
|
||||
if (outputds == null) { inputds.Dispose(); return false; }
|
||||
try
|
||||
{
|
||||
int test = Gdal.wrapper_GDALVectorTranslateDestDS(
|
||||
outputds, inputds,
|
||||
new GDALVectorTranslateOptions(options), null, null);
|
||||
}
|
||||
catch (Exception) { return false; }
|
||||
finally
|
||||
{
|
||||
inputds.Dispose();
|
||||
outputds.Dispose();
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
public static GdalInfo GetGdalInfo(string inputFile)
|
||||
{
|
||||
GdalInfo info = new GdalInfo();
|
||||
Dataset ds = Gdal.Open(inputFile, Access.GA_ReadOnly);
|
||||
double[] GT = new double[6];
|
||||
ds.GetGeoTransform(GT);
|
||||
info.XMin = GT[0];
|
||||
info.XPixelSize = GT[1];
|
||||
info.XCoefficient = GT[2];
|
||||
info.YMax = GT[3];
|
||||
info.YCoefficient = GT[4];
|
||||
info.YPixelSize = GT[5];
|
||||
info.XMax = GT[0] + GT[1] * ds.RasterXSize + GT[2] * ds.RasterYSize;
|
||||
info.YMin = GT[3] + GT[4] * ds.RasterXSize + GT[5] * ds.RasterYSize;
|
||||
info.XRasterSize = ds.RasterXSize;
|
||||
info.YRasterSize = ds.RasterYSize;
|
||||
ds.Dispose();
|
||||
return info;
|
||||
}
|
||||
public static void SetGdalInfo(string inputFile, GdalInfo info)
|
||||
{
|
||||
Dataset ds = Gdal.Open(inputFile, Access.GA_Update);
|
||||
double[] GT = new double[6];
|
||||
ds.GetGeoTransform(GT);
|
||||
GT[1] = info.XPixelSize; GT[5] = info.YPixelSize;
|
||||
GT[0] = info.XMin; GT[3] = info.YMax;
|
||||
ds.SetGeoTransform(GT);
|
||||
ds.Dispose();
|
||||
}
|
||||
public static bool Translate(
|
||||
string inputFile, string outputFile, string[] options)
|
||||
{
|
||||
using (Dataset inputds = Gdal.OpenEx(
|
||||
inputFile, (uint)GdalConst.OF_RASTER, null, null, null))
|
||||
{
|
||||
if (inputds == null) { return false; }
|
||||
try
|
||||
{
|
||||
Dataset test = Gdal.wrapper_GDALTranslate(
|
||||
outputFile, inputds,
|
||||
new GDALTranslateOptions(options), null, null);
|
||||
if (test == null)
|
||||
{
|
||||
inputds.Dispose();
|
||||
return false;
|
||||
}
|
||||
test.Dispose();
|
||||
}
|
||||
catch (Exception) { return false; }
|
||||
finally
|
||||
{
|
||||
inputds.Dispose();
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
public static bool Warp(
|
||||
string inputFile, string outputFile, string[] options)
|
||||
{
|
||||
using (Dataset inputds = Gdal.Open(
|
||||
inputFile, Access.GA_ReadOnly))
|
||||
{
|
||||
if (inputds == null)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
IntPtr[] ptr = { Dataset.getCPtr(inputds).Handle };
|
||||
GCHandle gcHandle = GCHandle.Alloc(ptr, GCHandleType.Pinned);
|
||||
Dataset result = null;
|
||||
try
|
||||
{
|
||||
SWIGTYPE_p_p_GDALDatasetShadow dss =
|
||||
new SWIGTYPE_p_p_GDALDatasetShadow(
|
||||
gcHandle.AddrOfPinnedObject(), false, null);
|
||||
result = Gdal.wrapper_GDALWarpDestName(
|
||||
outputFile, 1, dss,
|
||||
new GDALWarpAppOptions(options), null, null);
|
||||
if (result == null)
|
||||
{
|
||||
throw new Exception("GdalWarp failed: " +
|
||||
Gdal.GetLastErrorMsg());
|
||||
}
|
||||
}
|
||||
catch (Exception) { return false; }
|
||||
finally
|
||||
{
|
||||
gcHandle.Free();
|
||||
result.Dispose();
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
412
software/cnip/cnip/Models/generic.cs
Normal file
412
software/cnip/cnip/Models/generic.cs
Normal file
@@ -0,0 +1,412 @@
|
||||
using System;
|
||||
using System.Data;
|
||||
using System.Diagnostics;
|
||||
using System.IO;
|
||||
using OSGeo.GDAL;
|
||||
using static cnip.Models.gisext;
|
||||
using static cnip.Models.pgsql;
|
||||
using static cnip.Models.strext;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
public static class generic
|
||||
{
|
||||
public static int RandomNumber(int min, int max)
|
||||
{
|
||||
Random random = new Random(); return random.Next(min, max);
|
||||
|
||||
}
|
||||
public static double DbmToWatt(double dbm)
|
||||
{
|
||||
return Math.Pow(10, dbm / 10) / 1000;
|
||||
}
|
||||
public static double WattToDbm(double watt)
|
||||
{
|
||||
return 10 * Math.Log10(watt * 1000);
|
||||
}
|
||||
public enum Extent
|
||||
{
|
||||
Center = 0,
|
||||
BottomLeft = 1,
|
||||
BottomRight = 2,
|
||||
TopLeft = 3,
|
||||
TopRight = 4
|
||||
}
|
||||
public static Coords GetExtent(
|
||||
string puid,
|
||||
string values,
|
||||
string columnname,
|
||||
string tableName,
|
||||
Extent extent)
|
||||
{
|
||||
Coords c = new Coords(0, 0);
|
||||
string sitesWhere = BuildWhere(values, columnname);
|
||||
foreach (DataRow row in GetDataTableFromQuery(
|
||||
"SELECT " +
|
||||
(extent == Extent.Center ?
|
||||
"(MAX(longitude)+MIN(longitude))/2 AS X, " +
|
||||
"(MAX(latitude)+MIN(latitude))/2 AS Y " :
|
||||
extent == Extent.BottomLeft ?
|
||||
"MIN(longitude) AS X, " +
|
||||
"MIN(latitude) AS Y " :
|
||||
extent == Extent.BottomRight ?
|
||||
"MAX(longitude) AS X, " +
|
||||
"MIN(latitude) AS Y " :
|
||||
extent == Extent.TopLeft ?
|
||||
"MIN(longitude) AS X, " +
|
||||
"MAX(latitude) AS Y " :
|
||||
"MAX(longitude) AS X, " +
|
||||
"MAX(latitude) AS Y "
|
||||
) +
|
||||
"FROM " +
|
||||
tableName + " WHERE " +
|
||||
"uid='" + puid + "' AND " +
|
||||
sitesWhere + "GROUP BY uid;").Rows)
|
||||
{
|
||||
c.X = row[0].ToString().ToDouble();
|
||||
c.Y = row[1].ToString().ToDouble();
|
||||
}
|
||||
return c;
|
||||
}
|
||||
public static void StartProcess(string path, string args = "", bool wait = true)
|
||||
{
|
||||
Process process = new Process();
|
||||
process.StartInfo.FileName = path;
|
||||
process.StartInfo.UseShellExecute = false;
|
||||
process.StartInfo.CreateNoWindow = true;
|
||||
process.StartInfo.Arguments = args;
|
||||
process.Start();
|
||||
if (wait) process.WaitForExit();
|
||||
process.Close();
|
||||
}
|
||||
public static string GetElevationStringFromPointsArray(
|
||||
string pointsArray)
|
||||
{
|
||||
string retval = "";
|
||||
int loca = 0, locb = 0;
|
||||
double prevLon = 0.000000000001, prevLat = 0.000000000001;
|
||||
double longitude = 0.000000000000, latitude = 0.000000000000;
|
||||
double[] pGT = new double[6];
|
||||
string[] locations = pointsArray.Split('@');
|
||||
int col = 0, row = 0, lastElev = 0;
|
||||
int[] pRBB = new int[1];
|
||||
Dataset ds = Gdal.Open(GetRasterPath(-200, -200),
|
||||
Access.GA_ReadOnly);
|
||||
Band band = ds.GetRasterBand(1);
|
||||
CPLErr error;
|
||||
for (int i = 0; i < locations.Length; i++)
|
||||
{
|
||||
try
|
||||
{
|
||||
longitude = locations[i].Split('&')[0].ToDouble();
|
||||
latitude = locations[i].Split('&')[1].ToDouble();
|
||||
if (latitude.ToString().Trim().Split('.')[0] !=
|
||||
prevLat.ToString().Trim().Split('.')[0] &&
|
||||
longitude.ToString().Trim().Split('.')[0] !=
|
||||
prevLon.ToString().Trim().Split('.')[0])
|
||||
{
|
||||
prevLat = latitude; prevLon = longitude;
|
||||
ds.Dispose();
|
||||
ds = Gdal.Open(
|
||||
GetRasterPath(longitude, latitude),
|
||||
Access.GA_ReadOnly);
|
||||
pGT = new double[6];
|
||||
ds.GetGeoTransform(pGT);
|
||||
band = ds.GetRasterBand(1);
|
||||
}
|
||||
col = Math.Abs((int)((longitude - pGT[0]) / pGT[1]));
|
||||
row = Math.Abs((int)((pGT[3] - latitude) / -pGT[5]));
|
||||
error =
|
||||
band.ReadRaster(col, row, 1, 1, pRBB, 1, 1, 0, 0);
|
||||
if (pRBB[0] < 0) { pRBB[0] = lastElev; }
|
||||
lastElev = pRBB[0];
|
||||
if (i == 0) { loca = pRBB[0]; }
|
||||
if (i == locations.Length - 2) { locb = pRBB[0]; }
|
||||
retval += locations[i] + "&" + pRBB[0].ToString() + "@";
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (retval.Length > 0)
|
||||
{
|
||||
retval = loca.ToString() + "#" + locb.ToString() + "#" + retval.TrimEnd(1);
|
||||
}
|
||||
else
|
||||
{
|
||||
retval = "0#0#0&0&0&0";
|
||||
}
|
||||
band.Dispose();
|
||||
ds.Dispose();
|
||||
return retval;
|
||||
}
|
||||
public static double GetAverageElevationFromPointsArray(
|
||||
string pointsArray)
|
||||
{
|
||||
int loca = 0, locb = 0;
|
||||
double averageElevation = 0;
|
||||
double prevLon = 0.000000000001, prevLat = 0.000000000001;
|
||||
double longitude = 0.000000000000, latitude = 0.000000000000;
|
||||
double[] pGT = new double[6];
|
||||
string[] locations = pointsArray.Split('@');
|
||||
int col = 0, row = 0, lastElev = 0;
|
||||
int[] pRBB = new int[1];
|
||||
Dataset ds = Gdal.Open(GetRasterPath(-200, -200),
|
||||
Access.GA_ReadOnly);
|
||||
Band band = ds.GetRasterBand(1);
|
||||
CPLErr error;
|
||||
for (int i = 0; i < locations.Length; i++)
|
||||
{
|
||||
try
|
||||
{
|
||||
longitude = locations[i].Split('&')[0].ToDouble();
|
||||
latitude = locations[i].Split('&')[1].ToDouble();
|
||||
if (latitude.ToString().Trim().Split('.')[0] !=
|
||||
prevLat.ToString().Trim().Split('.')[0] &&
|
||||
longitude.ToString().Trim().Split('.')[0] !=
|
||||
prevLon.ToString().Trim().Split('.')[0])
|
||||
{
|
||||
prevLat = latitude; prevLon = longitude;
|
||||
ds.Dispose();
|
||||
ds = Gdal.Open(
|
||||
GetRasterPath(longitude, latitude),
|
||||
Access.GA_ReadOnly);
|
||||
pGT = new double[6];
|
||||
ds.GetGeoTransform(pGT);
|
||||
band = ds.GetRasterBand(1);
|
||||
}
|
||||
col = Math.Abs((int)((longitude - pGT[0]) / pGT[1]));
|
||||
row = Math.Abs((int)((pGT[3] - latitude) / -pGT[5]));
|
||||
error =
|
||||
band.ReadRaster(col, row, 1, 1, pRBB, 1, 1, 0, 0);
|
||||
if (pRBB[0] < 0) { pRBB[0] = lastElev; }
|
||||
lastElev = pRBB[0];
|
||||
if (i == 0) { loca = pRBB[0]; }
|
||||
if (i == locations.Length - 2) { locb = pRBB[0]; }
|
||||
averageElevation = (averageElevation + pRBB[0]) / 2;
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
band.Dispose();
|
||||
ds.Dispose();
|
||||
return averageElevation;
|
||||
}
|
||||
public static int GetElevationFromLonLat(
|
||||
double longitude, double latitude)
|
||||
{
|
||||
try
|
||||
{
|
||||
Dataset ds = Gdal.Open(
|
||||
GetRasterPath(longitude, latitude),
|
||||
Access.GA_ReadOnly);
|
||||
double[] pGT = new double[6];
|
||||
ds.GetGeoTransform(pGT);
|
||||
int col = Math.Abs((int)((longitude - pGT[0]) / pGT[1]));
|
||||
int row = Math.Abs((int)((pGT[3] - latitude) / -pGT[5]));
|
||||
Band band = ds.GetRasterBand(1);
|
||||
CPLErr error;
|
||||
// p read block byte
|
||||
int[] pRBB = new int[1];
|
||||
error =
|
||||
band.ReadRaster(col, row, 1, 1, pRBB, 1, 1, 0, 0);
|
||||
if (pRBB[0] < 0) { pRBB[0] = 0; }
|
||||
band.Dispose();
|
||||
ds.Dispose();
|
||||
return pRBB[0];
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
public static string GetRasterPath(
|
||||
double longitude, double latitude)
|
||||
{
|
||||
string path = "dummy.tif";
|
||||
string lon = longitude.ToString().Trim().Split('.')[0];
|
||||
string lat = latitude.ToString().Trim().Split('.')[0];
|
||||
if (longitude != -200 && latitude != -200)
|
||||
{
|
||||
if (lat.StartsWith("-"))
|
||||
{
|
||||
path = "S" +
|
||||
(lat.Replace("-", "").ToInt() + 1).ToString("00");
|
||||
}
|
||||
else
|
||||
{
|
||||
path = "N" + lat.ToInt().ToString("00");
|
||||
}
|
||||
if (lon.StartsWith("-"))
|
||||
{
|
||||
path += "W" +
|
||||
(lon.Replace("-", "").ToInt() + 1).ToString("000");
|
||||
}
|
||||
else
|
||||
{
|
||||
path += "E" + lon.ToInt().ToString("000") + ".hgt";
|
||||
}
|
||||
}
|
||||
return @"C:/SPLAT/sdf-hd/" + path;
|
||||
}
|
||||
public static string GetElevationStringFromLineString(
|
||||
string lineString, int resolution = 100)
|
||||
{
|
||||
string pointsArray = ""; double unitLength = 0;
|
||||
foreach (DataRow row in GetDataTableFromQuery(
|
||||
"SELECT locations, dist FROM (" +
|
||||
"SELECT " +
|
||||
"ST_AsText(ST_LineSubstring(wkb_geometry, " +
|
||||
"length/" + resolution.ToString() + "*n/length," +
|
||||
"CASE WHEN length/" + resolution.ToString() + "*(n+1)<length " +
|
||||
"THEN length/" + resolution.ToString() + "*(n+1)/length " +
|
||||
"ELSE 1 END)) AS locations, " +
|
||||
"ST_Length(Geography(ST_LineSubstring(wkb_geometry, " +
|
||||
"length/" + resolution.ToString() + "*n/length," +
|
||||
"CASE WHEN length/" + resolution.ToString() + "*(n+1)<length " +
|
||||
"THEN length/" + resolution.ToString() + "*(n+1)/length " +
|
||||
"ELSE 1 END)),TRUE) As dist FROM " +
|
||||
"(SELECT " +
|
||||
"ST_LineMerge(ST_GeomFromText('" +
|
||||
lineString + "',4326)) AS wkb_geometry," +
|
||||
"ROUND(ST_Length(Geography(ST_GeomFromText('" +
|
||||
lineString + "',4326)),TRUE)) As length" +
|
||||
")tmp " +
|
||||
"CROSS JOIN generate_series(0,10000) AS n " +
|
||||
"WHERE n*length/" + resolution.ToString() + "/length<1" +
|
||||
")tmp WHERE dist>0;").Rows)
|
||||
{
|
||||
string[] locations = row[0].ToString().Replace(
|
||||
"LINESTRING(", "").Replace(")", "").Split(',');
|
||||
string[] location1 = locations[0].Split(' ');
|
||||
string[] location2 = locations[1].Split(' ');
|
||||
if (pointsArray.Length == 0)
|
||||
{
|
||||
pointsArray += location1[0] + "&" +
|
||||
location1[1] + "&" + unitLength.ToString() + "@";
|
||||
unitLength += row[1].ToString().ToDouble() / 1000;
|
||||
pointsArray += location2[0] + '&' +
|
||||
location2[1] + "&" + unitLength.ToString() + "@";
|
||||
}
|
||||
else
|
||||
{
|
||||
unitLength += row[1].ToString().ToDouble() / 1000;
|
||||
pointsArray += location2[0] + "&" +
|
||||
location2[1] + "&" + unitLength.ToString() + "@";
|
||||
}
|
||||
}
|
||||
pointsArray = pointsArray.TrimEnd(1);
|
||||
return GetElevationStringFromPointsArray(pointsArray);
|
||||
}
|
||||
public static double GetAverageElevationFromLineString(
|
||||
string lineString, int resolution = 100)
|
||||
{
|
||||
string pointsArray = "";
|
||||
foreach (DataRow row in GetDataTableFromQuery(
|
||||
"SELECT locations, dist FROM (" +
|
||||
"SELECT " +
|
||||
"ST_AsText(ST_LineSubstring(wkb_geometry, " +
|
||||
"length/" + resolution.ToString() + "*n/length," +
|
||||
"CASE WHEN length/" + resolution.ToString() + "*(n+1)<length " +
|
||||
"THEN length/" + resolution.ToString() + "*(n+1)/length " +
|
||||
"ELSE 1 END)) AS locations, " +
|
||||
"ST_Length(Geography(ST_LineSubstring(wkb_geometry, " +
|
||||
"length/" + resolution.ToString() + "*n/length," +
|
||||
"CASE WHEN length/" + resolution.ToString() + "*(n+1)<length " +
|
||||
"THEN length/" + resolution.ToString() + "*(n+1)/length " +
|
||||
"ELSE 1 END)),TRUE) As dist FROM " +
|
||||
"(SELECT " +
|
||||
"ST_LineMerge(ST_GeomFromText('" +
|
||||
lineString + "',4326)) AS wkb_geometry," +
|
||||
"ROUND(ST_Length(Geography(ST_GeomFromText('" +
|
||||
lineString + "',4326)),TRUE)) As length" +
|
||||
")tmp " +
|
||||
"CROSS JOIN generate_series(0,10000) AS n " +
|
||||
"WHERE n*length/" + resolution.ToString() + "/length<1" +
|
||||
")tmp WHERE dist>0;").Rows)
|
||||
{
|
||||
string[] locations = row[0].ToString().Replace(
|
||||
"LINESTRING(", "").Replace(")", "").Split(',');
|
||||
string[] location1 = locations[0].Split(' ');
|
||||
string[] location2 = locations[1].Split(' ');
|
||||
if (pointsArray.Length == 0)
|
||||
{
|
||||
pointsArray += location1[0] + "&" +
|
||||
location1[1] + "@";
|
||||
pointsArray += location2[0] + '&' +
|
||||
location2[1] + "@";
|
||||
}
|
||||
else
|
||||
{
|
||||
pointsArray += location2[0] + "&" +
|
||||
location2[1] + "@";
|
||||
}
|
||||
}
|
||||
pointsArray = pointsArray.TrimEnd(1);
|
||||
return GetAverageElevationFromPointsArray(pointsArray);
|
||||
}
|
||||
public static double AverageElevationFromCluster(Coords center, double radiusMeters)
|
||||
{
|
||||
string pointsArray = "";
|
||||
foreach (DataRow point in GetDataTableFromQuery(
|
||||
"SELECT ST_AsText((ST_Dump(ST_GeneratePoints(" +
|
||||
"Geometry(ST_Buffer(Geography(ST_GeomFromText(" +
|
||||
"'POINT(" + center.X.ToString() + " " + center.Y.ToString() + ")'" +
|
||||
",4326))," + radiusMeters.ToString() + ")),600))).geom);"
|
||||
).Rows)
|
||||
{
|
||||
string[] location = point[0].ToString().
|
||||
Replace("POINT(", "").Replace(")", "").Split(' ');
|
||||
pointsArray += location[0] + "&" + location[1] + "@";
|
||||
}
|
||||
pointsArray = pointsArray.TrimEnd(1);
|
||||
return GetAverageElevationFromPointsArray(pointsArray);
|
||||
}
|
||||
public static double AverageElevationFromCenter(Coords center, double radiusMeters)
|
||||
{
|
||||
Coords locA, locB;
|
||||
locA = Destination(center, 0, radiusMeters);
|
||||
locB = Destination(center, 180, radiusMeters);
|
||||
string lineString1 = "LINESTRING(" +
|
||||
locA.X.ToString() + " " + locA.Y.ToString() + "," +
|
||||
locB.X.ToString() + " " + locB.Y.ToString() + ")";
|
||||
locA = Destination(center, 90, radiusMeters);
|
||||
locB = Destination(center, 270, radiusMeters);
|
||||
string lineString2 = "LINESTRING(" +
|
||||
locA.X.ToString() + " " + locA.Y.ToString() + "," +
|
||||
locB.X.ToString() + " " + locB.Y.ToString() + ")";
|
||||
locA = Destination(center, 45, radiusMeters);
|
||||
locB = Destination(center, 225, radiusMeters);
|
||||
string lineString3 = "LINESTRING(" +
|
||||
locA.X.ToString() + " " + locA.Y.ToString() + "," +
|
||||
locB.X.ToString() + " " + locB.Y.ToString() + ")";
|
||||
locA = Destination(center, 135, radiusMeters);
|
||||
locB = Destination(center, 315, radiusMeters);
|
||||
string lineString4 = "LINESTRING(" +
|
||||
locA.X.ToString() + " " + locA.Y.ToString() + "," +
|
||||
locB.X.ToString() + " " + locB.Y.ToString() + ")";
|
||||
return
|
||||
(
|
||||
(
|
||||
GetAverageElevationFromLineString(lineString1) +
|
||||
GetAverageElevationFromLineString(lineString2) +
|
||||
GetAverageElevationFromLineString(lineString3) +
|
||||
GetAverageElevationFromLineString(lineString4)
|
||||
)
|
||||
/ 4
|
||||
);
|
||||
}
|
||||
public static void ClearTempPath(string tempfol)
|
||||
{
|
||||
try
|
||||
{
|
||||
Array.ForEach(Directory.GetFiles(tempfol),
|
||||
delegate (string path) { File.Delete(path); });
|
||||
}
|
||||
catch (Exception) { }
|
||||
}
|
||||
}
|
||||
}
|
||||
276
software/cnip/cnip/Models/gisext.cs
Normal file
276
software/cnip/cnip/Models/gisext.cs
Normal file
@@ -0,0 +1,276 @@
|
||||
using System;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
public static class gisext
|
||||
{
|
||||
public enum UnitSystem
|
||||
{
|
||||
SI = 0,
|
||||
US = 1
|
||||
}
|
||||
public enum DistanceFormula
|
||||
{
|
||||
Haversine = 0,
|
||||
SphericalLawOfCosines = 1,
|
||||
SphericalEarthProjection = 2
|
||||
}
|
||||
|
||||
#region internal: properties (read-only)
|
||||
internal static double EarthRadiusKm { get { return _radiusEarthKM; } }
|
||||
internal static double EarthRadiusMiles { get { return _radiusEarthMiles; } }
|
||||
internal static double M2Km { get { return _m2Km; } }
|
||||
internal static double Deg2rad { get { return _toRad; } }
|
||||
internal static double Rad2deg { get { return _toDeg; } }
|
||||
#endregion
|
||||
#region private: const
|
||||
private const double _radiusEarthMiles = 3959;
|
||||
private const double _radiusEarthKM = 6371;
|
||||
private const double _m2Km = 1.60934;
|
||||
private const double _toRad = Math.PI / 180;
|
||||
private const double _toDeg = 180 / Math.PI;
|
||||
#endregion
|
||||
#region Method 1: Haversine algo
|
||||
/// <summary>
|
||||
/// Distance between two geographic points on surface, km/miles
|
||||
/// Haversine formula to calculate
|
||||
/// great-circle (orthodromic) distance on Earth
|
||||
/// High Accuracy, Medium speed
|
||||
/// re: http://en.wikipedia.org/wiki/Haversine_formula
|
||||
/// </summary>
|
||||
/// <param name="Lat1">double: 1st point Latitude</param>
|
||||
/// <param name="Lon1">double: 1st point Longitude</param>
|
||||
/// <param name="Lat2">double: 2nd point Latitude</param>
|
||||
/// <param name="Lon2">double: 2nd point Longitude</param>
|
||||
/// <returns>double: distance, km/miles</returns>
|
||||
private static double DistanceHaversine(
|
||||
Coords loc1,
|
||||
Coords loc2,
|
||||
UnitSystem unitSystem)
|
||||
{
|
||||
try
|
||||
{
|
||||
double _radLat1 = loc1.Y * _toRad;
|
||||
double _radLat2 = loc2.Y * _toRad;
|
||||
double _dLatHalf = (_radLat2 - _radLat1) / 2;
|
||||
double _dLonHalf = Math.PI * (loc2.Y - loc1.X) / 360;
|
||||
|
||||
// intermediate result
|
||||
double _a = Math.Sin(_dLatHalf);
|
||||
_a *= _a;
|
||||
|
||||
// intermediate result
|
||||
double _b = Math.Sin(_dLonHalf);
|
||||
_b *= _b * Math.Cos(_radLat1) * Math.Cos(_radLat2);
|
||||
|
||||
// central angle, aka arc segment angular distance
|
||||
double _centralAngle =
|
||||
2 * Math.Atan2(
|
||||
Math.Sqrt(_a + _b),
|
||||
Math.Sqrt(1 - _a - _b)
|
||||
);
|
||||
|
||||
// great-circle (orthodromic) distance on Earth between 2 points
|
||||
if (unitSystem == UnitSystem.SI)
|
||||
{
|
||||
return _radiusEarthKM * _centralAngle * 1000;
|
||||
}
|
||||
else
|
||||
{
|
||||
return _radiusEarthMiles * _centralAngle;
|
||||
}
|
||||
}
|
||||
catch { throw; }
|
||||
}
|
||||
#endregion
|
||||
#region Method 2: Spherical Law of Cosines
|
||||
/// <summary>
|
||||
/// Distance between two geographic points on surface, km/miles
|
||||
/// Spherical Law of Cosines formula to calculate
|
||||
/// great-circle (orthodromic) distance on Earth;
|
||||
/// High Accuracy, Medium speed
|
||||
/// re: http://en.wikipedia.org/wiki/Spherical_law_of_cosines
|
||||
/// </summary>
|
||||
/// <param name="Lat1">double: 1st point Latitude</param>
|
||||
/// <param name="Lon1">double: 1st point Longitude</param>
|
||||
/// <param name="Lat2">double: 2nd point Latitude</param>
|
||||
/// <param name="Lon2">double: 2nd point Longitude</param>
|
||||
/// <returns>double: distance, km/miles</returns>
|
||||
private static double DistanceSLC(
|
||||
Coords loc1,
|
||||
Coords loc2,
|
||||
UnitSystem unitSystem)
|
||||
{
|
||||
try
|
||||
{
|
||||
double _radLat1 = loc1.Y * _toRad;
|
||||
double _radLat2 = loc2.Y * _toRad;
|
||||
double _radLon1 = loc1.X * _toRad;
|
||||
double _radLon2 = loc2.X * _toRad;
|
||||
|
||||
// central angle, aka arc segment angular distance
|
||||
double _centralAngle =
|
||||
Math.Acos(Math.Sin(_radLat1) *
|
||||
Math.Sin(_radLat2) +
|
||||
Math.Cos(_radLat1) *
|
||||
Math.Cos(_radLat2) *
|
||||
Math.Cos(_radLon2 - _radLon1));
|
||||
|
||||
// great-circle (orthodromic) distance on Earth between 2 points
|
||||
if (unitSystem == UnitSystem.SI)
|
||||
{
|
||||
return _radiusEarthKM * _centralAngle * 1000;
|
||||
}
|
||||
else
|
||||
{
|
||||
return _radiusEarthMiles * _centralAngle;
|
||||
}
|
||||
}
|
||||
catch { throw; }
|
||||
}
|
||||
#endregion
|
||||
#region Method 3: Spherical Earth projection
|
||||
/// <summary>
|
||||
/// Distance between two geographic points on surface, km/miles
|
||||
/// Spherical Earth projection to a plane formula (using Pythagorean Theorem)
|
||||
/// to calculate great-circle (orthodromic) distance on Earth.
|
||||
/// central angle =
|
||||
/// Sqrt((_radLat2 - _radLat1)^2 + (Cos((_radLat1 + _radLat2)/2) * (Lon2 - Lon1))^2)
|
||||
/// Medium Accuracy, Fast,
|
||||
/// relative error less than 0.1% in search area smaller than 250 miles
|
||||
/// re: http://en.wikipedia.org/wiki/Geographical_distance
|
||||
/// </summary>
|
||||
/// <param name="Lat1">double: 1st point Latitude</param>
|
||||
/// <param name="Lon1">double: 1st point Longitude</param>
|
||||
/// <param name="Lat2">double: 2nd point Latitude</param>
|
||||
/// <param name="Lon2">double: 2nd point Longitude</param>
|
||||
/// <returns>double: distance, km/miles</returns>
|
||||
private static double DistanceSEP(Coords loc1,
|
||||
Coords loc2,
|
||||
UnitSystem unitSystem)
|
||||
{
|
||||
try
|
||||
{
|
||||
double _radLat1 = loc1.Y * _toRad;
|
||||
double _radLat2 = loc2.Y * _toRad;
|
||||
double _dLat = (_radLat2 - _radLat1);
|
||||
double _dLon = (loc2.X - loc1.X) * _toRad;
|
||||
|
||||
double _a = (_dLon) * Math.Cos((_radLat1 + _radLat2) / 2);
|
||||
|
||||
// central angle, aka arc segment angular distance
|
||||
double _centralAngle = Math.Sqrt(_a * _a + _dLat * _dLat);
|
||||
|
||||
// great-circle (orthodromic) distance on Earth between 2 points
|
||||
if (unitSystem == UnitSystem.SI)
|
||||
{
|
||||
return _radiusEarthKM * _centralAngle * 1000;
|
||||
}
|
||||
else
|
||||
{
|
||||
return _radiusEarthMiles * _centralAngle;
|
||||
}
|
||||
}
|
||||
catch { throw; }
|
||||
}
|
||||
#endregion
|
||||
public struct Coords
|
||||
{
|
||||
public double X { get; set; }
|
||||
public double Y { get; set; }
|
||||
public Coords(double x, double y)
|
||||
{
|
||||
X = x; Y = y;
|
||||
}
|
||||
}
|
||||
public struct Bounds
|
||||
{
|
||||
public double XMin { get; set; }
|
||||
public double YMin { get; set; }
|
||||
public double XMax { get; set; }
|
||||
public double YMax { get; set; }
|
||||
public Bounds(
|
||||
double xmin,
|
||||
double ymin,
|
||||
double xmax,
|
||||
double ymax)
|
||||
{
|
||||
XMin = xmin;
|
||||
YMin = ymin;
|
||||
XMax = xmax;
|
||||
YMax = ymax;
|
||||
}
|
||||
}
|
||||
public static Bounds MBR(
|
||||
Coords center, double radius)
|
||||
{
|
||||
Bounds mbr = new Bounds();
|
||||
Coords bottomLeft, topRight;
|
||||
bottomLeft =
|
||||
Destination(center, 225,
|
||||
Math.Sqrt(2 * Math.Pow(radius, 2)));
|
||||
topRight =
|
||||
Destination(center, 45,
|
||||
Math.Sqrt(2 * Math.Pow(radius, 2)));
|
||||
mbr.XMin = bottomLeft.X > topRight.X ?
|
||||
topRight.X : bottomLeft.X;
|
||||
mbr.XMax = bottomLeft.X > topRight.X ?
|
||||
bottomLeft.X : topRight.X;
|
||||
mbr.YMin = bottomLeft.Y > topRight.Y ?
|
||||
topRight.Y : bottomLeft.Y;
|
||||
mbr.YMax = bottomLeft.Y > topRight.Y ?
|
||||
bottomLeft.Y : topRight.Y;
|
||||
return mbr;
|
||||
}
|
||||
public static Coords Destination(
|
||||
Coords source, double bearing, double distance)
|
||||
{
|
||||
Coords destination = new Coords();
|
||||
source.X = source.X * _toRad;
|
||||
source.Y = source.Y * _toRad;
|
||||
distance = distance / 1000;
|
||||
bearing = bearing * _toRad;
|
||||
destination.Y = Math.Asin(
|
||||
(
|
||||
Math.Sin(source.Y) *
|
||||
Math.Cos(distance / _radiusEarthKM)
|
||||
) +
|
||||
(
|
||||
Math.Cos(source.Y) *
|
||||
Math.Sin(distance / _radiusEarthKM) *
|
||||
Math.Cos(bearing)
|
||||
)
|
||||
);
|
||||
destination.X = source.X + Math.Atan2(
|
||||
Math.Sin(bearing) *
|
||||
Math.Sin(distance / _radiusEarthKM) *
|
||||
Math.Cos(source.Y),
|
||||
Math.Cos(distance / _radiusEarthKM) -
|
||||
Math.Sin(source.Y) *
|
||||
Math.Sin(destination.Y)
|
||||
);
|
||||
destination.Y = destination.Y * _toDeg;
|
||||
destination.X = destination.X * _toDeg;
|
||||
return destination;
|
||||
}
|
||||
public static double Distance(
|
||||
Coords loc1,
|
||||
Coords loc2,
|
||||
UnitSystem unitSystem = UnitSystem.SI,
|
||||
DistanceFormula distanceFormula =
|
||||
DistanceFormula.SphericalEarthProjection)
|
||||
{
|
||||
switch (distanceFormula)
|
||||
{
|
||||
case DistanceFormula.Haversine:
|
||||
return DistanceHaversine(loc1, loc2, unitSystem);
|
||||
case DistanceFormula.SphericalEarthProjection:
|
||||
return DistanceSEP(loc1, loc2, unitSystem);
|
||||
case DistanceFormula.SphericalLawOfCosines:
|
||||
return DistanceSLC(loc1, loc2, unitSystem);
|
||||
default:
|
||||
return DistanceSEP(loc1, loc2, unitSystem);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
135
software/cnip/cnip/Models/kruskal.cs
Normal file
135
software/cnip/cnip/Models/kruskal.cs
Normal file
@@ -0,0 +1,135 @@
|
||||
using System;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
// https://www.geeksforgeeks.org/kruskals-minimum-spanning-tree-algorithm-greedy-algo-2/
|
||||
|
||||
public static class kruskal
|
||||
{
|
||||
// A class to represent a graph edge
|
||||
public class Edge : IComparable<Edge>
|
||||
{
|
||||
public int src, dest, weight;
|
||||
|
||||
// Comparator function used for sorting edges
|
||||
// based on their weight
|
||||
public int CompareTo(Edge compareEdge)
|
||||
{
|
||||
return this.weight - compareEdge.weight;
|
||||
}
|
||||
}
|
||||
|
||||
public class Graph
|
||||
{
|
||||
|
||||
// A class to represent a subset for union-find
|
||||
private class Subset
|
||||
{
|
||||
public int parent, rank;
|
||||
};
|
||||
|
||||
private readonly int V, E; // V-> no. of vertices & E->no.of edges
|
||||
public Edge[] edge; // collection of all edges
|
||||
|
||||
// Creates a graph with V vertices and E edges
|
||||
public Graph(int v, int e)
|
||||
{
|
||||
V = v;
|
||||
E = e;
|
||||
edge = new Edge[E];
|
||||
for (int i = 0; i < e; ++i)
|
||||
edge[i] = new Edge();
|
||||
}
|
||||
|
||||
// A utility function to find set of an element i
|
||||
// (uses path compression technique)
|
||||
private int Find(Subset[] subsets, int i)
|
||||
{
|
||||
// find root and make root as
|
||||
// parent of i (path compression)
|
||||
if (subsets[i].parent != i)
|
||||
subsets[i].parent = Find(subsets,
|
||||
subsets[i].parent);
|
||||
|
||||
return subsets[i].parent;
|
||||
}
|
||||
|
||||
// A function that does union of
|
||||
// two sets of x and y (uses union by rank)
|
||||
private void Union(Subset[] subsets, int x, int y)
|
||||
{
|
||||
int xroot = Find(subsets, x);
|
||||
int yroot = Find(subsets, y);
|
||||
|
||||
// Attach smaller rank tree under root of
|
||||
// high rank tree (Union by Rank)
|
||||
if (subsets[xroot].rank < subsets[yroot].rank)
|
||||
subsets[xroot].parent = yroot;
|
||||
else if (subsets[xroot].rank > subsets[yroot].rank)
|
||||
subsets[yroot].parent = xroot;
|
||||
|
||||
// If ranks are same, then make one as root
|
||||
// and increment its rank by one
|
||||
else
|
||||
{
|
||||
subsets[yroot].parent = xroot;
|
||||
subsets[xroot].rank++;
|
||||
}
|
||||
}
|
||||
|
||||
// The main function to construct MST
|
||||
// using Kruskal's algorithm
|
||||
public Edge[] KruskalMST()
|
||||
{
|
||||
Edge[] result = new Edge[V]; // This will store the resultant MST
|
||||
int e = 0; // An index variable, used for result[]
|
||||
int i = 0; // An index variable, used for sorted edges
|
||||
for (i = 0; i < V; ++i)
|
||||
result[i] = new Edge();
|
||||
|
||||
// Step 1: Sort all the edges in non-decreasing
|
||||
// order of their weight. If we are not allowed
|
||||
// to change the given graph, we can create
|
||||
// a copy of array of edges
|
||||
Array.Sort(edge);
|
||||
|
||||
// Allocate memory for creating V ssubsets
|
||||
Subset[] subsets = new Subset[V];
|
||||
for (i = 0; i < V; ++i)
|
||||
subsets[i] = new Subset();
|
||||
|
||||
// Create V subsets with single elements
|
||||
for (int v = 0; v < V; ++v)
|
||||
{
|
||||
subsets[v].parent = v;
|
||||
subsets[v].rank = 0;
|
||||
}
|
||||
|
||||
i = 0; // Index used to pick next edge
|
||||
|
||||
// Number of edges to be taken is equal to V-1
|
||||
while (e < V - 1)
|
||||
{
|
||||
// Step 2: Pick the smallest edge. And increment
|
||||
// the index for next iteration
|
||||
Edge next_edge = new Edge();
|
||||
next_edge = edge[i++];
|
||||
|
||||
int x = Find(subsets, next_edge.src);
|
||||
int y = Find(subsets, next_edge.dest);
|
||||
|
||||
// If including this edge does't cause cycle,
|
||||
// include it in result and increment the index
|
||||
// of result for next edge
|
||||
if (x != y)
|
||||
{
|
||||
result[e++] = next_edge;
|
||||
Union(subsets, x, y);
|
||||
}
|
||||
// Else discard the next_edge
|
||||
}
|
||||
return result;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
141
software/cnip/cnip/Models/pgsql.cs
Normal file
141
software/cnip/cnip/Models/pgsql.cs
Normal file
@@ -0,0 +1,141 @@
|
||||
using System;
|
||||
using System.Data;
|
||||
using static System.Configuration.ConfigurationManager;
|
||||
using Npgsql;
|
||||
using static Npgsql.NpgsqlConnection;
|
||||
using static cnip.Models.gisext;
|
||||
using System.Linq;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
public static class pgsql
|
||||
{
|
||||
public static void DropTable(string tablename)
|
||||
{
|
||||
ExecuteNonQuery("DROP TABLE IF EXISTS " + tablename + ";");
|
||||
}
|
||||
public static bool TableExists(string tablename)
|
||||
{
|
||||
DataTable dt = GetDataTableFromQuery("SELECT * FROM " +
|
||||
"information_schema.tables WHERE table_schema = 'public' " +
|
||||
"AND table_name = '" + tablename + "';");
|
||||
return dt.Rows.Count > 0 ? true : false;
|
||||
}
|
||||
public static bool TableHasData(string tablename)
|
||||
{
|
||||
DataTable dt = GetDataTableFromQuery("SELECT EXISTS(SELECT * FROM " +
|
||||
tablename + ") AS has_row;");
|
||||
return dt.Rows.Count == 0 ? false :
|
||||
dt.Rows[0][0].ToString().ToLower() == "true" ? true : false;
|
||||
}
|
||||
public static DataTable GetDataTableFromQuery(
|
||||
string query, string connstr = "")
|
||||
{
|
||||
if (connstr == "")
|
||||
{
|
||||
connstr = ConnectionStrings["cnipdb"].ConnectionString;
|
||||
}
|
||||
GlobalTypeMapper.UseNetTopologySuite();
|
||||
using (NpgsqlConnection con = new NpgsqlConnection(connstr))
|
||||
using (NpgsqlDataAdapter da = new NpgsqlDataAdapter(query, con))
|
||||
{
|
||||
DataSet ds = new DataSet();
|
||||
da.Fill(ds);
|
||||
return ds.Tables[0];
|
||||
}
|
||||
}
|
||||
public static void ExecuteNonQuery(string query, string connstr = "")
|
||||
{
|
||||
if (connstr == "")
|
||||
{
|
||||
connstr = ConnectionStrings["cnipdb"].ConnectionString;
|
||||
}
|
||||
GlobalTypeMapper.UseNetTopologySuite();
|
||||
using (NpgsqlConnection con = new NpgsqlConnection(connstr))
|
||||
using (NpgsqlCommand cmd = new NpgsqlCommand(query, con))
|
||||
{
|
||||
con.Open();
|
||||
cmd.CommandTimeout = 0;
|
||||
cmd.CommandType = CommandType.Text;
|
||||
cmd.ExecuteNonQuery();
|
||||
con.Close();
|
||||
}
|
||||
}
|
||||
public static string BuildWhere(
|
||||
string values,
|
||||
string columnname,
|
||||
bool equals = true)
|
||||
{
|
||||
string where = "";
|
||||
if (values.Length > 0)
|
||||
{
|
||||
where = String.Join(" ",
|
||||
values.Split(',').
|
||||
Select(x => columnname +
|
||||
(equals ? "=" : "<>") +
|
||||
"'" + x + "' " +
|
||||
(equals ? "OR" : "AND")).
|
||||
ToArray());
|
||||
where =where.TrimEnd(equals ? 3 : 4);
|
||||
where = "(" + where + ") ";
|
||||
}
|
||||
return where;
|
||||
}
|
||||
public static Bounds MBR(Coords center, double radius)
|
||||
{
|
||||
Bounds mbr = new Bounds();
|
||||
Coords bottomLeft = new Coords();
|
||||
Coords topRight = new Coords();
|
||||
foreach (DataRow row in GetDataTableFromQuery(
|
||||
"SELECT ST_Project(Geography(ST_GeomFromText(" +
|
||||
"'POINT(" +
|
||||
center.X.ToString() + " " +
|
||||
center.Y.ToString() + ")',4326))," +
|
||||
Math.Sqrt(2 * Math.Pow(radius, 2)).ToString() +
|
||||
",radians(225));").Rows)
|
||||
{
|
||||
bottomLeft.X = row[0].ToString().Replace(
|
||||
"POINT(", "").Replace(")", "").Split(' ')[0].ToDouble();
|
||||
bottomLeft.Y = row[0].ToString().Replace(
|
||||
"POINT(", "").Replace(")", "").Split(' ')[1].ToDouble();
|
||||
}
|
||||
foreach (DataRow row in GetDataTableFromQuery(
|
||||
"SELECT ST_Project(Geography(ST_GeomFromText(" +
|
||||
"'POINT(" +
|
||||
center.X.ToString() + " " +
|
||||
center.Y.ToString() + ")',4326))," +
|
||||
Math.Sqrt(2 * Math.Pow(radius, 2)).ToString() +
|
||||
",radians(45));").Rows)
|
||||
{
|
||||
topRight.X = row[0].ToString().Replace(
|
||||
"POINT(", "").Replace(")", "").Split(' ')[0].ToDouble();
|
||||
topRight.Y = row[0].ToString().Replace(
|
||||
"POINT(", "").Replace(")", "").Split(' ')[1].ToDouble();
|
||||
}
|
||||
mbr.XMin = bottomLeft.X > topRight.X ? topRight.X : bottomLeft.X;
|
||||
mbr.XMax = bottomLeft.X > topRight.X ? bottomLeft.X : topRight.X;
|
||||
mbr.YMin = bottomLeft.Y > topRight.Y ? topRight.Y : bottomLeft.Y;
|
||||
mbr.YMax = bottomLeft.Y > topRight.Y ? bottomLeft.Y : topRight.Y;
|
||||
return mbr;
|
||||
}
|
||||
public static double Distance(Coords loc1, Coords loc2)
|
||||
{
|
||||
double d = 0;
|
||||
foreach (DataRow row in GetDataTableFromQuery(
|
||||
"SELECT ST_Distance(" +
|
||||
"Geography(ST_GeomFromText(" +
|
||||
"'POINT(" +
|
||||
loc1.X.ToString() + " " +
|
||||
loc1.Y.ToString() + ")',4326))," +
|
||||
"Geography(ST_GeomFromText(" +
|
||||
"'POINT(" +
|
||||
loc2.X.ToString() + " " +
|
||||
loc2.Y.ToString() + ")',4326))," +
|
||||
"true);").Rows)
|
||||
{
|
||||
d = row[0].ToString().ToDouble();
|
||||
}
|
||||
return d;
|
||||
}
|
||||
}
|
||||
}
|
||||
96
software/cnip/cnip/Models/rfantenna.cs
Normal file
96
software/cnip/cnip/Models/rfantenna.cs
Normal file
@@ -0,0 +1,96 @@
|
||||
namespace cnip.Models
|
||||
{
|
||||
class rfantenna
|
||||
{
|
||||
public struct RFAntenna
|
||||
{
|
||||
public string AntennaModel { get; set; }
|
||||
public string AntennaType { get; set; }
|
||||
public string Polarization { get; set; }
|
||||
public string VBeamWidth { get; set; }
|
||||
public string HBeamWidth { get; set; }
|
||||
public string DownTilt { get; set; }
|
||||
public string AntennaGain { get; set; }
|
||||
}
|
||||
public static RFAntenna GetRFAntennaParameters(string antennaModel)
|
||||
{
|
||||
RFAntenna rfAntenna = new RFAntenna();
|
||||
switch (antennaModel)
|
||||
{
|
||||
case "LT OD9-5 890-950 MHz":
|
||||
rfAntenna.AntennaModel = "LT OD9-5 890-950 MHz";
|
||||
rfAntenna.AntennaType = "Omni";
|
||||
rfAntenna.Polarization = "Vertical";
|
||||
rfAntenna.VBeamWidth = "36";
|
||||
rfAntenna.HBeamWidth = "360";
|
||||
rfAntenna.DownTilt = "0";
|
||||
rfAntenna.AntennaGain = "5";
|
||||
break;
|
||||
case "LT OD9-6 865-945 MHz":
|
||||
rfAntenna.AntennaModel = "LT OD9-6 865-945 MHz";
|
||||
rfAntenna.AntennaType = "Omni";
|
||||
rfAntenna.Polarization = "Vertical";
|
||||
rfAntenna.VBeamWidth = "16";
|
||||
rfAntenna.HBeamWidth = "360";
|
||||
rfAntenna.DownTilt = "0";
|
||||
rfAntenna.AntennaGain = "6";
|
||||
break;
|
||||
case "LT OD9-6 860-960 MHz":
|
||||
rfAntenna.AntennaModel = "LT OD9-6 860-960 MHz";
|
||||
rfAntenna.AntennaType = "Omni";
|
||||
rfAntenna.Polarization = "Vertical";
|
||||
rfAntenna.VBeamWidth = "16";
|
||||
rfAntenna.HBeamWidth = "360";
|
||||
rfAntenna.DownTilt = "0";
|
||||
rfAntenna.AntennaGain = "6";
|
||||
break;
|
||||
case "LT OD9-8 865-945 MHz":
|
||||
rfAntenna.AntennaModel = "LT OD9-8 865-945 MHz";
|
||||
rfAntenna.AntennaType = "Omni";
|
||||
rfAntenna.Polarization = "Vertical";
|
||||
rfAntenna.VBeamWidth = "10";
|
||||
rfAntenna.HBeamWidth = "360";
|
||||
rfAntenna.DownTilt = "0";
|
||||
rfAntenna.AntennaGain = "8";
|
||||
break;
|
||||
case "LT OD9-8 860-960 MHz":
|
||||
rfAntenna.AntennaModel = "LT OD9-8 860-960 MHz";
|
||||
rfAntenna.AntennaType = "Omni";
|
||||
rfAntenna.Polarization = "Vertical";
|
||||
rfAntenna.VBeamWidth = "10";
|
||||
rfAntenna.HBeamWidth = "360";
|
||||
rfAntenna.DownTilt = "0";
|
||||
rfAntenna.AntennaGain = "8";
|
||||
break;
|
||||
case "LT OD9-11 860-960 MHz":
|
||||
rfAntenna.AntennaModel = "LT OD9-11 860-960 MHz";
|
||||
rfAntenna.AntennaType = "Omni";
|
||||
rfAntenna.Polarization = "Vertical";
|
||||
rfAntenna.VBeamWidth = "7";
|
||||
rfAntenna.HBeamWidth = "360";
|
||||
rfAntenna.DownTilt = "0";
|
||||
rfAntenna.AntennaGain = "11";
|
||||
break;
|
||||
case "LT OD9-11D1 860-960 MHz":
|
||||
rfAntenna.AntennaModel = "LT OD9-11D1 860-960 MHz";
|
||||
rfAntenna.AntennaType = "Omni";
|
||||
rfAntenna.Polarization = "Vertical";
|
||||
rfAntenna.VBeamWidth = "7";
|
||||
rfAntenna.HBeamWidth = "360";
|
||||
rfAntenna.DownTilt = "1";
|
||||
rfAntenna.AntennaGain = "11";
|
||||
break;
|
||||
default:
|
||||
rfAntenna.AntennaModel = "LT OD9-5 890-950 MHz";
|
||||
rfAntenna.AntennaType = "Omni";
|
||||
rfAntenna.Polarization = "Vertical";
|
||||
rfAntenna.VBeamWidth = "36";
|
||||
rfAntenna.HBeamWidth = "360";
|
||||
rfAntenna.DownTilt = "0";
|
||||
rfAntenna.AntennaGain = "5";
|
||||
break;
|
||||
}
|
||||
return rfAntenna;
|
||||
}
|
||||
}
|
||||
}
|
||||
275
software/cnip/cnip/Models/settings.cs
Normal file
275
software/cnip/cnip/Models/settings.cs
Normal file
@@ -0,0 +1,275 @@
|
||||
using System.Data;
|
||||
using static cnip.Models.pgsql;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
class settings
|
||||
{
|
||||
public struct Settings
|
||||
{
|
||||
|
||||
public string Pl_MeasurementType { get; set; }
|
||||
public string Pl_TerrainResolution { get; set; }
|
||||
public string Pl_Thematic { get; set; }
|
||||
public string Pl_Radius { get; set; }
|
||||
public string Pl_PropagationModel { get; set; }
|
||||
public string Pl_ReliabilityS { get; set; }
|
||||
public string Pl_ReliabilityT { get; set; }
|
||||
public string Pl_TerrainConductivity { get; set; }
|
||||
public string Pl_RadioClimate { get; set; }
|
||||
public string Pl_ReceiverHeight { get; set; }
|
||||
public string Pl_ReceiverGain { get; set; }
|
||||
public string Pl_ReceiverSensitivity { get; set; }
|
||||
public string Rp_AntennaModel { get; set; }
|
||||
public string Rp_CellRadius { get; set; }
|
||||
public string Rp_GSMBand { get; set; }
|
||||
public string Rp_GSMBandwidth { get; set; }
|
||||
public string Rp_LTEBand { get; set; }
|
||||
public string Rp_LTEBandwidth { get; set; }
|
||||
public string Mw_Frequency { get; set; }
|
||||
public string Mw_Channelwidth { get; set; }
|
||||
public string Mw_OutputPower { get; set; }
|
||||
public string Mw_AntennaGain { get; set; }
|
||||
public string Mw_Losses { get; set; }
|
||||
public string Mw_FresnelClearance { get; set; }
|
||||
public string EarthDielectricConstant { get; set; }
|
||||
public string EarthConductivity { get; set; }
|
||||
public string RadioClimateNumber { get; set; }
|
||||
public string AtmosphericBendingConstant { get; set; }
|
||||
public string ThematicBaseType { get; set; }
|
||||
public string ThematicExtension { get; set; }
|
||||
public string Resolution { get; set; }
|
||||
public double XPixelSize { get; set; }
|
||||
public double YPixelSize { get; set; }
|
||||
|
||||
public void SetPl_MeasurementType(string pl_measurementType)
|
||||
{
|
||||
Pl_MeasurementType = pl_measurementType;
|
||||
ThematicBaseType =
|
||||
Pl_MeasurementType == "Received Power (dBm)" ? "trp" :
|
||||
Pl_MeasurementType == "Field Strength (dBµV/m)" ? "tfs" : "tpl";
|
||||
ThematicExtension =
|
||||
Pl_MeasurementType == "Received Power (dBm)" ? "trp" :
|
||||
Pl_MeasurementType == "Field Strength (dBµV/m)" ? "tfs" :
|
||||
Pl_MeasurementType == "Path Loss (dB)" ? "tfs" :
|
||||
Pl_MeasurementType == "SNR (dB)" ? "tsn" :
|
||||
Pl_MeasurementType == "Voice Quality Score" ? "tvq" :
|
||||
Pl_MeasurementType == "Data Rate Score" ? "tdr" : "tpl";
|
||||
}
|
||||
|
||||
public Settings(string puid)
|
||||
{
|
||||
// default values
|
||||
Pl_MeasurementType = "Received Power (dBm)";
|
||||
Pl_TerrainResolution = "90m";
|
||||
Pl_Thematic = "default";
|
||||
Pl_Radius = "1.5";
|
||||
Pl_PropagationModel = "ITWOM 3.0 (< 20GHz)";
|
||||
Pl_ReliabilityS = "50";
|
||||
Pl_ReliabilityT = "90";
|
||||
Pl_TerrainConductivity = "Average ground";
|
||||
Pl_RadioClimate = "Maritime Temperate (Land)";
|
||||
Pl_ReceiverHeight = "1.5";
|
||||
Pl_ReceiverGain = "2.14";
|
||||
Pl_ReceiverSensitivity = "-90";
|
||||
Rp_AntennaModel = "LT OD9-5 890-950 MHz";
|
||||
Rp_CellRadius = "1.5";
|
||||
Rp_GSMBand = "GSM900 PGSM";
|
||||
Rp_GSMBandwidth = "0.2";
|
||||
Rp_LTEBand = "B08_FDD_900 E-GSM";
|
||||
Rp_LTEBandwidth = "10";
|
||||
Mw_Frequency = "5";
|
||||
Mw_Channelwidth = "20";
|
||||
Mw_OutputPower = "47";
|
||||
Mw_AntennaGain = "22.5";
|
||||
Mw_Losses = "0";
|
||||
Mw_FresnelClearance = "60";
|
||||
// dependent variables
|
||||
Resolution = Pl_TerrainResolution == "90m" ? "sd" : "hd";
|
||||
XPixelSize = Pl_TerrainResolution == "90m" ?
|
||||
0.0008333333333333333868 : 0.0002777777777777777775;
|
||||
YPixelSize = Pl_TerrainResolution == "90m" ?
|
||||
-0.0008333333333333333868 : -0.0002777777777777777775;
|
||||
ThematicBaseType =
|
||||
Pl_MeasurementType == "Received Power (dBm)" ? "trp" :
|
||||
Pl_MeasurementType == "Field Strength (dBµV/m)" ? "tfs" : "tpl";
|
||||
ThematicExtension =
|
||||
Pl_MeasurementType == "Received Power (dBm)" ? "trp" :
|
||||
Pl_MeasurementType == "Field Strength (dBµV/m)" ? "tfs" :
|
||||
Pl_MeasurementType == "Path Loss (dB)" ? "tfs" :
|
||||
Pl_MeasurementType == "SNR (dB)" ? "tsn" :
|
||||
Pl_MeasurementType == "Voice Quality Score" ? "tvq" :
|
||||
Pl_MeasurementType == "Data Rate Score" ? "tdr" : "tpl";
|
||||
EarthDielectricConstant = EarthDielectricConstant(Pl_TerrainConductivity);
|
||||
EarthConductivity = EarthConductivity(Pl_TerrainConductivity);
|
||||
RadioClimateNumber = RadioClimateNumber(Pl_RadioClimate);
|
||||
AtmosphericBendingConstant = AtmosphericBendingConstant(Pl_RadioClimate);
|
||||
|
||||
foreach (DataRow row in GetDataTableFromQuery("SELECT " +
|
||||
"pl_measurementtype, pl_terrainresolution, pl_thematic, " +
|
||||
"pl_radius, pl_propagationmodel, pl_reliabilitys, " +
|
||||
"pl_reliabilityt, pl_terrainconductivity, pl_radioclimate, " +
|
||||
"pl_receiverheight, pl_receivergain, pl_receiversensitivity, " +
|
||||
"rp_antennamodel, rp_cellradius, rp_gsmband, " +
|
||||
"rp_gsmbandwidth, rp_lteband, rp_ltebandwidth, " +
|
||||
"mw_frequency, mw_channelwidth, mw_outputpower, " +
|
||||
"mw_antennagain, mw_losses, mw_fresnelclearance " +
|
||||
"FROM puserssettings WHERE uid='" + puid + "';").Rows)
|
||||
{
|
||||
Pl_MeasurementType = row[0].ToString();
|
||||
Pl_TerrainResolution = row[1].ToString();
|
||||
Pl_Thematic = row[2].ToString();
|
||||
Pl_Radius = row[3].ToString();
|
||||
Pl_PropagationModel = row[4].ToString();
|
||||
Pl_ReliabilityS = row[5].ToString();
|
||||
Pl_ReliabilityT = row[6].ToString();
|
||||
Pl_TerrainConductivity = row[7].ToString();
|
||||
Pl_RadioClimate = row[8].ToString();
|
||||
Pl_ReceiverHeight = row[9].ToString();
|
||||
Pl_ReceiverGain = row[10].ToString();
|
||||
Pl_ReceiverSensitivity = row[11].ToString();
|
||||
Rp_AntennaModel = row[12].ToString();
|
||||
Rp_CellRadius = row[13].ToString();
|
||||
Rp_GSMBand = row[14].ToString();
|
||||
Rp_GSMBandwidth = row[15].ToString();
|
||||
Rp_LTEBand = row[16].ToString();
|
||||
Rp_LTEBandwidth = row[17].ToString();
|
||||
Mw_Frequency = row[18].ToString();
|
||||
Mw_Channelwidth = row[19].ToString();
|
||||
Mw_OutputPower = row[20].ToString();
|
||||
Mw_AntennaGain = row[21].ToString();
|
||||
Mw_Losses = row[22].ToString();
|
||||
Mw_FresnelClearance = row[23].ToString();
|
||||
// dependent variables
|
||||
Resolution = Pl_TerrainResolution == "90m" ? "sd" : "hd";
|
||||
XPixelSize = Pl_TerrainResolution == "90m" ?
|
||||
0.0008333333333333333868 : 0.0002777777777777777775;
|
||||
YPixelSize = Pl_TerrainResolution == "90m" ?
|
||||
-0.0008333333333333333868 : -0.0002777777777777777775;
|
||||
ThematicBaseType =
|
||||
Pl_MeasurementType == "Received Power (dBm)" ? "trp" :
|
||||
Pl_MeasurementType == "Field Strength (dBµV/m)" ? "tfs" : "tpl";
|
||||
ThematicExtension =
|
||||
Pl_MeasurementType == "Received Power (dBm)" ? "trp" :
|
||||
Pl_MeasurementType == "Field Strength (dBµV/m)" ? "tfs" :
|
||||
Pl_MeasurementType == "Path Loss (dB)" ? "tfs" :
|
||||
Pl_MeasurementType == "SNR (dB)" ? "tsn" :
|
||||
Pl_MeasurementType == "Voice Quality Score" ? "tvq" :
|
||||
Pl_MeasurementType == "Data Rate Score" ? "tdr" : "tpl";
|
||||
EarthDielectricConstant = EarthDielectricConstant(Pl_TerrainConductivity);
|
||||
EarthConductivity = EarthConductivity(Pl_TerrainConductivity);
|
||||
RadioClimateNumber = RadioClimateNumber(Pl_RadioClimate);
|
||||
AtmosphericBendingConstant = AtmosphericBendingConstant(Pl_RadioClimate);
|
||||
}
|
||||
}
|
||||
}
|
||||
public static string EarthDielectricConstant(string terrainConductivity)
|
||||
{
|
||||
string earthDielectricConstant = "";
|
||||
switch (terrainConductivity)
|
||||
{
|
||||
case "Salt water":
|
||||
earthDielectricConstant = "80.000"; break;
|
||||
case "Good ground":
|
||||
earthDielectricConstant = "25.000"; break;
|
||||
case "Fresh water":
|
||||
earthDielectricConstant = "80.000"; break;
|
||||
case "Marshy land":
|
||||
earthDielectricConstant = "12.000"; break;
|
||||
case "Farm land":
|
||||
earthDielectricConstant = "15.000"; break;
|
||||
case "Forest":
|
||||
earthDielectricConstant = "15.000"; break;
|
||||
case "Average ground":
|
||||
earthDielectricConstant = "15.000"; break;
|
||||
case "Mountain / Sand":
|
||||
earthDielectricConstant = "13.000"; break;
|
||||
case "City":
|
||||
earthDielectricConstant = "05.000"; break;
|
||||
case "Poor ground":
|
||||
earthDielectricConstant = "04.000"; break;
|
||||
default: earthDielectricConstant = "15.000"; break;
|
||||
}
|
||||
return earthDielectricConstant;
|
||||
}
|
||||
public static string EarthConductivity(string terrainConductivity)
|
||||
{
|
||||
string earthConductivity = "";
|
||||
switch (terrainConductivity)
|
||||
{
|
||||
case "Salt water":
|
||||
earthConductivity = "5.000"; break;
|
||||
case "Good ground":
|
||||
earthConductivity = "0.020"; break;
|
||||
case "Fresh water":
|
||||
earthConductivity = "0.010"; break;
|
||||
case "Marshy land":
|
||||
earthConductivity = "0.007"; break;
|
||||
case "Farm land":
|
||||
earthConductivity = "0.005"; break;
|
||||
case "Forest":
|
||||
earthConductivity = "0.005"; break;
|
||||
case "Average ground":
|
||||
earthConductivity = "0.005"; break;
|
||||
case "Mountain / Sand":
|
||||
earthConductivity = "0.002"; break;
|
||||
case "City":
|
||||
earthConductivity = "0.001"; break;
|
||||
case "Poor ground":
|
||||
earthConductivity = "0.001"; break;
|
||||
default: earthConductivity = "0.005"; break;
|
||||
}
|
||||
return earthConductivity;
|
||||
}
|
||||
|
||||
public static string RadioClimateNumber(string radioClimate)
|
||||
{
|
||||
string radioClimateNumber = "";
|
||||
switch (radioClimate)
|
||||
{
|
||||
case "Equatorial (Congo)":
|
||||
radioClimateNumber = "1"; break;
|
||||
case "Continental Subtropical (Sudan)":
|
||||
radioClimateNumber = "2"; break;
|
||||
case "Maritime Subtropical (W. Africa)":
|
||||
radioClimateNumber = "3"; break;
|
||||
case "Desert (Sahara)":
|
||||
radioClimateNumber = "4"; break;
|
||||
case "Continental Temperate":
|
||||
radioClimateNumber = "5"; break;
|
||||
case "Maritime Temperate (Land)":
|
||||
radioClimateNumber = "6"; break;
|
||||
case "Maritime Temperate (Sea)":
|
||||
radioClimateNumber = "7"; break;
|
||||
default: radioClimateNumber = "5"; break;
|
||||
}
|
||||
return radioClimateNumber;
|
||||
}
|
||||
|
||||
public static string AtmosphericBendingConstant(string radioClimate)
|
||||
{
|
||||
string atmosphericBendingConstant = "";
|
||||
switch (radioClimate)
|
||||
{
|
||||
case "Equatorial (Congo)":
|
||||
atmosphericBendingConstant = "360.000"; break;
|
||||
case "Continental Subtropical (Sudan)":
|
||||
atmosphericBendingConstant = "320.000"; break;
|
||||
case "Maritime Subtropical (W. Africa)":
|
||||
atmosphericBendingConstant = "370.000"; break;
|
||||
case "Desert (Sahara)":
|
||||
atmosphericBendingConstant = "280.000"; break;
|
||||
case "Continental Temperate":
|
||||
atmosphericBendingConstant = "301.000"; break;
|
||||
case "Maritime Temperate (Land)":
|
||||
atmosphericBendingConstant = "320.000"; break;
|
||||
case "Maritime Temperate (Sea)":
|
||||
atmosphericBendingConstant = "350.000"; break;
|
||||
default: atmosphericBendingConstant = "301.000"; break;
|
||||
}
|
||||
return atmosphericBendingConstant;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
159
software/cnip/cnip/Models/site.cs
Normal file
159
software/cnip/cnip/Models/site.cs
Normal file
@@ -0,0 +1,159 @@
|
||||
using System;
|
||||
using System.Data;
|
||||
using static cnip.Models.gisext;
|
||||
using static cnip.Models.settings;
|
||||
using static cnip.Models.pgsql;
|
||||
using static cnip.Models.generic;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
public static class site
|
||||
{
|
||||
public struct Site
|
||||
{
|
||||
public string Puid { get; set; }
|
||||
public string Siteid { get; set; }
|
||||
public string SiteName { get; set; }
|
||||
public string Latitude { get; set; }
|
||||
public string Longitude { get; set; }
|
||||
public string HBA { get; set; }
|
||||
public string Frequency { get; set; }
|
||||
public string Polarization { get; set; }
|
||||
public string PolarizationNumber { get; set; }
|
||||
public string EIRP { get; set; }
|
||||
public string AntennaType { get; set; }
|
||||
public string AntennaModel { get; set; }
|
||||
public double AntennaGain { get; set; }
|
||||
public double FeederLoss { get; set; }
|
||||
public double RfPower { get; set; }
|
||||
public string Azimuth { get; set; }
|
||||
public string DownTilt { get; set; }
|
||||
public double Bandwidth { get; set; }
|
||||
public string SnrFactor { get; set; }
|
||||
public string Technology { get; set; }
|
||||
public string Height { get; set; }
|
||||
public Coords Location;
|
||||
|
||||
public Site(string puid, string siteid)
|
||||
{
|
||||
Settings settings = new Settings(puid);
|
||||
Puid = "";
|
||||
Siteid = "";
|
||||
SiteName = "";
|
||||
Latitude = "";
|
||||
Longitude = "";
|
||||
HBA = "";
|
||||
Frequency = "";
|
||||
Polarization = "";
|
||||
PolarizationNumber = "";
|
||||
EIRP = "";
|
||||
AntennaType = "";
|
||||
AntennaModel = "";
|
||||
AntennaGain = 0;
|
||||
FeederLoss = 0;
|
||||
RfPower = 0;
|
||||
Azimuth = "";
|
||||
DownTilt = "";
|
||||
Bandwidth = 0;
|
||||
SnrFactor = "";
|
||||
Technology = "";
|
||||
Height = "";
|
||||
Location = new Coords(0, 0);
|
||||
foreach (DataRow row in GetDataTableFromQuery("SELECT " +
|
||||
"siteid, sitename, latitude, longitude*-1, " +
|
||||
"hba, dlfrequency, polarization, rfpower, " +
|
||||
"antennatype, azimuth, downtilt, antennamodel, " +
|
||||
"antennagain, feederloss, bandwidth, technology, height " +
|
||||
"FROM pusersnetwork WHERE uid = '" + puid + "' AND " +
|
||||
"siteid = '" + siteid + "';").Rows)
|
||||
{
|
||||
Puid = puid;
|
||||
Siteid = row[0].ToString();
|
||||
SiteName = row[1].ToString();
|
||||
Latitude = row[2].ToString();
|
||||
Longitude = row[3].ToString();
|
||||
HBA = row[4].ToString() + " m ";
|
||||
Frequency = row[5].ToString();
|
||||
Polarization = row[6].ToString();
|
||||
RfPower = row[7].ToString().ToDouble();
|
||||
AntennaType = row[8].ToString().ToLower();
|
||||
Azimuth = row[9].ToString();
|
||||
DownTilt = row[10].ToString();
|
||||
AntennaModel = row[11].ToString();
|
||||
AntennaGain = row[12].ToString().ToDouble();
|
||||
FeederLoss = row[13].ToString().ToDouble();
|
||||
Bandwidth = row[14].ToString().ToDouble() * 1000000; // unit hertz
|
||||
Technology = row[15].ToString();
|
||||
Height = row[16].ToString();
|
||||
// dependent variables , calculated
|
||||
PolarizationNumber =
|
||||
Polarization.ToLower() == "vertical" ? "1" : "0";
|
||||
// rfpower (W) + antennagain (dBi) - feederloss (dB) + recievergain (dBi)
|
||||
EIRP = DbmToWatt(WattToDbm(RfPower) + AntennaGain - FeederLoss +
|
||||
settings.Pl_ReceiverGain.ToDouble()).ToString();
|
||||
double eirpdbW = WattToDbm(EIRP.ToDouble()) - 30;
|
||||
double noisedbW = -174 + (10 * Math.Log10(Bandwidth)) - 30;
|
||||
SnrFactor = (eirpdbW - noisedbW).ToString();
|
||||
Location = new Coords(Longitude.ToDouble() * -1, Latitude.ToDouble());
|
||||
}
|
||||
}
|
||||
public Site(
|
||||
string puid,
|
||||
string siteid,
|
||||
Coords location)
|
||||
{
|
||||
Puid = puid;
|
||||
Siteid = siteid;
|
||||
Location = location;
|
||||
SiteName = "";
|
||||
Latitude = "";
|
||||
Longitude = "";
|
||||
HBA = "";
|
||||
Frequency = "";
|
||||
Polarization = "";
|
||||
PolarizationNumber = "";
|
||||
EIRP = "";
|
||||
AntennaType = "";
|
||||
AntennaModel = "";
|
||||
AntennaGain = 0;
|
||||
FeederLoss = 0;
|
||||
RfPower = 0;
|
||||
Azimuth = "";
|
||||
DownTilt = "";
|
||||
Bandwidth = 0;
|
||||
SnrFactor = "";
|
||||
Technology = "";
|
||||
Height = "";
|
||||
}
|
||||
public Site(
|
||||
string puid,
|
||||
string siteid,
|
||||
double x,
|
||||
double y)
|
||||
{
|
||||
Puid = puid;
|
||||
Siteid = siteid;
|
||||
Location = new Coords(x, y);
|
||||
SiteName = "";
|
||||
Latitude = "";
|
||||
Longitude = "";
|
||||
HBA = "";
|
||||
Frequency = "";
|
||||
Polarization = "";
|
||||
PolarizationNumber = "";
|
||||
EIRP = "";
|
||||
AntennaType = "";
|
||||
AntennaModel = "";
|
||||
AntennaGain = 0;
|
||||
FeederLoss = 0;
|
||||
RfPower = 0;
|
||||
Azimuth = "";
|
||||
DownTilt = "";
|
||||
Bandwidth = 0;
|
||||
SnrFactor = "";
|
||||
Technology = "";
|
||||
Height = "";
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
68
software/cnip/cnip/Models/strext.cs
Normal file
68
software/cnip/cnip/Models/strext.cs
Normal file
@@ -0,0 +1,68 @@
|
||||
using System;
|
||||
|
||||
namespace cnip.Models
|
||||
{
|
||||
public static class strext
|
||||
{
|
||||
public static int ToInt(this string value)
|
||||
{
|
||||
int parsedInt;
|
||||
if (int.TryParse(value, out parsedInt))
|
||||
{
|
||||
return parsedInt;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
public static double ToDouble(this string value)
|
||||
{
|
||||
double parsedDouble;
|
||||
if (double.TryParse(value, out parsedDouble))
|
||||
{
|
||||
return parsedDouble;
|
||||
}
|
||||
return 0.0;
|
||||
}
|
||||
public static String TrimEnd(this string value, int NumChar)
|
||||
{
|
||||
if (value.Length > NumChar)
|
||||
{
|
||||
return value.Substring(0, value.Length - NumChar);
|
||||
}
|
||||
return "";
|
||||
}
|
||||
public static String Left(this string input, int length)
|
||||
{
|
||||
var result = "";
|
||||
if ((input.Length <= 0)) return result;
|
||||
if ((length > input.Length))
|
||||
{
|
||||
length = input.Length;
|
||||
}
|
||||
result = input.Substring(0, length);
|
||||
return result;
|
||||
}
|
||||
public static String Mid(this string input, int start, int length)
|
||||
{
|
||||
var result = "";
|
||||
if (((input.Length <= 0) ||
|
||||
(start >= input.Length))) return result;
|
||||
if ((start + length > input.Length))
|
||||
{
|
||||
length = (input.Length - start);
|
||||
}
|
||||
result = input.Substring(start, length);
|
||||
return result;
|
||||
}
|
||||
public static String Right(this string input, int length)
|
||||
{
|
||||
var result = "";
|
||||
if ((input.Length <= 0)) return result;
|
||||
if ((length > input.Length))
|
||||
{
|
||||
length = input.Length;
|
||||
}
|
||||
result = input.Substring((input.Length - length), length);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
}
|
||||
57
software/cnip/cnip/Models/webext.cs
Normal file
57
software/cnip/cnip/Models/webext.cs
Normal file
@@ -0,0 +1,57 @@
|
||||
using System.Web;
|
||||
namespace cnip.Models
|
||||
{
|
||||
public class webext
|
||||
{
|
||||
public static string GetUserIP()
|
||||
{
|
||||
string ipList = string.Empty;
|
||||
HttpContext context = HttpContext.Current;
|
||||
if (context.Request.Headers["True-Client-IP"] != null)
|
||||
{
|
||||
ipList = context.Request.Headers["True-Client-IP"];
|
||||
}
|
||||
else if (context.Request.Headers["X-ClientSide"] != null)
|
||||
{
|
||||
ipList = context.Request.Headers["X-ClientSide"];
|
||||
}
|
||||
if (string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
ipList = context.Request.ServerVariables["HTTP_X_FORWARDED_FOR"];
|
||||
}
|
||||
if (string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
ipList = context.Request.ServerVariables["HTTP_CLIENT_IP"];
|
||||
}
|
||||
if (string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
ipList = context.Request.ServerVariables["HTTP_X_FORWARDED"];
|
||||
}
|
||||
if (string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
ipList = context.Request.ServerVariables["HTTP_X_CLUSTER_CLIENT_IP"];
|
||||
}
|
||||
if (string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
ipList = context.Request.ServerVariables["HTTP_FORWARDED_FOR"];
|
||||
}
|
||||
if (string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
ipList = context.Request.ServerVariables["HTTP_FORWARDED"];
|
||||
}
|
||||
if (string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
ipList = context.Request.ServerVariables["HTTP_VIA"];
|
||||
}
|
||||
if (string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
ipList = context.Request.UserHostAddress;
|
||||
}
|
||||
if (!string.IsNullOrEmpty(ipList))
|
||||
{
|
||||
return ipList.Split(',')[0];
|
||||
}
|
||||
return context.Request.ServerVariables["REMOTE_ADDR"];
|
||||
}
|
||||
}
|
||||
}
|
||||
35
software/cnip/cnip/Properties/AssemblyInfo.cs
Normal file
35
software/cnip/cnip/Properties/AssemblyInfo.cs
Normal file
@@ -0,0 +1,35 @@
|
||||
using System.Reflection;
|
||||
using System.Runtime.CompilerServices;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
// General Information about an assembly is controlled through the following
|
||||
// set of attributes. Change these attribute values to modify the information
|
||||
// associated with an assembly.
|
||||
[assembly: AssemblyTitle("cnip")]
|
||||
[assembly: AssemblyDescription("")]
|
||||
[assembly: AssemblyConfiguration("")]
|
||||
[assembly: AssemblyCompany("HP Inc.")]
|
||||
[assembly: AssemblyProduct("cnip")]
|
||||
[assembly: AssemblyCopyright("Copyright © HP Inc. 2020")]
|
||||
[assembly: AssemblyTrademark("")]
|
||||
[assembly: AssemblyCulture("")]
|
||||
|
||||
// Setting ComVisible to false makes the types in this assembly not visible
|
||||
// to COM components. If you need to access a type in this assembly from
|
||||
// COM, set the ComVisible attribute to true on that type.
|
||||
[assembly: ComVisible(false)]
|
||||
|
||||
// The following GUID is for the ID of the typelib if this project is exposed to COM
|
||||
[assembly: Guid("aadcf23e-c85e-4bdf-b600-9c75aac4d402")]
|
||||
|
||||
// Version information for an assembly consists of the following four values:
|
||||
//
|
||||
// Major Version
|
||||
// Minor Version
|
||||
// Build Number
|
||||
// Revision
|
||||
//
|
||||
// You can specify all the values or you can default the Revision and Build Numbers
|
||||
// by using the '*' as shown below:
|
||||
[assembly: AssemblyVersion("1.0.0.0")]
|
||||
[assembly: AssemblyFileVersion("1.0.0.0")]
|
||||
@@ -0,0 +1,41 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!--
|
||||
This file is used by the publish/package process of your Web project. You can customize the behavior of this process
|
||||
by editing this MSBuild file. In order to learn more about this please visit https://go.microsoft.com/fwlink/?LinkID=208121.
|
||||
-->
|
||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<WebPublishMethod>MSDeploy</WebPublishMethod>
|
||||
<LastUsedBuildConfiguration>Release</LastUsedBuildConfiguration>
|
||||
<LastUsedPlatform>Any CPU</LastUsedPlatform>
|
||||
<SiteUrlToLaunchAfterPublish>
|
||||
</SiteUrlToLaunchAfterPublish>
|
||||
<LaunchSiteAfterPublish>True</LaunchSiteAfterPublish>
|
||||
<ExcludeApp_Data>False</ExcludeApp_Data>
|
||||
<MSDeployServiceURL>localhost</MSDeployServiceURL>
|
||||
<DeployIisAppPath>Default Web Site/cnip</DeployIisAppPath>
|
||||
<RemoteSitePhysicalPath />
|
||||
<SkipExtraFilesOnServer>True</SkipExtraFilesOnServer>
|
||||
<MSDeployPublishMethod>InProc</MSDeployPublishMethod>
|
||||
<EnableMSDeployBackup>False</EnableMSDeployBackup>
|
||||
<UserName />
|
||||
<_SavePWD>False</_SavePWD>
|
||||
<PublishDatabaseSettings>
|
||||
<Objects xmlns="">
|
||||
<ObjectGroup Name="cnipdb" Order="1" Enabled="False">
|
||||
<Destination Path="" />
|
||||
<Object Type="DbDacFx">
|
||||
<PreSource Path="Host=localhost;Database=cnip;Username=postgres;Password=root" includeData="False" />
|
||||
<Source Path="$(IntermediateOutputPath)AutoScripts\cnipdb_IncrementalSchemaOnly.dacpac" dacpacAction="Deploy" />
|
||||
</Object>
|
||||
<UpdateFrom Type="Web.Config">
|
||||
<Source MatchValue="Host=localhost;Database=cnip;Username=postgres;Password=root" MatchAttributes="$(UpdateFromConnectionStringAttributes)" />
|
||||
</UpdateFrom>
|
||||
</ObjectGroup>
|
||||
</Objects>
|
||||
</PublishDatabaseSettings>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<MSDeployParameterValue Include="$(DeployParameterPrefix)cnipdb-Web.config Connection String" />
|
||||
</ItemGroup>
|
||||
</Project>
|
||||
@@ -0,0 +1,11 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!--
|
||||
This file is used by the publish/package process of your Web project. You can customize the behavior of this process
|
||||
by editing this MSBuild file. In order to learn more about this please visit https://go.microsoft.com/fwlink/?LinkID=208121.
|
||||
-->
|
||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<TimeStampOfAssociatedLegacyPublishXmlFile />
|
||||
<EncryptedPassword />
|
||||
</PropertyGroup>
|
||||
</Project>
|
||||
20755
software/cnip/cnip/Scripts/Chart.bundle.js
Normal file
20755
software/cnip/cnip/Scripts/Chart.bundle.js
Normal file
File diff suppressed because it is too large
Load Diff
7
software/cnip/cnip/Scripts/Chart.bundle.min.js
vendored
Normal file
7
software/cnip/cnip/Scripts/Chart.bundle.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
47
software/cnip/cnip/Scripts/Chart.css
Normal file
47
software/cnip/cnip/Scripts/Chart.css
Normal file
@@ -0,0 +1,47 @@
|
||||
/*
|
||||
* DOM element rendering detection
|
||||
* https://davidwalsh.name/detect-node-insertion
|
||||
*/
|
||||
@keyframes chartjs-render-animation {
|
||||
from { opacity: 0.99; }
|
||||
to { opacity: 1; }
|
||||
}
|
||||
|
||||
.chartjs-render-monitor {
|
||||
animation: chartjs-render-animation 0.001s;
|
||||
}
|
||||
|
||||
/*
|
||||
* DOM element resizing detection
|
||||
* https://github.com/marcj/css-element-queries
|
||||
*/
|
||||
.chartjs-size-monitor,
|
||||
.chartjs-size-monitor-expand,
|
||||
.chartjs-size-monitor-shrink {
|
||||
position: absolute;
|
||||
direction: ltr;
|
||||
left: 0;
|
||||
top: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
overflow: hidden;
|
||||
pointer-events: none;
|
||||
visibility: hidden;
|
||||
z-index: -1;
|
||||
}
|
||||
|
||||
.chartjs-size-monitor-expand > div {
|
||||
position: absolute;
|
||||
width: 1000000px;
|
||||
height: 1000000px;
|
||||
left: 0;
|
||||
top: 0;
|
||||
}
|
||||
|
||||
.chartjs-size-monitor-shrink > div {
|
||||
position: absolute;
|
||||
width: 200%;
|
||||
height: 200%;
|
||||
left: 0;
|
||||
top: 0;
|
||||
}
|
||||
16151
software/cnip/cnip/Scripts/Chart.js
vendored
Normal file
16151
software/cnip/cnip/Scripts/Chart.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1
software/cnip/cnip/Scripts/Chart.min.css
vendored
Normal file
1
software/cnip/cnip/Scripts/Chart.min.css
vendored
Normal file
@@ -0,0 +1 @@
|
||||
@keyframes chartjs-render-animation{from{opacity:.99}to{opacity:1}}.chartjs-render-monitor{animation:chartjs-render-animation 1ms}.chartjs-size-monitor,.chartjs-size-monitor-expand,.chartjs-size-monitor-shrink{position:absolute;direction:ltr;left:0;top:0;right:0;bottom:0;overflow:hidden;pointer-events:none;visibility:hidden;z-index:-1}.chartjs-size-monitor-expand>div{position:absolute;width:1000000px;height:1000000px;left:0;top:0}.chartjs-size-monitor-shrink>div{position:absolute;width:200%;height:200%;left:0;top:0}
|
||||
7
software/cnip/cnip/Scripts/Chart.min.js
vendored
Normal file
7
software/cnip/cnip/Scripts/Chart.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
2
software/cnip/cnip/Scripts/FileSaver.min.js
vendored
Normal file
2
software/cnip/cnip/Scripts/FileSaver.min.js
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
/*! @source http://purl.eligrey.com/github/FileSaver.js/blob/master/FileSaver.js */
|
||||
var saveAs=saveAs||function(e){"use strict";if(typeof e==="undefined"||typeof navigator!=="undefined"&&/MSIE [1-9]\./.test(navigator.userAgent)){return}var t=e.document,n=function(){return e.URL||e.webkitURL||e},r=t.createElementNS("http://www.w3.org/1999/xhtml","a"),o="download"in r,a=function(e){var t=new MouseEvent("click");e.dispatchEvent(t)},i=/constructor/i.test(e.HTMLElement)||e.safari,f=/CriOS\/[\d]+/.test(navigator.userAgent),u=function(t){(e.setImmediate||e.setTimeout)(function(){throw t},0)},s="application/octet-stream",d=1e3*40,c=function(e){var t=function(){if(typeof e==="string"){n().revokeObjectURL(e)}else{e.remove()}};setTimeout(t,d)},l=function(e,t,n){t=[].concat(t);var r=t.length;while(r--){var o=e["on"+t[r]];if(typeof o==="function"){try{o.call(e,n||e)}catch(a){u(a)}}}},p=function(e){if(/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(e.type)){return new Blob([String.fromCharCode(65279),e],{type:e.type})}return e},v=function(t,u,d){if(!d){t=p(t)}var v=this,w=t.type,m=w===s,y,h=function(){l(v,"writestart progress write writeend".split(" "))},S=function(){if((f||m&&i)&&e.FileReader){var r=new FileReader;r.onloadend=function(){var t=f?r.result:r.result.replace(/^data:[^;]*;/,"data:attachment/file;");var n=e.open(t,"_blank");if(!n)e.location.href=t;t=undefined;v.readyState=v.DONE;h()};r.readAsDataURL(t);v.readyState=v.INIT;return}if(!y){y=n().createObjectURL(t)}if(m){e.location.href=y}else{var o=e.open(y,"_blank");if(!o){e.location.href=y}}v.readyState=v.DONE;h();c(y)};v.readyState=v.INIT;if(o){y=n().createObjectURL(t);setTimeout(function(){r.href=y;r.download=u;a(r);h();c(y);v.readyState=v.DONE});return}S()},w=v.prototype,m=function(e,t,n){return new v(e,t||e.name||"download",n)};if(typeof navigator!=="undefined"&&navigator.msSaveOrOpenBlob){return function(e,t,n){t=t||e.name||"download";if(!n){e=p(e)}return navigator.msSaveOrOpenBlob(e,t)}}w.abort=function(){};w.readyState=w.INIT=0;w.WRITING=1;w.DONE=2;w.error=w.onwritestart=w.onprogress=w.onwrite=w.onabort=w.onerror=w.onwriteend=null;return m}(typeof self!=="undefined"&&self||typeof window!=="undefined"&&window||this.content);if(typeof module!=="undefined"&&module.exports){module.exports.saveAs=saveAs}else if(typeof define!=="undefined"&&define!==null&&define.amd!==null){define("FileSaver.js",function(){return saveAs})}
|
||||
7
software/cnip/cnip/Scripts/bootstrap.4.1.1/bootstrap.min.css
vendored
Normal file
7
software/cnip/cnip/Scripts/bootstrap.4.1.1/bootstrap.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
7
software/cnip/cnip/Scripts/bootstrap.4.1.1/bootstrap.min.js
vendored
Normal file
7
software/cnip/cnip/Scripts/bootstrap.4.1.1/bootstrap.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
2377
software/cnip/cnip/Scripts/bootstrap.js
vendored
Normal file
2377
software/cnip/cnip/Scripts/bootstrap.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7
software/cnip/cnip/Scripts/bootstrap.min.js
vendored
Normal file
7
software/cnip/cnip/Scripts/bootstrap.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
182
software/cnip/cnip/Scripts/cnip/acc/accsrv.js
Normal file
182
software/cnip/cnip/Scripts/cnip/acc/accsrv.js
Normal file
@@ -0,0 +1,182 @@
|
||||
// Account activation messages
|
||||
if (pmsg === 'activate : account already activated' || pmsg === 'activate : account activated successfully') {
|
||||
document.getElementById('th1').innerHTML = 'Your account has been activated successfully';
|
||||
document.getElementById('sh1').innerHTML = 'You can now login to your account using your email address and password. Please click Login to login to your account.';
|
||||
document.getElementById('th2').innerHTML = 'Activate 2-Step Verification?';
|
||||
document.getElementById('sh2').innerHTML = '2-step Verification adds another layer of security to prevent unauthorized access to your account. Please click the Turn On 2-Step Verification? link to activate 2-Step Verification for your account.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
document.getElementById('g2steplnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'activate : error accessing server') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Please look for the verification email in your inbox and click the link in that email. A confirmation message will appear in your web browser.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
}
|
||||
if (pmsg === 'activate : link expired') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Link expired. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Your account activation link has been expired. If your account is not activated you can reset your password to activate your account. Please click the Forgot your password? link to try resetting the password to activate your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
}
|
||||
// Reset password messages
|
||||
if (pmsg === 'resetpassword : password changed successfully') {
|
||||
document.getElementById('th1').innerHTML = 'Your password has been changed successfully';
|
||||
document.getElementById('sh1').innerHTML = 'You can now login to your account using your email address and password. Please click Login to login to your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = '';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
}
|
||||
if (pmsg === 'resetpassword : error accessing server') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Please look for the reset password email in your inbox and click the link in that email. New password request form will appear in your web browser.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
}
|
||||
if (pmsg === 'resetpassword : link expired') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Link expired. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Your password reset link has been expired. Please click the Forgot your password? link to try resetting your password.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
}
|
||||
// turn off 2-step verification messages
|
||||
if (pmsg === 'turnoff2step : 2-Step Verification turned off') {
|
||||
document.getElementById('th1').innerHTML = '2-Step Verification deactivated successfully';
|
||||
document.getElementById('sh1').innerHTML = 'You can now login to your account using your email address and password. Please click Login to login to your account.';
|
||||
document.getElementById('th2').innerHTML = 'Activate 2-Step Verification?';
|
||||
document.getElementById('sh2').innerHTML = '2-step Verification adds another layer of security to prevent unauthorized access to your account. Please click the Turn On 2-Step Verification? link to activate 2-Step Verification for your account.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
document.getElementById('g2steplnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'turnoff2step : error accessing server') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Please look for the deactivate 2-Step Verification email in your inbox and click the link in that email. A confirmation message will appear in your web browser.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
}
|
||||
if (pmsg === 'turnoff2step : link expired') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Link expired. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Your deactivate 2-Step Verification link has been expired. Please click the Turn Off 2-Step Verification? link to try deactivating 2-Step Verification for your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('lostlnk').hidden = false;
|
||||
}
|
||||
// turn on 2-step verification messages
|
||||
if (pmsg === 'turnon2stepact : email not registered or invalid password') {
|
||||
document.getElementById('th1').innerHTML = 'Email address not registered or Invalid password';
|
||||
document.getElementById('sh1').innerHTML = 'Make sure you entered the correct email address and password. Pease click Turn On 2-Step Verification? link to try activating 2-Step Verification for your account.';
|
||||
document.getElementById('th2').innerHTML = 'Don\'t have an account or Forgot your password?';
|
||||
document.getElementById('sh2').innerHTML = '1. Click Sign Up to create your free account.<br/>2. Click the Forgot your password? link if you don\'t remember your password.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Sign Up';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=signup';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
document.getElementById('g2steplnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'turnon2stepact : 2-Step Verification already setup') {
|
||||
document.getElementById('th1').innerHTML = '2-Step Verification is already activated for your account';
|
||||
document.getElementById('sh1').innerHTML = 'In addition to your password, you\'ll also need a code generated by the Google Authenticator app on your device. Please click Login to login to your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = '';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
}
|
||||
if (pmsg === 'turnon2stepact : error accessing server' || pmsg === 'turnon2step : error accessing server') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = '2-step Verification adds another layer of security to prevent unauthorized access to your account. Please click the Turn On 2-Step Verification? link to activate 2-Step Verification for your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = '';
|
||||
document.getElementById('g2steplnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'turnon2step : 2-Step Verification turned on') {
|
||||
document.getElementById('th1').innerHTML = '2-Step Verification has been activated for your account successfully';
|
||||
document.getElementById('sh1').innerHTML = 'In addition to your password, you\'ll also need a code generated by the Google Authenticator app on your device. Please click Login to login to your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = '';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
}
|
||||
if (pmsg === 'turnon2step : link expired') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Link expired. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Your activate 2-Step Verification link has been expired. Please click the Turn On 2-Step Verification? link to try activating 2-Step Verification for your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('btn').hidden = true;
|
||||
document.getElementById('g2steplnk').hidden = false;
|
||||
}
|
||||
// login messages
|
||||
if (pmsg === 'loginact : account suspended') {
|
||||
document.getElementById('th1').innerHTML = 'Your account has been suspended';
|
||||
document.getElementById('sh1').innerHTML = 'Your account may have been suspended due to multiple unsuccessful login attempts. This is an automated security feature and cannot be disabled.';
|
||||
document.getElementById('sh2').innerHTML = 'Please click the Forgot your password? link to reset password and un-suspend your account.';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'login : login successful') {
|
||||
document.getElementById('th1').innerHTML = 'login successful';
|
||||
}
|
||||
if (pmsg === 'login : invalid passcode') {
|
||||
document.getElementById('th1').innerHTML = 'You have entered an invalid passcode, please try again';
|
||||
document.getElementById('sh1').innerHTML = 'Please click Login to try login to your account.';
|
||||
document.getElementById('th2').innerHTML = 'Lost your 2-Step Verification device?';
|
||||
document.getElementById('sh2').innerHTML = 'Please click the Turn Off 2-Step Verification? link to deactivate 2-Step Verification for your account.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
document.getElementById('lostlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'login : invalid password') {
|
||||
document.getElementById('th1').innerHTML = 'You have entered an invalid password, please try again';
|
||||
document.getElementById('sh1').innerHTML = 'Please click Login to try login to your account.';
|
||||
document.getElementById('th2').innerHTML = 'Lost your password?';
|
||||
document.getElementById('sh2').innerHTML = 'Please click the Forgot your password? link to reset your password.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'login : link expired') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Link expired. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Your login link has been expired. Please click Login to try login to your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
}
|
||||
if (pmsg === 'login : error accessing server' || pmsg === 'loginact : error accessing server') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Please click Login to try login to your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
}
|
||||
if (pmsg === 'loginact : email not registered') {
|
||||
document.getElementById('th1').innerHTML = 'Email address not registered';
|
||||
document.getElementById('sh1').innerHTML = 'We didn\'t find any account associated with your email address. Please make sure you entered the correct email address. Please click Login to try login to your account.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
}
|
||||
if (pmsg === 'loginact : account not active') {
|
||||
document.getElementById('th1').innerHTML = 'Your account is not activated';
|
||||
document.getElementById('sh1').innerHTML = 'Please look for the verification email in your inbox and click the link in that email. A confirmation message will appear in your web browser.';
|
||||
document.getElementById('th2').innerHTML = 'Didn\'t get the email?';
|
||||
document.getElementById('sh2').innerHTML = 'Check your spam folder to make sure it didn\'t end up there. You can also add the email address opencellularcnip@gmail.com to your address book and then try sending the email again.' +
|
||||
'<br /><br />' +
|
||||
'If you\'re still not able to find the email, please send an email to us at opencellularcnip@gmail.com';
|
||||
}
|
||||
if (pmsg === 'blank form submitted') {
|
||||
document.getElementById('th1').innerHTML = 'Blank form submitted';
|
||||
}
|
||||
119
software/cnip/cnip/Scripts/cnip/acc/accsrvrq.js
Normal file
119
software/cnip/cnip/Scripts/cnip/acc/accsrvrq.js
Normal file
@@ -0,0 +1,119 @@
|
||||
if (pmsg === 'turnoff2step : account not active') {
|
||||
document.getElementById('th1').innerHTML = 'Your account is not activated';
|
||||
document.getElementById('sh1').innerHTML = 'Please look for the verification email in your inbox and click the link in that email. A confirmation message will appear in your web browser.';
|
||||
document.getElementById('th2').innerHTML = 'Didn\'t get the email?';
|
||||
document.getElementById('sh2').innerHTML = 'Check your spam folder to make sure it didn\'t end up there. You can also add the email address opencellularcnip@gmail.com to your address book and then try sending the email again.' +
|
||||
'<br /><br />' +
|
||||
'If you\'re still not able to find the email, please send an email to us at opencellularcnip@gmail.com';
|
||||
}
|
||||
if (pmsg === 'turnoff2step : 2-Step Verification not setup') {
|
||||
document.getElementById('th1').innerHTML = '2-Step Verification is not activated for your account';
|
||||
document.getElementById('sh1').innerHTML = '';
|
||||
document.getElementById('th2').innerHTML = 'Activate 2-Step Verification?';
|
||||
document.getElementById('sh2').innerHTML = '2-step Verification adds another layer of security to prevent unauthorized access to your account. Please click the Turn On 2-Step Verification? link to activate 2-Step Verification for your account.';
|
||||
document.getElementById('g2steplnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'turnoff2step : turn off 2-Step Verification link sent') {
|
||||
document.getElementById('th1').innerHTML = 'A link has been sent to your email address to deactivate 2-Step Verification for your account';
|
||||
document.getElementById('sh1').innerHTML = 'Please look for the deactivate 2-Step Verification email in your inbox and click the link in that email. A confirmation message will appear in your web browser.';
|
||||
document.getElementById('th2').innerHTML = 'Didn\'t get the email?';
|
||||
document.getElementById('sh2').innerHTML = 'Check your spam folder to make sure it didn\'t end up there. You can also add the email address opencellularcnip@gmail.com to your address book and then try sending the email again.' +
|
||||
'<br /><br />' +
|
||||
'If you\'re still not receiving the email, please send an email to us at opencellularcnip@gmail.com';
|
||||
}
|
||||
if (pmsg === 'turnoff2step : error accessing server') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Please click the Turn Off 2-Step Verification? link to try deactivating 2-Step Verification for your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('lostlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'turnoff2step : failed to send email') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'We are unable to send deactivate 2-Step Verification link to your email address at this time. Please click the Turn Off 2-Step Verification? link to try deactivating 2-Step Verification for your account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('lostlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'turnoff2step : email not registered or invalid password') {
|
||||
document.getElementById('th1').innerHTML = 'Email address not registered or Invalid password';
|
||||
document.getElementById('sh1').innerHTML = 'Make sure you entered the correct email address and password. Pease click Turn Off 2-Step Verification? link to try deactivating 2-Step Verification for your account.';
|
||||
document.getElementById('th2').innerHTML = 'Don\'t have an account or Forgot your password?';
|
||||
document.getElementById('sh2').innerHTML = '1. Click Sign Up to create your free account.<br/>2. Click the Forgot your password? link if you don\'t remember your password.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Sign Up';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=signup';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
document.getElementById('lostlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'resetpassword : email not registered') {
|
||||
document.getElementById('th1').innerHTML = 'Email address not registered';
|
||||
document.getElementById('sh1').innerHTML = 'We didn\'t find any account associated with your email address. Please make sure you entered the correct email address. Please click the Forgot your password? link to try resetting your password.';
|
||||
document.getElementById('th2').innerHTML = 'Don\'t have an account?';
|
||||
document.getElementById('sh2').innerHTML = 'Please click Sign Up to create your free account.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Sign Up';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=signup';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'resetpassword : link sent') {
|
||||
document.getElementById('th1').innerHTML = 'A reset password link has been sent to your email address';
|
||||
document.getElementById('sh1').innerHTML = 'Please look for the reset password email in your inbox and click the link in that email. New password request form will appear in your web browser.';
|
||||
document.getElementById('th2').innerHTML = 'Didn\'t get the email?';
|
||||
document.getElementById('sh2').innerHTML = 'Check your spam folder to make sure it didn\'t end up there. You can also add the email address opencellularcnip@gmail.com to your address book and then try sending the email again.' +
|
||||
'<br /><br />' +
|
||||
'If you\'re still not receiving the email, please send an email to us at opencellularcnip@gmail.com';
|
||||
}
|
||||
if (pmsg === 'resetpassword : failed to send email') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'We are unable to send reset password link to your email address at this time. Please click the Forgot your password? link to try resetting your password.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'resetpassword : error accessing server') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'Please click the Forgot your password? link to try resetting your password.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'signup : email address already registered') {
|
||||
document.getElementById('th1').innerHTML = 'Email address already in use';
|
||||
document.getElementById('sh1').innerHTML = 'There\'s already an account associated with your email address, if you don\'t own that account, please send an email to us at opencellularcnip@gmail.com.';
|
||||
document.getElementById('th2').innerHTML = 'To access your account:';
|
||||
document.getElementById('sh2').innerHTML = '1. Click Login.<br/>2. Click the Forgot your password? link if you don\'t remember your password.';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Login';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=login';
|
||||
document.getElementById('forgotlnk').hidden = false;
|
||||
}
|
||||
if (pmsg === 'signup : user created successfully') {
|
||||
document.getElementById('th1').innerHTML = 'A verfication link has been sent to your email address';
|
||||
document.getElementById('sh1').innerHTML = 'Please look for the verification email in your inbox and click the link in that email. A confirmation message will appear in your web browser.';
|
||||
document.getElementById('th2').innerHTML = 'Didn\'t get the email?';
|
||||
document.getElementById('sh2').innerHTML = 'Check your spam folder to make sure it didn\'t end up there. You can also add the email address opencellularcnip@gmail.com to your address book and then try sending the email again.' +
|
||||
'<br /><br />' +
|
||||
'If you\'re still not receiving the email, please send an email to us at opencellularcnip@gmail.com';
|
||||
}
|
||||
if (pmsg === 'signup : failed to send email') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'We are unable to send verification link to your email address. Please make sure you typed the correct email address. Please click Sign Up to try creating your free account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Sign Up';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=signup';
|
||||
}
|
||||
if (pmsg === 'signup : error accessing server') {
|
||||
document.getElementById('th1').innerHTML = 'Oops. Something went wrong. Please try again later';
|
||||
document.getElementById('sh1').innerHTML = 'We are unable to successfully complete your registration at this time. Please click Sign Up to try creating your free account.';
|
||||
document.getElementById('th2').innerHTML = '';
|
||||
document.getElementById('sh2').innerHTML = 'If you continue facing this issue, please send an email to us at opencellularcnip@gmail.com';
|
||||
document.getElementById('btn').hidden = false;
|
||||
document.getElementById('btn').value = 'Sign Up';
|
||||
document.getElementById('btnlnk').href = 'accui.aspx?uaction=signup';
|
||||
}
|
||||
if (pmsg === 'blank form submitted') {
|
||||
document.getElementById('th1').innerHTML = 'Blank form submitted';
|
||||
}
|
||||
199
software/cnip/cnip/Scripts/cnip/acc/accui.js
Normal file
199
software/cnip/cnip/Scripts/cnip/acc/accui.js
Normal file
@@ -0,0 +1,199 @@
|
||||
if (puaction === 'login') {
|
||||
document.title = 'cnip - Login';
|
||||
document.getElementById('headl3').hidden = false;
|
||||
document.getElementById('headl3').innerHTML = 'Sign In';
|
||||
document.getElementById('pname').disabled = true;
|
||||
document.getElementById('pcompany').disabled = true;
|
||||
document.getElementById('pemaili').hidden = false;
|
||||
document.getElementById('pemail').hidden = false;
|
||||
document.getElementById('pemail').disabled = false;
|
||||
document.getElementById('pemail').focus();
|
||||
document.getElementById('pemail').select();
|
||||
document.getElementById('ppassword').disabled = true;
|
||||
document.getElementById('ppasscode').disabled = true;
|
||||
document.getElementById('btnSubmit').value = 'Login';
|
||||
document.getElementById('signuplnk').hidden = false;
|
||||
document.getElementById('signupllnk').hidden = false;
|
||||
document.getElementById('resetpasswordlnk').hidden = false;
|
||||
document.getElementById('turnon2steplnk').hidden = false;
|
||||
document.getElementById('turnoff2steplnk').hidden = false;
|
||||
}
|
||||
if (puaction === 'loginact') {
|
||||
document.title = 'cnip - Login';
|
||||
document.getElementById('headl3').hidden = false;
|
||||
document.getElementById('headl3').innerHTML = 'Sign In';
|
||||
document.getElementById('pname').disabled = true;
|
||||
document.getElementById('pcompany').disabled = true;
|
||||
document.getElementById('pemail').disabled = true;
|
||||
document.getElementById('ppasswordi').hidden = false;
|
||||
document.getElementById('ppassword').hidden = false;
|
||||
document.getElementById('ppassword').disabled = false;
|
||||
document.getElementById('ppassword').focus();
|
||||
document.getElementById('ppassword').select();
|
||||
g2stepen = p2stepen;
|
||||
if (g2stepen === 'true') {
|
||||
document.getElementById('ppasscodei').hidden = false;
|
||||
document.getElementById('ppasscode').hidden = false;
|
||||
document.getElementById('ppasscode').disabled = false;
|
||||
}
|
||||
else {
|
||||
document.getElementById('ppasscode').disabled = true;
|
||||
}
|
||||
loginattempt = loginattempt;
|
||||
document.getElementById('loginl').hidden = false;
|
||||
document.getElementById('loginc').hidden = false;
|
||||
document.getElementById('loginc').innerHTML = '<br/><br/>Login Attempt : ' + loginattempt;
|
||||
document.getElementById('btnSubmit').value = 'Login';
|
||||
document.getElementById('resetpasswordlnk').hidden = false;
|
||||
document.getElementById('turnoff2steplnk').hidden = false;
|
||||
}
|
||||
if (puaction === 'signup') {
|
||||
document.title = 'cnip - Sign Up';
|
||||
document.getElementById('headl3').hidden = false;
|
||||
document.getElementById('headl3').innerHTML = 'Sign Up';
|
||||
document.getElementById('pnamei').hidden = false;
|
||||
document.getElementById('pname').hidden = false;
|
||||
document.getElementById('pname').disabled = false;
|
||||
document.getElementById('pname').focus();
|
||||
document.getElementById('pname').select();
|
||||
document.getElementById('pcompanyi').hidden = false;
|
||||
document.getElementById('pcompany').hidden = false;
|
||||
document.getElementById('pcompany').disabled = false;
|
||||
document.getElementById('pemaili').hidden = false;
|
||||
document.getElementById('pemail').hidden = false;
|
||||
document.getElementById('pemail').disabled = false;
|
||||
document.getElementById('ppasswordi').hidden = false;
|
||||
document.getElementById('ppassword').hidden = false;
|
||||
document.getElementById('ppassword').disabled = false;
|
||||
document.getElementById('ppasscode').disabled = true;
|
||||
document.getElementById('btnSubmit').value = 'Submit';
|
||||
document.getElementById('loginllnk').hidden = false;
|
||||
document.getElementById('loginlnk').hidden = false;
|
||||
}
|
||||
if (puaction === 'resetpassword') {
|
||||
document.title = 'cnip - Reset Password';
|
||||
document.getElementById('headl5').hidden = false;
|
||||
document.getElementById('headl5').innerHTML = 'Reset Password';
|
||||
document.getElementById('pname').disabled = true;
|
||||
document.getElementById('pcompany').disabled = true;
|
||||
document.getElementById('pemaili').hidden = false;
|
||||
document.getElementById('pemail').hidden = false;
|
||||
document.getElementById('pemail').disabled = false;
|
||||
document.getElementById('pemail').focus();
|
||||
document.getElementById('pemail').select();
|
||||
document.getElementById('ppassword').disabled = true;
|
||||
document.getElementById('ppasscode').disabled = true;
|
||||
document.getElementById('btnSubmit').value = 'Submit';
|
||||
}
|
||||
if (puaction === 'resetpasswordact') {
|
||||
document.title = 'cnip - Reset Password';
|
||||
document.getElementById('headl5').hidden = false;
|
||||
document.getElementById('headl5').innerHTML = 'Reset Password';
|
||||
document.getElementById('pname').disabled = true;
|
||||
document.getElementById('pcompany').disabled = true;
|
||||
document.getElementById('pemail').disabled = true;
|
||||
document.getElementById('ppasswordi').hidden = false;
|
||||
document.getElementById('ppassword').hidden = false;
|
||||
document.getElementById('ppassword').disabled = false;
|
||||
document.getElementById('ppassword').focus();
|
||||
document.getElementById('ppassword').select();
|
||||
document.getElementById('ppasscode').disabled = true;
|
||||
document.getElementById('btnSubmit').value = 'Submit';
|
||||
}
|
||||
if (puaction === 'turnoff2step') {
|
||||
document.title = 'cnip - Turn Off 2-Step Verification';
|
||||
document.getElementById('headl5').hidden = false;
|
||||
document.getElementById('headl5').innerHTML = 'Turn Off 2-Step Verification';
|
||||
document.getElementById('pname').disabled = true;
|
||||
document.getElementById('pcompany').disabled = true;
|
||||
document.getElementById('pemaili').hidden = false;
|
||||
document.getElementById('pemail').hidden = false;
|
||||
document.getElementById('pemail').disabled = false;
|
||||
document.getElementById('pemail').focus();
|
||||
document.getElementById('pemail').select();
|
||||
document.getElementById('ppasswordi').hidden = false;
|
||||
document.getElementById('ppassword').hidden = false;
|
||||
document.getElementById('ppassword').disabled = false;
|
||||
document.getElementById('ppasscode').disabled = true;
|
||||
document.getElementById('btnSubmit').value = 'Submit';
|
||||
}
|
||||
if (puaction === 'turnon2step') {
|
||||
document.title = 'cnip - Turn On 2-Step Verification';
|
||||
document.getElementById('headl5').hidden = false;
|
||||
document.getElementById('headl5').innerHTML = 'Turn On 2-Step Verification';
|
||||
document.getElementById('pname').disabled = true;
|
||||
document.getElementById('pcompany').disabled = true;
|
||||
document.getElementById('pemaili').hidden = false;
|
||||
document.getElementById('pemail').hidden = false;
|
||||
document.getElementById('pemail').disabled = false;
|
||||
document.getElementById('pemail').focus();
|
||||
document.getElementById('pemail').select();
|
||||
document.getElementById('ppasswordi').hidden = false;
|
||||
document.getElementById('ppassword').hidden = false;
|
||||
document.getElementById('ppassword').disabled = false;
|
||||
document.getElementById('ppasscode').disabled = true;
|
||||
document.getElementById('btnSubmit').value = 'Submit';
|
||||
document.getElementById('g2step2i').hidden = false;
|
||||
document.getElementById('g2step2l').hidden = false;
|
||||
}
|
||||
if (puaction === 'turnon2stepact') {
|
||||
document.title = 'cnip - Turn On 2-Step Verification';
|
||||
document.getElementById('headl5').hidden = false;
|
||||
document.getElementById('headl5').innerHTML = 'Turn On 2-Step Verification';
|
||||
document.getElementById('pname').disabled = true;
|
||||
document.getElementById('pcompany').disabled = true;
|
||||
document.getElementById('pemail').disabled = true;
|
||||
document.getElementById('ppassword').disabled = true;
|
||||
document.getElementById('ppasscode').disabled = true;
|
||||
document.getElementById('btnSubmit').value = 'Submit';
|
||||
document.getElementById('g2stepi').hidden = false;
|
||||
document.getElementById('g2stepl').hidden = false;
|
||||
document.getElementById('barcodeimgi').hidden = false;
|
||||
document.getElementById('barcodeimg').hidden = false;
|
||||
document.getElementById('barcodeimg').src = barcode;
|
||||
document.getElementById('setupcode').innerHTML = setupcode;
|
||||
}
|
||||
function doSubmit() {
|
||||
let vpname = document.getElementById('pname').value;
|
||||
let vpcompany = document.getElementById('pcompany').value;
|
||||
let vpemail = document.getElementById('pemail').value;
|
||||
let vppassword = document.getElementById('ppassword').value;
|
||||
let vppasscode = document.getElementById('ppasscode').value;
|
||||
vpemail = vpemail.toLowerCase();
|
||||
if (puaction === 'signup') {
|
||||
if (vpemail !== '' && vpname !== '' && vpcompany !== '' && vppassword !== '') {
|
||||
window.open('../pages/accsrvrq.aspx?uaction=signup&name=' + vpname + '&company=' + vpcompany + '&email=' + vpemail + '&password=' + vppassword, '_self');
|
||||
}
|
||||
}
|
||||
if (puaction === 'resetpassword') {
|
||||
if (vpemail !== '') {
|
||||
window.open('../pages/accsrvrq.aspx?uaction=resetpassword&email=' + vpemail, '_self');
|
||||
}
|
||||
}
|
||||
if (puaction === 'turnoff2step') {
|
||||
if (vpemail !== '' && vppassword !== '') {
|
||||
window.open('../pages/accsrvrq.aspx?uaction=turnoff2step&email=' + vpemail + '&password=' + vppassword, '_self');
|
||||
}
|
||||
}
|
||||
if (puaction === 'login') {
|
||||
if (vpemail !== '') {
|
||||
window.open('../pages/accui.aspx?uaction=loginact&email=' + vpemail, '_self');
|
||||
}
|
||||
}
|
||||
if (puaction === 'turnon2step') {
|
||||
if (vpemail !== '' && vppassword !== '') {
|
||||
window.open('../pages/accui.aspx?uaction=turnon2stepact&email=' + vpemail + '&password=' + vppassword, '_self');
|
||||
}
|
||||
}
|
||||
if (puaction === 'loginact') {
|
||||
window.open('../pages/accsrv.aspx?uid=' + puid + '&ukey=' + pukey + '&password=' + vppassword + '&passcode=' + vppasscode + '&uaction=login', '_self');
|
||||
}
|
||||
if (puaction === 'resetpasswordact') {
|
||||
if (vppassword !== '') {
|
||||
window.open('../pages/accsrv.aspx?uid=' + puid + '&ukey=' + pukey + '&password=' + vppassword + '&uaction=resetpassword', '_self');
|
||||
}
|
||||
}
|
||||
if (puaction === 'turnon2stepact') {
|
||||
window.open('../pages/accsrv.aspx?uid=' + puid + '&ukey=' + pukey + '&uaction=turnon2step', '_self');
|
||||
}
|
||||
}
|
||||
591
software/cnip/cnip/Scripts/cnip/webui/activeinteraction.js
Normal file
591
software/cnip/cnip/Scripts/cnip/webui/activeinteraction.js
Normal file
@@ -0,0 +1,591 @@
|
||||
// ************* active interaction function *****************
|
||||
var activeInteraction = document.getElementById('activeInteraction');
|
||||
activeInteraction.style.width = '22px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-mouse-pointer"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Measure Area');
|
||||
activeInteraction.style.display = 'block';
|
||||
|
||||
// *****************************************************
|
||||
function setActiveInteraction(e = null, interactionName, active) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
highlightLayer.setStyle(highlightStyle);
|
||||
if (actionRunning) {
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '22px';
|
||||
activeInteraction.innerHTML = '';
|
||||
activeInteraction.setAttribute('data-original-title', '');
|
||||
activeInteraction.style.display = 'none';
|
||||
return;
|
||||
}
|
||||
switch (interactionName) {
|
||||
case 'drawPolygon':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(active);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-draw-polygon" style="color: rgb(127,58,183);"></i></span> - <span><i class="fas fa-edit"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Draw Polygon');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'modifyPolygon':
|
||||
selectPolygon.setActive(active);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(active);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(active);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
addLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-draw-polygon" style="color: rgb(127,58,183);"></i></span> - <span><i class="fas fa-external-link-alt"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Modify Polygon');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'transformPolygon':
|
||||
selectPolygon.setActive(active);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(active);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(active);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-draw-polygon" style="color: rgb(127,58,183);"></i></span> - <span><i class="fas fa-retweet"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Transform Polygon');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'deletePolygon':
|
||||
highlightLayer.setStyle(deletePolygonStyle);
|
||||
selectPolygon.setActive(active);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = active;
|
||||
snapPolygon.setActive(active);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-draw-polygon" style="color: rgb(127,58,183);"></i></span> - <span><i class="fas fa-trash-alt"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Delete Polygon');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'drawLink':
|
||||
highlightLayer.setStyle(drawLinkSiteStyle);
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(active);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-link" style="color: rgb(127,58,183);"></i></span> - <span><i class="fas fa-edit"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Draw Link');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'deleteLink':
|
||||
highlightLayer.setStyle(deleteLinkStyle);
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(active);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = active;
|
||||
snapLink.setActive(active);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-link" style="color: rgb(127,58,183);"></i></span> - <span><i class="fas fa-trash-alt"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Delete Link');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'drawSite2G':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(active);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-broadcast-tower" style="color: rgb(33,163,246);"></i></span> - <span><i class="fas fa-edit"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Draw Site');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'drawSite4G':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(active);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-broadcast-tower" style="color: rgb(33,163,246);"></i></span> - <span><i class="fas fa-edit" style="color:rgb(255,106,0);"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Draw Site');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'modifySite':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(active);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(active);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(active);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-broadcast-tower" style="color: rgb(33,163,246);"></i></span> - <span><i class="fas fa-external-link-alt"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Modify Site');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'deleteSite':
|
||||
highlightLayer.setStyle(deleteSiteStyle);
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(active);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = active;
|
||||
snapSite.setActive(active);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-broadcast-tower" style="color: rgb(33,163,246);"></i></span> - <span><i class="fas fa-trash-alt"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Delete Site');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'drawNote':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(active);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-flag" style="color: rgb(33,163,246);"></i></span> - <span><i class="fas fa-edit"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Draw Note');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'modifyNote':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(active);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(active);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(active);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-flag" style="color: rgb(33,163,246);"></i></span> - <span><i class="fas fa-external-link-alt"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Modify Note');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'deleteNote':
|
||||
highlightLayer.setStyle(deleteNoteStyle);
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(active);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = active;
|
||||
snapNote.setActive(active);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
activeInteraction.style.width = '55px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-flag" style="color: rgb(33,163,246);"></i></span> - <span><i class="fas fa-trash-alt"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Delete Note');
|
||||
activeInteraction.style.display = 'block';
|
||||
break;
|
||||
case 'toggleSelect':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(active);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(false);
|
||||
if (active) {
|
||||
activeInteraction.style.width = '22px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-mouse-pointer"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Select');
|
||||
activeInteraction.style.display = 'block';
|
||||
} else {
|
||||
activeInteraction.style.width = '22px';
|
||||
activeInteraction.innerHTML = '';
|
||||
activeInteraction.setAttribute('data-original-title', '');
|
||||
activeInteraction.style.display = 'none';
|
||||
}
|
||||
break;
|
||||
case 'toggleMeasureLine':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(!measureLine.getActive());
|
||||
measureArea.setActive(false);
|
||||
if (measureLine.getActive()) {
|
||||
activeInteraction.style.width = '22px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-ruler"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Measure Line');
|
||||
activeInteraction.style.display = 'block';
|
||||
} else {
|
||||
activeInteraction.style.width = '22px';
|
||||
activeInteraction.innerHTML = '';
|
||||
activeInteraction.setAttribute('data-original-title', '');
|
||||
activeInteraction.style.display = 'none';
|
||||
}
|
||||
break;
|
||||
case 'toggleMeasureArea':
|
||||
selectPolygon.setActive(false);
|
||||
drawPolygon.setActive(false);
|
||||
modifyPolygon.setActive(false);
|
||||
transformPolygon.setActive(false);
|
||||
deletePolygonActive = false;
|
||||
snapPolygon.setActive(false);
|
||||
selectSite.setActive(false);
|
||||
drawSite2G.setActive(false);
|
||||
drawSite4G.setActive(false);
|
||||
modifySite.setActive(false);
|
||||
deleteSiteActive = false;
|
||||
snapSite.setActive(false);
|
||||
addLink.setActive(false);
|
||||
selectLink.setActive(false);
|
||||
drawLink.setActive(false);
|
||||
deleteLinkActive = false;
|
||||
snapLink.setActive(false);
|
||||
selectNote.setActive(false);
|
||||
drawNote.setActive(false);
|
||||
modifyNote.setActive(false);
|
||||
deleteNoteActive = false;
|
||||
snapNote.setActive(false);
|
||||
select.setActive(false);
|
||||
measureLine.setActive(false);
|
||||
measureArea.setActive(!measureArea.getActive());
|
||||
if (measureArea.getActive()) {
|
||||
activeInteraction.style.width = '22px';
|
||||
activeInteraction.innerHTML = '<span><i class="fas fa-ruler-combined"></i></span>';
|
||||
activeInteraction.setAttribute('data-original-title', 'Active Tool - Measure Area');
|
||||
activeInteraction.style.display = 'block';
|
||||
} else {
|
||||
activeInteraction.style.width = '22px';
|
||||
activeInteraction.innerHTML = '';
|
||||
activeInteraction.setAttribute('data-original-title', '');
|
||||
activeInteraction.style.display = 'none';
|
||||
}
|
||||
break;
|
||||
}
|
||||
clearInteractions();
|
||||
}
|
||||
function clearInteractions() {
|
||||
select.getFeatures().clear();
|
||||
selectPolygon.getFeatures().clear();
|
||||
selectSite.getFeatures().clear();
|
||||
selectLink.getFeatures().clear();
|
||||
selectNote.getFeatures().clear();
|
||||
addLink.getFeatures().clear(); pointCount = 0; siteASelected = undefined;
|
||||
transformPolygon.getFeatures().clear();
|
||||
transformPolygon.setActive(!transformPolygon.getActive());
|
||||
transformPolygon.setActive(!transformPolygon.getActive());
|
||||
highlightLayer.getSource().clear();
|
||||
highlightFeature = undefined;
|
||||
featureInfo.innerHTML = '';
|
||||
featureInfo.style.opacity = 0;
|
||||
noteInfo.innerHTML = '';
|
||||
noteInfo.style.opacity = 0;
|
||||
//featureTip.attr('data-original-title', '').tooltip('hide');
|
||||
}
|
||||
function toggleSelect() {
|
||||
setActiveInteraction(null, 'toggleSelect', true);
|
||||
setActiveInteraction(null, 'toggleSelect', true);
|
||||
}
|
||||
96
software/cnip/cnip/Scripts/cnip/webui/contextmenu.js
Normal file
96
software/cnip/cnip/Scripts/cnip/webui/contextmenu.js
Normal file
@@ -0,0 +1,96 @@
|
||||
//// context menu *********************************
|
||||
//var contextmenu_items = [
|
||||
// {
|
||||
// text: 'Center map here',
|
||||
// classname: 'bold',
|
||||
// icon: '../img/center.png',
|
||||
// callback: center
|
||||
// },
|
||||
// //{
|
||||
// // text: 'Some Actions',
|
||||
// // icon: '../img/view_list.png',
|
||||
// // items: [
|
||||
// // {
|
||||
// // text: 'Center map here',
|
||||
// // icon: '../img/center.png',
|
||||
// // callback: center
|
||||
// // },
|
||||
// // {
|
||||
// // text: 'Add Site',
|
||||
// // icon: '../img/site2G.png',
|
||||
// // callback: marker
|
||||
// // }
|
||||
// // ]
|
||||
// //},
|
||||
// , '-',
|
||||
// {
|
||||
// text: 'Add Site',
|
||||
// icon: '../img/site2G.png',
|
||||
// callback: marker
|
||||
// },
|
||||
// //'-' // this is a separator
|
||||
//];
|
||||
//var propertiesItem = {
|
||||
// text: 'Site Options',
|
||||
// icon: '../img/options.png',
|
||||
// callback: showsiteOptions
|
||||
//};
|
||||
//var removeMarkerItem = {
|
||||
// text: 'Delete Site',
|
||||
// icon: '../img/delete.png',
|
||||
// callback: removeMarker
|
||||
//};
|
||||
//var contextmenu = new ContextMenu({
|
||||
// width: 180,
|
||||
// items: contextmenu_items
|
||||
//});
|
||||
//myMap.addControl(contextmenu);
|
||||
//contextmenu.on('open', function (evt) {
|
||||
// var feature = myMap.forEachFeatureAtPixel(evt.pixel, function (ft, l) {
|
||||
// return ft;
|
||||
// });
|
||||
// if (feature /*&& feature.get('type') === 'removable'*/) {
|
||||
// contextmenu.clear();
|
||||
// propertiesItem.data = {
|
||||
// marker: feature
|
||||
// };
|
||||
// contextmenu.push(propertiesItem);
|
||||
// contextmenu.push('-');
|
||||
// removeMarkerItem.data = {
|
||||
// marker: feature
|
||||
// };
|
||||
// contextmenu.push(removeMarkerItem);
|
||||
// } else {
|
||||
// contextmenu.clear();
|
||||
// contextmenu.extend(contextmenu_items);
|
||||
// //contextmenu.extend(contextmenu.getDefaultItems());
|
||||
// }
|
||||
//});
|
||||
//function showsiteOptions(obj) {
|
||||
// var siteid = obj.data.marker.get('siteid');
|
||||
// document.getElementById('siteOptions').style.display = 'block';
|
||||
// document.getElementById('siteOptionsFrame').contentWindow.showsite(siteid);
|
||||
//}
|
||||
//function center(obj) {
|
||||
// let view = myMap.getView();
|
||||
// view.animate({
|
||||
// duration: 700,
|
||||
// center: obj.coordinate
|
||||
// });
|
||||
//}
|
||||
//function removeMarker(obj) {
|
||||
// var siteid = obj.data.marker.get('siteid');
|
||||
// deleteSite(siteid);
|
||||
// createmynetwork();
|
||||
// myNetworkLayer.getSource().clear();
|
||||
// document.getElementById('siteOptionsFrame').contentWindow.refreshsitedata();
|
||||
//}
|
||||
//function marker(obj) {
|
||||
// var coord4326 = ol.proj.transform(obj.coordinate, 'EPSG:3857', 'EPSG:4326');
|
||||
// var longitude = ol.coordinate.format(coord4326, '{x}', 6);
|
||||
// var latitude = ol.coordinate.format(coord4326, '{y}', 6);
|
||||
// AddNewSite(longitude, latitude);
|
||||
// createmynetwork();
|
||||
// myNetworkLayer.getSource().clear();
|
||||
// document.getElementById('siteOptionsFrame').contentWindow.refreshsitedata();
|
||||
//}
|
||||
145
software/cnip/cnip/Scripts/cnip/webui/controlbar.js
Normal file
145
software/cnip/cnip/Scripts/cnip/webui/controlbar.js
Normal file
@@ -0,0 +1,145 @@
|
||||
var mainControlBar = new ol.control.Bar();
|
||||
myMap.addControl(mainControlBar);
|
||||
var nestedControlBar = new ol.control.Bar({ toggleOne: true, group: true });
|
||||
mainControlBar.addControl(nestedControlBar);
|
||||
var selectControl = new ol.control.Toggle(
|
||||
{
|
||||
html: '<i class="fas fa-mouse-pointer"></i>',
|
||||
className: 'select',
|
||||
title: 'Select',
|
||||
interaction: select,
|
||||
active: true,
|
||||
onToggle: function (active) {
|
||||
setActiveInteraction(null,'toggleSelect', active);
|
||||
}
|
||||
});
|
||||
nestedControlBar.addControl(selectControl);
|
||||
var measureLineControl = new ol.control.Toggle(
|
||||
{
|
||||
html: '<i class="fas fa-ruler"></i>',
|
||||
className: 'draw',
|
||||
title: 'Measure Line',
|
||||
active: false,
|
||||
onToggle: function (active) {
|
||||
setActiveInteraction(null,'toggleMeasureLine', active);
|
||||
}
|
||||
});
|
||||
nestedControlBar.addControl(measureLineControl);
|
||||
var measureAreaControl = new ol.control.Toggle(
|
||||
{
|
||||
html: '<i class="fas fa-ruler-combined"></i>',
|
||||
className: 'draw',
|
||||
title: 'Measure Area',
|
||||
active: false,
|
||||
onToggle: function (active) {
|
||||
setActiveInteraction(null,'toggleMeasureArea', active);
|
||||
}
|
||||
});
|
||||
nestedControlBar.addControl(measureAreaControl);
|
||||
var downloadPngControl = new ol.control.Button(
|
||||
{
|
||||
html: '<i class="fa fa-download"></i>',
|
||||
className: 'download',
|
||||
title: 'Download PNG',
|
||||
handleClick: function () {
|
||||
if (actionRunning) { return; }
|
||||
myMap.once('postrender', function (event) {
|
||||
hideAllDialogs();
|
||||
showProgress('Exporting PNG');
|
||||
setTimeout(function () {
|
||||
closeProgress();
|
||||
if (browser === 'edge') {
|
||||
html2canvas(myMap.getTargetElement(), { ignoreElements: ignoreElements }).then(function (canvas) {
|
||||
let base64image = canvas.toDataURL("image/png");
|
||||
let block = base64image.split(";");
|
||||
let mimeType = block[0].split(":")[1];
|
||||
let realData = block[1].split(",")[1];
|
||||
let canvasBlob = b64toBlob(realData, mimeType);
|
||||
saveAs(canvasBlob, "map.png");
|
||||
});
|
||||
}
|
||||
else {
|
||||
domtoimage.toBlob(myMap.getTargetElement(), { filter: selectElements })
|
||||
.then(function (blob) {
|
||||
saveAs(blob, 'map.png');
|
||||
});
|
||||
}
|
||||
unHideAllDialogs();
|
||||
}, 500);
|
||||
});
|
||||
myMap.render();
|
||||
}
|
||||
});
|
||||
function selectElements(element) {
|
||||
return (element.className ? element.className.indexOf('ol-control') === -1 : true)
|
||||
&& element.id !== 'activeInteraction';
|
||||
}
|
||||
function ignoreElements(element) {
|
||||
return (element.className ? element.className.indexOf('ol-control') !== -1 : false)
|
||||
|| element.id === 'activeInteraction';
|
||||
}
|
||||
function b64toBlob(b64Data, contentType, sliceSize) {
|
||||
contentType = contentType || '';
|
||||
sliceSize = sliceSize || 512;
|
||||
let byteCharacters = atob(b64Data);
|
||||
let byteArrays = [];
|
||||
for (let offset = 0; offset < byteCharacters.length; offset += sliceSize) {
|
||||
let slice = byteCharacters.slice(offset, offset + sliceSize);
|
||||
let byteNumbers = new Array(slice.length);
|
||||
for (let i = 0; i < slice.length; i++) {
|
||||
byteNumbers[i] = slice.charCodeAt(i);
|
||||
}
|
||||
let byteArray = new Uint8Array(byteNumbers);
|
||||
byteArrays.push(byteArray);
|
||||
}
|
||||
let blob = new Blob(byteArrays, { type: contentType });
|
||||
return blob;
|
||||
}
|
||||
mainControlBar.addControl(downloadPngControl);
|
||||
var myLocationControl = new ol.control.Button(
|
||||
{
|
||||
html: '<i class="fas fa-map-marker-alt"></i>',
|
||||
className: 'mylocation',
|
||||
title: 'My Location',
|
||||
handleClick: function () {
|
||||
if (actionRunning) { return; }
|
||||
//let geolocation = new ol.Geolocation();
|
||||
//geolocation.setTracking(true);
|
||||
//geolocation.on('change', function () {
|
||||
// myMap.getView().animate({
|
||||
// duration: 700,
|
||||
// center: ol.proj.fromLonLat(geolocation.getPosition())
|
||||
// });
|
||||
// geolocation.setTracking(false);
|
||||
//});
|
||||
navigator.geolocation.getCurrentPosition(function (pos) {
|
||||
myMap.getView().animate({
|
||||
duration: 700,
|
||||
center: ol.proj.fromLonLat([pos.coords.longitude, pos.coords.latitude])
|
||||
});
|
||||
}, function (error) {
|
||||
|
||||
}, {
|
||||
enableHighAccuracy: true,
|
||||
timeout: 5000,
|
||||
maximumAge: 0
|
||||
});
|
||||
}
|
||||
});
|
||||
mainControlBar.addControl(myLocationControl);
|
||||
myLocationControl.button_.click();
|
||||
var fullscreenControl = new ol.control.FullScreen({
|
||||
source: 'fullscreen'
|
||||
});
|
||||
mainControlBar.addControl(fullscreenControl);
|
||||
var searchGpsControl = new ol.control.SearchGPS({
|
||||
});
|
||||
myMap.addControl(searchGpsControl);
|
||||
searchGpsControl.button.title = 'Search GPS';
|
||||
searchGpsControl.on('select', function (event) {
|
||||
if (actionRunning) { return; }
|
||||
myMap.getView().animate({
|
||||
center: event.search.coordinate,
|
||||
zoom: Math.max(myMap.getView().getZoom(), 5)
|
||||
});
|
||||
});
|
||||
308
software/cnip/cnip/Scripts/cnip/webui/dds.js
Normal file
308
software/cnip/cnip/Scripts/cnip/webui/dds.js
Normal file
@@ -0,0 +1,308 @@
|
||||
var ddsCount = 0;
|
||||
var ddsContentData = [];
|
||||
var ddsContentExtension = [];
|
||||
var ddsContentChart = [];
|
||||
var ddsContentChartPngString = [];
|
||||
function ddsCreate(title, loadObj) {
|
||||
let dsDiv = document.createElement('div');
|
||||
let dsTable = document.createElement('table');
|
||||
let dsTBody = document.createElement('tbody');
|
||||
let dsTr = document.createElement('tr');
|
||||
let dsTd1 = document.createElement('td');
|
||||
let dsTitleDiv = document.createElement('div');
|
||||
dsTd1.appendChild(dsTitleDiv);
|
||||
let dsTd21 = document.createElement('td');
|
||||
let dsMinDiv = document.createElement('div');
|
||||
let dsMinButton = document.createElement('button');
|
||||
let dsMinButtonI = document.createElement('i');
|
||||
dsMinButton.appendChild(dsMinButtonI);
|
||||
dsMinDiv.appendChild(dsMinButton);
|
||||
dsTd21.appendChild(dsMinDiv);
|
||||
let dsTd22 = document.createElement('td');
|
||||
let dsMaxDiv = document.createElement('div');
|
||||
let dsMaxButton = document.createElement('button');
|
||||
let dsMaxButtonI = document.createElement('i');
|
||||
dsMaxButton.appendChild(dsMaxButtonI);
|
||||
dsMaxDiv.appendChild(dsMaxButton);
|
||||
dsTd22.appendChild(dsMaxDiv);
|
||||
let dsTd2 = document.createElement('td');
|
||||
let dsCloseDiv = document.createElement('div');
|
||||
let dsCloseButton = document.createElement('button');
|
||||
let dsCloseButtonI = document.createElement('i');
|
||||
dsCloseButton.appendChild(dsCloseButtonI);
|
||||
dsCloseDiv.appendChild(dsCloseButton);
|
||||
dsTd2.appendChild(dsCloseDiv);
|
||||
dsTr.appendChild(dsTd1);
|
||||
dsTr.appendChild(dsTd21);
|
||||
dsTr.appendChild(dsTd22);
|
||||
dsTr.appendChild(dsTd2);
|
||||
dsTBody.appendChild(dsTr);
|
||||
dsTable.appendChild(dsTBody);
|
||||
dsDiv.appendChild(dsTable);
|
||||
let dsBodyDiv = document.createElement('div');
|
||||
let dsBodyTabLinkDiv = document.createElement('div');
|
||||
let dsBodyTabContentDiv = document.createElement('div');
|
||||
let dsBodyTabLinks = [];
|
||||
let dsBodyTabContents = [];
|
||||
for (let i = 0; i < loadObj.length; i++) {
|
||||
dsBodyTabLinks.push(document.createElement('button'));
|
||||
dsBodyTabContents.push(document.createElement('div'));
|
||||
dsBodyTabLinkDiv.appendChild(dsBodyTabLinks[i]);
|
||||
dsBodyTabContentDiv.appendChild(dsBodyTabContents[i]);
|
||||
}
|
||||
dsBodyTopButton = document.createElement('button');
|
||||
let dsBodyTopButtonI = document.createElement('i');
|
||||
dsBodyTopButton.appendChild(dsBodyTopButtonI);
|
||||
dsBodyTabLinkDiv.appendChild(dsBodyTopButton);
|
||||
dsBodyTabLinkDiv.appendChild(document.createElement('hr'));
|
||||
dsBodyDiv.appendChild(dsBodyTabLinkDiv);
|
||||
dsBodyDiv.appendChild(dsBodyTabContentDiv);
|
||||
dsDiv.appendChild(dsBodyDiv);
|
||||
document.getElementById('myMap').insertBefore(dsDiv, document.getElementsByClassName('ol-viewport')[0]);
|
||||
dsDiv.id = 'dds' + ddsCount.toString();
|
||||
dsDiv.className = 'datasheet panel panel-primary draggable';
|
||||
dsDiv.style.display = 'block';
|
||||
dsDiv.onclick = function (e) {
|
||||
setDialogZIndex(e, this.value);
|
||||
};
|
||||
dsDiv.value = dsDiv.id;
|
||||
dsTable.style.width = '100%';
|
||||
dsTd1.style.width = '94%';
|
||||
dsTd21.style.width = '2%';
|
||||
dsTd22.style.width = '2%';
|
||||
dsTd2.style.width = '2%';
|
||||
dsTitleDiv.id = 'ch' + dsDiv.id + 'Title';
|
||||
dsTitleDiv.className = 'panel-heading draggable-handler';
|
||||
dsTitleDiv.innerHTML = ' ' + title + '...';
|
||||
dsMinDiv.className = 'panel-action';
|
||||
dsMinButton.className = 'panel-action-button';
|
||||
dsMinButton.title = 'Minimize';
|
||||
dsMinButtonI.className = 'fas fa-window-minimize';
|
||||
dsMinButton.onclick = function (e) {
|
||||
minimizeDialog(e, 'dds' + this.value.toString());
|
||||
};
|
||||
dsMinButton.value = ddsCount;
|
||||
dsMaxDiv.className = 'panel-action';
|
||||
dsMaxButton.className = 'panel-action-button';
|
||||
dsMaxButton.title = 'Restore';
|
||||
dsMaxButtonI.className = 'fas fa-window-restore';
|
||||
dsMaxButton.onclick = function (e) {
|
||||
restoreDialog(e, 'dds' + this.value.toString());
|
||||
};
|
||||
dsMaxButton.value = ddsCount;
|
||||
dsCloseDiv.className = 'panel-action';
|
||||
dsCloseButton.className = 'panel-action-button';
|
||||
dsCloseButton.title = 'Close';
|
||||
dsCloseButtonI.className = 'fas fa-window-close';
|
||||
dsCloseButton.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
ddsDestroy(this.value);
|
||||
};
|
||||
dsCloseButton.value = ddsCount;
|
||||
dsBodyDiv.className = 'panel-body';
|
||||
dsBodyDiv.style.width = (Number(dsDiv.style.width.replace('px')) - 6).toString() + 'px';
|
||||
dsBodyDiv.style.height = (Number(dsDiv.style.height.replace('px')) - 37).toString() + 'px';
|
||||
dsBodyTabLinkDiv.style.overflow = 'hidden';
|
||||
dsBodyTabContentDiv.style.overflow = 'auto';
|
||||
dsBodyTabContentDiv.style.height = (360 - (Math.ceil(loadObj.length / 5) - 1) * 27.14).toString() + 'px';
|
||||
dsBodyTopButtonI.className = 'fas fa-file-csv'; //fas fa-chart-line
|
||||
dsBodyTopButtonI.id = 'ch' + dsDiv.id + 'TopButton'; //fas fa-chart-line
|
||||
dsBodyTopButton.className = 'pageTopButton';
|
||||
dsBodyTopButton.title = 'Download Content';
|
||||
dsBodyTopButton.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
ddsDownloadActiveContent(this.value);
|
||||
};
|
||||
dsBodyTopButton.value = ddsCount;
|
||||
ddsContentData.push([ddsCount]);
|
||||
ddsContentExtension.push([ddsCount]);
|
||||
ddsContentChart.push([ddsCount]);
|
||||
ddsContentChartPngString.push([ddsCount]);
|
||||
for (let i = 0; i < loadObj.length; i++) {
|
||||
dsBodyTabLinks[i].className = 'pageTabLink';
|
||||
dsBodyTabLinks[i].onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
ddsOpenPage(this.value, this.index, this);
|
||||
};
|
||||
dsBodyTabLinks[i].value = ddsCount;
|
||||
dsBodyTabLinks[i].index = i;
|
||||
dsBodyTabLinks[i].id = 'ch' + dsDiv.id + 'TabLink' + i.toString();
|
||||
dsBodyTabLinks[i].style.display = 'block';
|
||||
dsBodyTabLinks[i].innerHTML = loadObj[i].title;
|
||||
dsBodyTabLinks[i].style.fontSize = '12px';
|
||||
dsBodyTabContents[i].className = 'pageTabContent';
|
||||
dsBodyTabContents[i].id = 'ch' + dsDiv.id + 'TabContent' + i.toString();
|
||||
dsBodyTabContents[i].style.padding = loadObj[i].contentPadding;
|
||||
dsBodyTabContents[i].style.fontSize = '12px';
|
||||
ddsContentData[ddsCount][i] = '';
|
||||
ddsContentExtension[ddsCount][i] = '';
|
||||
ddsContentChart[ddsCount][i] = '';
|
||||
ddsContentChartPngString[ddsCount][i] = '';
|
||||
if (loadObj[i].contentType === 'chart') {
|
||||
ddsContentChartPngString[ddsCount][i] = loadObj[i].pngString;
|
||||
dsBodyTabContents[i].contentType = 'chart';
|
||||
let contentTitleDiv = document.createElement('div');
|
||||
let chDiv = document.createElement('div');
|
||||
let chCanvas = document.createElement('canvas');
|
||||
dsBodyTabContents[i].appendChild(contentTitleDiv);
|
||||
chDiv.appendChild(chCanvas);
|
||||
dsBodyTabContents[i].appendChild(chDiv);
|
||||
contentTitleDiv.style.textAlign = 'center';
|
||||
contentTitleDiv.style.color =
|
||||
loadObj[i].contentTitle.includes('Passed') ? 'green' :
|
||||
loadObj[i].contentTitle.includes('Failed') ? 'red' : 'blue';
|
||||
contentTitleDiv.innerHTML = loadObj[i].contentTitle;
|
||||
chCanvas.id = 'ch' + dsDiv.id + 'Chart' + i.toString();
|
||||
chCanvas.width = '570';
|
||||
chCanvas.height = '342'; // should be 60% of width
|
||||
chCanvas.style.msUserSelect = 'none';
|
||||
chCanvas.style.userSelect = 'none';
|
||||
chCanvas.style.webkitUserSelect = 'none';
|
||||
let xDataset = [];
|
||||
let dataString = loadObj[i].dataString; //rate&value&r,g,b
|
||||
dataString.split('$').forEach(function (d) {
|
||||
xDataset.push({
|
||||
Label: d.split('&')[0],
|
||||
Data: d.split('&')[1],
|
||||
BackgroundColor: getColorFromLabel(d.split('&')[2], true),
|
||||
BorderColor: getColorFromLabel(d.split('&')[2], false)
|
||||
});
|
||||
});
|
||||
let chartData = {
|
||||
labels: xDataset.map(d => d.Label),
|
||||
datasets: [
|
||||
{
|
||||
type: 'bar',
|
||||
label: loadObj[i].title,
|
||||
data: xDataset.map(d => d.Data),
|
||||
backgroundColor: xDataset.map(d => d.BackgroundColor),
|
||||
borderColor: xDataset.map(d => d.BorderColor)
|
||||
}]
|
||||
};
|
||||
let chartContext = document.getElementById(chCanvas.id).getContext('2d');
|
||||
ddsContentChart[ddsCount][i] = new Chart(chartContext, {
|
||||
type: 'bar',
|
||||
data: chartData,
|
||||
options: {
|
||||
animation: {
|
||||
duration: 0
|
||||
},
|
||||
responsive: false,
|
||||
tooltips: {
|
||||
enabled: true,
|
||||
mode: 'index',
|
||||
intersect: false,
|
||||
position: 'average'
|
||||
},
|
||||
legend: {
|
||||
display: false
|
||||
},
|
||||
scales: {
|
||||
xAxes: [{
|
||||
gridLines: {
|
||||
drawOnChartArea: false
|
||||
}
|
||||
}],
|
||||
yAxes: [{
|
||||
gridLines: {
|
||||
drawOnChartArea: false
|
||||
},
|
||||
scaleLabel: {
|
||||
display: true,
|
||||
labelString: '% Polygon Area Covered'
|
||||
}
|
||||
}]
|
||||
}
|
||||
}
|
||||
});
|
||||
} else {
|
||||
dsBodyTabContents[i].contentType = 'table';
|
||||
dsBodyTabContents[i].innerHTML = loadObj[i].contentHTML;
|
||||
ddsContentData[ddsCount][i] = loadObj[i].contentData;
|
||||
ddsContentExtension[ddsCount][i] = loadObj[i].contentExtension;
|
||||
}
|
||||
}
|
||||
if (dsBodyTabLinks[0]) { dsBodyTabLinks[0].click(); }
|
||||
setDialogZIndex(null, dsDiv.id);
|
||||
ddsCount += 1;
|
||||
// set draggable
|
||||
setDraggable();
|
||||
}
|
||||
function ddsOpenPage(ddsId, tabContentId, tabLink) {
|
||||
$('button[id^="chdds' + ddsId.toString() + 'TabLink"]').css({ 'background-color': '', 'color': '' });
|
||||
$('div[id^="chdds' + ddsId.toString() + 'TabContent"]').css('display', 'none');
|
||||
$('#chdds' + ddsId.toString() + 'TabContent' + tabContentId.toString()).css('display', 'block');
|
||||
if (document.getElementById('chdds' + ddsId.toString() + 'TabContent' + tabContentId.toString()).contentType === 'chart') {
|
||||
document.getElementById('chdds' + ddsId.toString() + 'TopButton').className = 'fas fa-chart-line';
|
||||
if (ddsContentChartPngString[ddsId][tabContentId] !== '') {
|
||||
loadRaster(ddsContentChartPngString[ddsId][tabContentId]);
|
||||
}
|
||||
} else {
|
||||
document.getElementById('chdds' + ddsId.toString() + 'TopButton').className = 'fas fa-file-csv';
|
||||
}
|
||||
tabLink.style.backgroundColor = '#555';
|
||||
tabLink.style.color = 'white';
|
||||
}
|
||||
function ddsDestroyAll() {
|
||||
for (let i = 0; i < ddsCount; i++) {
|
||||
for (let j = 0; j < $('div[id^="chdds' + i.toString() + 'TabContent"]').length; j++) {
|
||||
if (ddsContentChart[i][j].hasOwnProperty('destroy')) { ddsContentChart[i][j].destroy; }
|
||||
}
|
||||
}
|
||||
for (let i = 0; i < ddsCount; i++) {
|
||||
let dds = document.getElementById('dds' + i.toString());
|
||||
if (dds) {
|
||||
while (dds.firstChild) {
|
||||
dds.firstChild.remove();
|
||||
}
|
||||
document.getElementById('myMap').removeChild(dds);
|
||||
}
|
||||
}
|
||||
ddsCount = 0; ddsContentChart = [];
|
||||
ddsContentData = []; ddsContentExtension = [];
|
||||
}
|
||||
function ddsDestroy(ddsId) {
|
||||
for (let j = 0; j < $('div[id^="chdds' + ddsId.toString() + 'TabContent"]').length; j++) {
|
||||
if (ddsContentChart[ddsId][j].hasOwnProperty('destroy')) { ddsContentChart[i][j].destroy; }
|
||||
ddsContentChart[ddsId][j] = '';
|
||||
ddsContentData[ddsId][j] = '';
|
||||
ddsContentExtension[ddsId][j] = '';
|
||||
}
|
||||
let dds = document.getElementById('dds' + ddsId.toString());
|
||||
if (dds) {
|
||||
while (dds.firstChild) {
|
||||
dds.firstChild.remove();
|
||||
}
|
||||
document.getElementById('myMap').removeChild(dds);
|
||||
}
|
||||
}
|
||||
function ddsDownloadActiveContent(ddsId) {
|
||||
let tabContent = $('div[id^="chdds' + ddsId.toString() + 'TabContent"]');
|
||||
for (i = 0; i < tabContent.length; i++) {
|
||||
if (tabContent[i].style.display === 'block') {
|
||||
if (tabContent[i].contentType === 'chart') {
|
||||
let base64image = document.getElementById('chdds' + ddsId.toString() + 'Chart' + i.toString()).toDataURL("image/png");
|
||||
let block = base64image.split(";");
|
||||
let mimeType = block[0].split(":")[1];
|
||||
let realData = block[1].split(",")[1];
|
||||
let canvasBlob = b64toBlob(realData, mimeType);
|
||||
saveAs(canvasBlob, "chart.png");
|
||||
} else {
|
||||
let blob = new Blob([ddsContentData[ddsId][i]], { type: "text/plain;charset=utf-8" });
|
||||
saveAs(blob, $('#chdds' + ddsId.toString() + 'TabLink' + i.toString()).html() +
|
||||
ddsContentExtension[ddsId][i]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
function getColorFromLabel(label, background) {
|
||||
let color = 'rgba(0,0,0,0)';
|
||||
let rgb = label.split(',');
|
||||
color = 'rgba('
|
||||
+ rgb[0] + ','
|
||||
+ rgb[1] + ','
|
||||
+ rgb[2] + ','
|
||||
+ (background ? '0.8' : '1')
|
||||
+ ')';
|
||||
return color;
|
||||
}
|
||||
140
software/cnip/cnip/Scripts/cnip/webui/dialogs.js
Normal file
140
software/cnip/cnip/Scripts/cnip/webui/dialogs.js
Normal file
@@ -0,0 +1,140 @@
|
||||
function _minimizeDialog(e) {
|
||||
e.style.left = 'calc(80vw)';
|
||||
e.style.top = 'calc(80vh)';
|
||||
e.style.width = '220px';
|
||||
e.style.height = '37px';
|
||||
e.style.overflow = 'hidden';
|
||||
}
|
||||
function minimizeDialog(e = null, dialogId) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let dds = document.getElementById(dialogId);
|
||||
_minimizeDialog(dds);
|
||||
}
|
||||
function restoreDialog(e = null, dialogId, width = '651px', height = '432px') {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let dds = document.getElementById(dialogId);
|
||||
dds.style.left = 'calc(50vw - (' + width + ' / 2))';
|
||||
dds.style.top = 'calc(50vh - (' + height + ' / 2))';
|
||||
dds.style.width = width;
|
||||
dds.style.height = height;
|
||||
dds.style.overflow = 'auto';
|
||||
}
|
||||
function hideAllDialogs() {
|
||||
closePredictBestCan();
|
||||
closePredictSites();
|
||||
closePredict();
|
||||
[...document.getElementsByClassName('draggable')].forEach(function (e) {
|
||||
if (e.id !== 'progressBar' && e.id !== 'messageBoxBar') {
|
||||
e.style.display = 'none';
|
||||
}
|
||||
});
|
||||
}
|
||||
function unHideAllDialogs() {
|
||||
[...document.getElementsByClassName('draggable')].forEach(function (e) {
|
||||
if (e.id !== 'progressBar' && e.id !== 'messageBoxBar') {
|
||||
switch (e.id) {
|
||||
case 'siteOptions':
|
||||
if (document.getElementById('siteOptionsFrame').contentWindow.userDisplay) { e.style.display = 'block'; } break;
|
||||
case 'polyOptions':
|
||||
if (document.getElementById('polyOptionsFrame').contentWindow.userDisplay) { e.style.display = 'block'; } break;
|
||||
case 'noteOptions':
|
||||
if (document.getElementById('noteOptionsFrame').contentWindow.userDisplay) { e.style.display = 'block'; } break;
|
||||
case 'linkOptions':
|
||||
if (document.getElementById('linkOptionsFrame').contentWindow.userDisplay) { e.style.display = 'block'; } break;
|
||||
case 'linkProfile':
|
||||
if (document.getElementById('linkProfileFrame').contentWindow.userDisplay) { e.style.display = 'block'; } break;
|
||||
default:
|
||||
e.style.display = 'block'; break;
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
function minimizeAllDialogs() {
|
||||
closePredictBestCan();
|
||||
closePredictSites();
|
||||
closePredict();
|
||||
[...document.getElementsByClassName('draggable')].forEach(function (e) {
|
||||
if (e.id !== 'progressBar' && e.id !== 'messageBoxBar') {
|
||||
switch (e.id) {
|
||||
case 'siteOptions':
|
||||
if (document.getElementById('siteOptionsFrame').contentWindow.userDisplay) { _minimizeDialog(e); } break;
|
||||
case 'polyOptions':
|
||||
if (document.getElementById('polyOptionsFrame').contentWindow.userDisplay) { _minimizeDialog(e); } break;
|
||||
case 'noteOptions':
|
||||
if (document.getElementById('noteOptionsFrame').contentWindow.userDisplay) { _minimizeDialog(e); } break;
|
||||
case 'linkOptions':
|
||||
if (document.getElementById('linkOptionsFrame').contentWindow.userDisplay) { _minimizeDialog(e); } break;
|
||||
case 'linkProfile':
|
||||
if (document.getElementById('linkProfileFrame').contentWindow.userDisplay) { _minimizeDialog(e); } break;
|
||||
default:
|
||||
_minimizeDialog(e); break;
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
function closeAllDialogs() {
|
||||
document.getElementById('siteOptions').style.display = 'none';
|
||||
document.getElementById('polyOptions').style.display = 'none';
|
||||
document.getElementById('noteOptions').style.display = 'none';
|
||||
document.getElementById('linkOptions').style.display = 'none';
|
||||
document.getElementById('linkProfile').style.display = 'none';
|
||||
closePredictBestCan();
|
||||
closePredictSites();
|
||||
closePredict();
|
||||
ddsDestroyAll();
|
||||
}
|
||||
function setDialogZIndex(e = null, dialogId) {
|
||||
if (document.getElementById(dialogId)) {
|
||||
if (document.getElementById(dialogId).style.zIndex !== '199') {
|
||||
if (e) { e.stopPropagation(); }
|
||||
[...document.getElementsByClassName('draggable')].forEach(function (e) { e.style.zIndex = '99'; });
|
||||
document.getElementById(dialogId).style.zIndex = 199;
|
||||
}
|
||||
}
|
||||
}
|
||||
function showProgress(msg) {
|
||||
actionRunning = true;
|
||||
document.getElementById('progressBar').style.display = 'block';
|
||||
setDialogZIndex(null, 'progressBar');
|
||||
document.getElementById('progressTitle').innerHTML = ' ' + msg + '...';
|
||||
document.body.style.cursor = 'wait';
|
||||
}
|
||||
function closeProgress() {
|
||||
sleep(1000);
|
||||
document.getElementById('progressBar').style.display = 'none';
|
||||
document.getElementById('progressBar').style.zIndex = 99;
|
||||
document.body.style.cursor = 'default';
|
||||
actionRunning = false;
|
||||
}
|
||||
// message box setup
|
||||
document.getElementById("yesMessageBox").addEventListener("click", function () {
|
||||
document.querySelector(".page-enabler").classList.add("hidden-content");
|
||||
document.querySelector(".page-disabler").classList.add("hidden-content");
|
||||
document.getElementById("main").removeEventListener("focus", function (e) { e.preventDefault(); });
|
||||
document.getElementById('messageBoxBar').style.zIndex = 99;
|
||||
});
|
||||
document.getElementById("okcancelMessageBox").addEventListener("click", function () {
|
||||
document.querySelector(".page-enabler").classList.add("hidden-content");
|
||||
document.querySelector(".page-disabler").classList.add("hidden-content");
|
||||
document.getElementById("main").removeEventListener("focus", function (e) { e.preventDefault(); });
|
||||
document.getElementById('messageBoxBar').style.zIndex = 99;
|
||||
});
|
||||
function showMessage(title, msg, request=false) {
|
||||
setDialogZIndex(null, 'messageBoxBar');
|
||||
if (request) {
|
||||
document.getElementById("yesMessageBox").style.display = 'block';
|
||||
document.getElementById("okcancelMessageBox").innerHTML = 'No';
|
||||
} else {
|
||||
document.getElementById("yesMessageBox").style.display = 'none';
|
||||
document.getElementById("okcancelMessageBox").innerHTML = 'Ok';
|
||||
}
|
||||
document.getElementById('messageBoxBar').style.left = 'calc(50vw - 403px / 2)';
|
||||
document.getElementById('messageBoxBar').style.top = 'calc(50vh - 203px / 2)';
|
||||
document.getElementById('messageBoxBar').style.width = '403px';
|
||||
document.getElementById('messageBoxBar').style.height = '203px';
|
||||
document.getElementById('messageBoxTitle').innerHTML = ' ' + title + '...';
|
||||
document.getElementById('messageBoxContent').innerHTML = '<br /> ' + msg;
|
||||
document.querySelector(".page-enabler").classList.remove("hidden-content");
|
||||
document.querySelector(".page-disabler").classList.remove("hidden-content");
|
||||
document.getElementById("main").addEventListener("focus", function (e) { e.preventDefault(); });
|
||||
}
|
||||
161
software/cnip/cnip/Scripts/cnip/webui/dialogs/linkoptions.js
Normal file
161
software/cnip/cnip/Scripts/cnip/webui/dialogs/linkoptions.js
Normal file
@@ -0,0 +1,161 @@
|
||||
/* global variables*/
|
||||
var userDisplay = false;
|
||||
var linkData;
|
||||
var siteAData;
|
||||
var siteBData;
|
||||
var linksCount;
|
||||
var currLink;
|
||||
/* initialize controls*/
|
||||
initSingleSlider(document.getElementById('frequencya'), '', '1', '15', '0.1', '5');
|
||||
initSelectOpt(document.getElementById('channelwidtha'), '100%', '10\t20\t30\t40\t50\t60\t80\t100', '20');
|
||||
initSingleSlider(document.getElementById('outputpowera'), '', '27', '47', '0.5', '30');
|
||||
initSingleSlider(document.getElementById('antennagaina'), '', '19', '51', '0.1', '34');
|
||||
initSingleSlider(document.getElementById('lossesa'), '', '0', '51', '0.1', '0');
|
||||
initSingleSlider(document.getElementById('frequencyb'), '', '1', '15', '0.1', '5');
|
||||
initSelectOpt(document.getElementById('channelwidthb'), '100%', '10\t20\t30\t40\t50\t60\t80\t100', '20');
|
||||
initSingleSlider(document.getElementById('outputpowerb'), '', '27', '47', '0.5', '30');
|
||||
initSingleSlider(document.getElementById('antennagainb'), '', '19', '51', '0.1', '34');
|
||||
initSingleSlider(document.getElementById('lossesb'), '', '0', '51', '0.1', '0');
|
||||
/* setup listeners*/
|
||||
document.getElementById('defaultOpen').click();
|
||||
document.getElementById('linkname').addEventListener('change', linkNameChange);
|
||||
document.getElementById('frequencya').addEventListener('change', saveLinkData);
|
||||
document.getElementById('channelwidtha').addEventListener('change', saveLinkData);
|
||||
document.getElementById('outputpowera').addEventListener('change', saveLinkData);
|
||||
document.getElementById('antennagaina').addEventListener('change', saveLinkData);
|
||||
document.getElementById('lossesa').addEventListener('change', saveLinkData);
|
||||
document.getElementById('frequencyb').addEventListener('change', saveLinkData);
|
||||
document.getElementById('channelwidthb').addEventListener('change', saveLinkData);
|
||||
document.getElementById('outputpowerb').addEventListener('change', saveLinkData);
|
||||
document.getElementById('antennagainb').addEventListener('change', saveLinkData);
|
||||
document.getElementById('lossesb').addEventListener('change', saveLinkData);
|
||||
/* linkoptions functions*/
|
||||
function linkNameChange(e) {
|
||||
document.getElementById('linkname').value = fixStringName(document.getElementById('linkname').value);
|
||||
saveLinkData(e);
|
||||
}
|
||||
function fillLinkData(linkData) {
|
||||
document.getElementById('linkid').value = linkData[0].toString();
|
||||
document.getElementById('linkname').value = linkData[1] === undefined ? '' : linkData[1].toString();
|
||||
document.getElementById('linkname1').value = linkData[1] === undefined ? '' : linkData[1].toString();
|
||||
document.getElementById('linktype').value = linkData[2] === undefined ? '' : linkData[2].toString();
|
||||
let linktype = linkData[2] === undefined ? '' : linkData[2].toString();
|
||||
if (linktype === 'public') {
|
||||
document.getElementById('sitebtd1').innerText = 'Site B (Public)';
|
||||
document.getElementById('sitebtd2').innerText = 'Site B (Public)';
|
||||
document.getElementById('user').hidden = false;
|
||||
document.getElementById('userhr').hidden = false;
|
||||
document.getElementById('name').hidden = false;
|
||||
document.getElementById('email').hidden = false;
|
||||
document.getElementById('spanname').hidden = false;
|
||||
document.getElementById('spanemail').hidden = false;
|
||||
} else {
|
||||
document.getElementById('sitebtd1').innerText = 'Site B';
|
||||
document.getElementById('sitebtd2').innerText = 'Site B';
|
||||
document.getElementById('user').hidden = true;
|
||||
document.getElementById('userhr').hidden = true;
|
||||
document.getElementById('name').hidden = true;
|
||||
document.getElementById('email').hidden = true;
|
||||
document.getElementById('spanname').hidden = true;
|
||||
document.getElementById('spanemail').hidden = true;
|
||||
}
|
||||
document.getElementById('siteida').value = linkData[3] === undefined ? '' : linkData[3].toString();
|
||||
document.getElementById('sitenamea').value = siteAData[1] === undefined ? '' : siteAData[1].toString();
|
||||
document.getElementById('heighta').value = siteAData[4] === undefined ? '' : siteAData[4].toString();
|
||||
document.getElementById('locheighta').value = linkData[4] === undefined ? '' : linkData[4].toString();
|
||||
document.getElementById('bearinga').value = linkData[5] === undefined ? '' : linkData[5].toString();
|
||||
document.getElementById('channelwidtha').setOpt(linkData[6] === undefined ? '' : linkData[6].toString());
|
||||
document.getElementById('frequencya').setValue(linkData[7] === undefined ? '' : linkData[7].toString());
|
||||
document.getElementById('outputpowera').setValue(linkData[8] === undefined ? '' : linkData[8].toString());
|
||||
document.getElementById('antennagaina').setValue(linkData[9] === undefined ? '' : linkData[9].toString());
|
||||
document.getElementById('lossesa').setValue(linkData[10] === undefined ? '' : linkData[10].toString());
|
||||
document.getElementById('siteidb').value = linkData[11] === undefined ? '' : linkData[11].toString();
|
||||
document.getElementById('sitenameb').value = siteBData[1] === undefined ? '' : siteBData[1].toString();
|
||||
document.getElementById('heightb').value = siteBData[4] === undefined ? '' : siteBData[4].toString();
|
||||
document.getElementById('locheightb').value = linkData[12] === undefined ? '' : linkData[12].toString();
|
||||
document.getElementById('bearingb').value = linkData[13] === undefined ? '' : linkData[13].toString();
|
||||
document.getElementById('channelwidthb').setOpt(linkData[14] === undefined ? '' : linkData[14].toString());
|
||||
document.getElementById('frequencyb').setValue(linkData[15] === undefined ? '' : linkData[15].toString());
|
||||
document.getElementById('outputpowerb').setValue(linkData[16] === undefined ? '' : linkData[16].toString());
|
||||
document.getElementById('antennagainb').setValue(linkData[17] === undefined ? '' : linkData[17].toString());
|
||||
document.getElementById('lossesb').setValue(linkData[18] === undefined ? '' : linkData[18].toString());
|
||||
document.getElementById('distance').value = linkData[19] === undefined ? '' : linkData[19].toString();
|
||||
document.getElementById('name').value = linkData[20] === undefined ? '' : linkData[20].toString();
|
||||
document.getElementById('email').value = linkData[21] === undefined ? '' : linkData[21].toString();
|
||||
}
|
||||
function refreshLinkData(refreshType, Idx = null) {
|
||||
let currLinkId = linkData === undefined ? 0 : linkData[0].toString();
|
||||
linkData = undefined; linksCount = '0';
|
||||
linksCount = window.parent.getLinksCount();
|
||||
if (Idx !== null) { currLink = Idx.toString(); } else {
|
||||
if (refreshType === 'start') { currLink = '0'; }
|
||||
else if (refreshType === 'add') {
|
||||
currLink = (Number(linksCount) - 1).toString();
|
||||
}
|
||||
else if (refreshType === 'cursor') {
|
||||
currLink = window.parent.getLinkIdxById(currLinkId).toString();
|
||||
}
|
||||
else if (refreshType === 'delete') /*delete*/ {
|
||||
if (Number(currLink) > Number(linksCount) - 1) {
|
||||
currLink = (Number(linksCount) - 1).toString();
|
||||
}
|
||||
}
|
||||
}
|
||||
linkData = window.parent.getLinkDataByIdx(currLink).split('\t');
|
||||
let siteida = linkData[3] === undefined ? -1 : linkData[3].toString();
|
||||
let siteidb = linkData[11] === undefined ? -1 : linkData[11].toString();
|
||||
let linktype = linkData[2] === undefined ? '' : linkData[2].toString();
|
||||
let email = linkData[21] === undefined ? '' : linkData[21].toString();
|
||||
siteAData = window.parent.getSiteDataById(siteida).split('\t');
|
||||
if (linktype === 'public') {
|
||||
siteBData = window.parent.getPublicSiteData(siteidb, email).split('\t');
|
||||
} else {
|
||||
siteBData = window.parent.getSiteDataById(siteidb).split('\t');
|
||||
}
|
||||
fillLinkData(linkData);
|
||||
}
|
||||
function refreshLinkDataById(linkid) {
|
||||
refreshLinkData('', window.parent.getLinkIdxById(linkid).toString());
|
||||
}
|
||||
function nextLink(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (Number(linksCount) - 1 > Number(currLink)) {
|
||||
refreshLinkData('', (Number(currLink) + 1).toString());
|
||||
}
|
||||
}
|
||||
function previousLink(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (Number(currLink) > 0) {
|
||||
refreshLinkData('', (Number(currLink) - 1).toString());
|
||||
}
|
||||
}
|
||||
function saveLinkData(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.updateLinkDataByIdx({
|
||||
idx: currLink,
|
||||
linkname: document.getElementById('linkname').value,
|
||||
channelwidtha: document.getElementById('channelwidtha').value,
|
||||
frequencya: document.getElementById('frequencya').value,
|
||||
outputpowera: document.getElementById('outputpowera').value,
|
||||
antennagaina: document.getElementById('antennagaina').value,
|
||||
lossesa: document.getElementById('lossesa').value,
|
||||
channelwidthb: document.getElementById('channelwidthb').value,
|
||||
frequencyb: document.getElementById('frequencyb').value,
|
||||
outputpowerb: document.getElementById('outputpowerb').value,
|
||||
antennagainb: document.getElementById('antennagainb').value,
|
||||
lossesb: document.getElementById('lossesb').value
|
||||
});
|
||||
window.parent.document.getElementById('linkProfileFrame').contentWindow.refreshLinkData('cursor');
|
||||
refreshLinkData('cursor');
|
||||
}
|
||||
function deleteLink(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.deleteLinkByIdx(currLink);
|
||||
window.parent.document.getElementById('linkProfileFrame').contentWindow.refreshLinkData('delete');
|
||||
refreshLinkData('delete');
|
||||
}
|
||||
function zoomToLink(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.document.getElementById('linkOptions').style.display = 'none';
|
||||
window.parent.zoomToLinkByIdx(currLink);
|
||||
}
|
||||
369
software/cnip/cnip/Scripts/cnip/webui/dialogs/linkprofile.js
Normal file
369
software/cnip/cnip/Scripts/cnip/webui/dialogs/linkprofile.js
Normal file
@@ -0,0 +1,369 @@
|
||||
/* global variables*/
|
||||
var userDisplay = false;
|
||||
var linkData;
|
||||
var siteAData;
|
||||
var siteBData;
|
||||
var linksCount;
|
||||
var currLink;
|
||||
var elevChart;
|
||||
/* char js global setup */
|
||||
Chart.defaults.global.pointHitDetectionRadius = 1;
|
||||
Chart.defaults.LineWithLine = Chart.defaults.line;
|
||||
Chart.controllers.LineWithLine = Chart.controllers.line.extend({
|
||||
draw: function (ease) {
|
||||
Chart.controllers.line.prototype.draw.call(this, ease);
|
||||
if (this.chart.tooltip._active && this.chart.tooltip._active.length) {
|
||||
let activePoint = this.chart.tooltip._active[0],
|
||||
ctx = this.chart.ctx,
|
||||
x = activePoint.tooltipPosition().x,
|
||||
topY = this.chart.legend.bottom,
|
||||
bottomY = this.chart.chartArea.bottom;
|
||||
ctx.save();
|
||||
ctx.beginPath();
|
||||
ctx.moveTo(x, topY);
|
||||
ctx.lineTo(x, bottomY);
|
||||
ctx.lineWidth = 1;
|
||||
ctx.strokeStyle = '#07C';
|
||||
ctx.stroke();
|
||||
ctx.restore();
|
||||
}
|
||||
}
|
||||
});
|
||||
var customTooltips = function (tooltip) {
|
||||
let tooltipEl = document.getElementById('chartjs-tooltip');
|
||||
if (!tooltipEl) {
|
||||
tooltipEl = document.createElement('div');
|
||||
tooltipEl.id = 'chartjs-tooltip';
|
||||
tooltipEl.innerHTML = '<table></table>';
|
||||
this._chart.canvas.parentNode.appendChild(tooltipEl);
|
||||
}
|
||||
if (tooltip.opacity === 0) {
|
||||
tooltipEl.style.opacity = 0;
|
||||
return;
|
||||
}
|
||||
tooltipEl.classList.remove('above', 'below', 'no-transform');
|
||||
if (tooltip.yAlign) {
|
||||
tooltipEl.classList.add(tooltip.yAlign);
|
||||
} else {
|
||||
tooltipEl.classList.add('no-transform');
|
||||
}
|
||||
function getBody(bodyItem) {
|
||||
return bodyItem.lines;
|
||||
}
|
||||
if (tooltip.body) {
|
||||
let titleLines = tooltip.title || [];
|
||||
let bodyLines = tooltip.body.map(getBody);
|
||||
let tDistance, tElevation, tLosHeight, tFreznelZone;
|
||||
titleLines.forEach(function (title) {
|
||||
tDistance = round(Number(title), 2);
|
||||
});
|
||||
bodyLines.forEach(function (body, i) {
|
||||
if (body) {
|
||||
if (body[0].includes('Elevation')) tElevation = Number(body[0].split(':')[1]);
|
||||
if (body[0].includes('LosHeight')) tLosHeight = Number(body[0].split(':')[1]);
|
||||
if (body[0].includes('FresnelZone')) tFresnelZone = Number(body[0].split(':')[1]);
|
||||
}
|
||||
});
|
||||
let innerHtml = '<thead>';
|
||||
innerHtml += '<tr><th></th></tr>';
|
||||
innerHtml += '</thead><tbody>';
|
||||
if (tDistance !== undefined && tElevation !== undefined && tLosHeight !== undefined && tFresnelZone !== undefined) {
|
||||
innerHtml += '<tr><td style="background-color:rgba(0,0,0,0.7);color:white;font-size:12px;" >Distance (Km): ' + tDistance.toString() + '</td></tr>';
|
||||
innerHtml += '<tr><td style="background-color:rgba(0,0,0,0.7);color:white;font-size:12px;" >Elevation (m): ' + tElevation.toString() + '</td></tr>';
|
||||
innerHtml += '<tr><td style="background-color:rgba(0,0,0,0.7);color:white;font-size:12px;" >Los Height (m): ' + round(tLosHeight - tElevation, 2).toString() + '</td></tr>';
|
||||
innerHtml += '<tr><td style="background-color:rgba(0,0,0,0.7);color:white;font-size:12px;" >Fresnel Height (m): ' + round(tFresnelZone - tElevation, 2).toString() + '</td></tr>';
|
||||
}
|
||||
innerHtml += '</tbody>';
|
||||
let tableRoot = tooltipEl.querySelector('table');
|
||||
tableRoot.innerHTML = innerHtml;
|
||||
}
|
||||
let positionY = this._chart.canvas.offsetTop;
|
||||
let positionX = this._chart.canvas.offsetLeft;
|
||||
tooltipEl.style.opacity = 1;
|
||||
tooltipEl.style.left = positionX + tooltip.caretX + 161 + 'px';
|
||||
tooltipEl.style.top = positionY + tooltip.caretY - 50 + 'px';
|
||||
tooltipEl.style.fontFamily = tooltip._bodyFontFamily;
|
||||
tooltipEl.style.fontSize = tooltip.bodyFontSize + 'px';
|
||||
tooltipEl.style.fontStyle = tooltip._bodyFontStyle;
|
||||
tooltipEl.style.padding = tooltip.yPadding + 'px ' + tooltip.xPadding + 'px';
|
||||
};
|
||||
/* linkprofile functions*/
|
||||
function fillLinkData(linkData) {
|
||||
document.getElementById('linkid').innerHTML = linkData[0].toString();
|
||||
document.getElementById('linkname').innerHTML = linkData[1] === undefined ? '' : linkData[1].toString();
|
||||
document.getElementById('linktype').innerHTML = linkData[2] === undefined ? '' : linkData[2].toString();
|
||||
let linktype = linkData[2] === undefined ? '' : linkData[2].toString();
|
||||
if (linktype === 'public') {
|
||||
document.getElementById('sitebp').innerHTML = 'Site B (Public)';
|
||||
document.getElementById('sitebp').style.width = '100px';
|
||||
} else {
|
||||
document.getElementById('sitebp').innerHTML = 'Site B';
|
||||
document.getElementById('sitebp').style.width = '50px';
|
||||
}
|
||||
document.getElementById('siteida').value = linkData[3] === undefined ? '' : linkData[3].toString();
|
||||
document.getElementById('sitenamea').value = siteAData[1] === undefined ? '' : siteAData[1].toString();
|
||||
document.getElementById('deviceheighta').value =
|
||||
round(Number(siteAData[4] === undefined ? '' : siteAData[4].toString()), 0).toString() + ' / ' +
|
||||
round(Number(linkData[4] === undefined ? '' : linkData[4].toString()), 0).toString();
|
||||
document.getElementById('channelwidtha').value = linkData[6] === undefined ? '' : linkData[6].toString();
|
||||
document.getElementById('frequencya').value = linkData[7] === undefined ? '' : linkData[7].toString();
|
||||
document.getElementById('outputpowera').value = linkData[8] === undefined ? '' : linkData[8].toString();
|
||||
document.getElementById('antennagaina').value = linkData[9] === undefined ? '' : linkData[9].toString();
|
||||
document.getElementById('lossesa').value = linkData[10] === undefined ? '' : linkData[10].toString();
|
||||
document.getElementById('siteidb').value = linkData[11] === undefined ? '' : linkData[11].toString();
|
||||
document.getElementById('sitenameb').value = siteBData[1] === undefined ? '' : siteBData[1].toString();
|
||||
document.getElementById('deviceheightb').value =
|
||||
round(Number(siteBData[4] === undefined ? '' : siteBData[4].toString()), 0).toString() + ' / ' +
|
||||
round(Number(linkData[12] === undefined ? '' : linkData[12].toString()), 0).toString();
|
||||
document.getElementById('channelwidthb').value = linkData[14] === undefined ? '' : linkData[14].toString();
|
||||
document.getElementById('frequencyb').value = linkData[15] === undefined ? '' : linkData[15].toString();
|
||||
document.getElementById('outputpowerb').value = linkData[16] === undefined ? '' : linkData[16].toString();
|
||||
document.getElementById('antennagainb').value = linkData[17] === undefined ? '' : linkData[17].toString();
|
||||
document.getElementById('lossesb').value = linkData[18] === undefined ? '' : linkData[18].toString();
|
||||
document.getElementById('distance').innerHTML =
|
||||
round(Number(linkData[19] === undefined ? '' : linkData[19].toString()), 1).toString() + ' Km';
|
||||
let xDistanceKm = Number(linkData[19] === undefined ? '' : linkData[19].toString());
|
||||
let deviceheightAm = Number(siteAData[4] === undefined ? '' : siteAData[4].toString()) +
|
||||
Number(linkData[4] === undefined ? '' : linkData[4].toString());
|
||||
let deviceheightBm = Number(siteBData[4] === undefined ? '' : siteBData[4].toString()) +
|
||||
Number(linkData[12] === undefined ? '' : linkData[12].toString());
|
||||
let tiltAd = 0; tiltBd = 0;
|
||||
if (deviceheightAm > deviceheightBm) {
|
||||
tiltAd = round(turf.radiansToDegrees(Math.atan(deviceheightAm / (xDistanceKm * 1000))), 2);
|
||||
tiltBd = round(turf.radiansToDegrees(-1 * Math.atan((deviceheightAm - deviceheightBm) / (xDistanceKm * 1000))), 2);
|
||||
}
|
||||
else {
|
||||
tiltAd = round(turf.radiansToDegrees(-1 * Math.atan((deviceheightBm - deviceheightAm) / (xDistanceKm * 1000))), 2);
|
||||
tiltBd = round(turf.radiansToDegrees(Math.atan(deviceheightBm / (xDistanceKm * 1000))), 2);
|
||||
}
|
||||
document.getElementById('headinga').value =
|
||||
round(Number(linkData[5] === undefined ? '' : linkData[5].toString()), 2).toString() + ' / ' + tiltAd;
|
||||
document.getElementById('headingb').value =
|
||||
round(Number(linkData[13] === undefined ? '' : linkData[13].toString()), 2).toString() + ' / ' + tiltBd;
|
||||
let xFrequencyGHz = Number(linkData[7] === undefined ? '' : linkData[7].toString());
|
||||
let channelwidthMHz = Number(linkData[6] === undefined ? '' : linkData[6].toString());
|
||||
let lossesAdB = Number(linkData[10] === undefined ? '' : linkData[10].toString());
|
||||
let lossesBdB = Number(linkData[18] === undefined ? '' : linkData[18].toString());
|
||||
let antennagainAdBi = Number(linkData[9] === undefined ? '' : linkData[9].toString());
|
||||
let antennagainBdBi = Number(linkData[17] === undefined ? '' : linkData[17].toString());
|
||||
let outputpowerAdBm = Number(linkData[8] === undefined ? '' : linkData[8].toString());
|
||||
let outputpowerBdBm = Number(linkData[16] === undefined ? '' : linkData[16].toString());
|
||||
let outputpowerAdBW = outputpowerAdBm - 30;
|
||||
let outputpowerBdBW = outputpowerBdBm - 30;
|
||||
let freespacelossdB = (20 * Math.log10(xDistanceKm)) + (20 * Math.log10(xFrequencyGHz * 1000)) + 32.44;
|
||||
let erpAdBm = outputpowerAdBm + antennagainAdBi - lossesAdB;
|
||||
let erpBdBm = outputpowerBdBm + antennagainBdBi - lossesBdB;
|
||||
let erpAdBW = outputpowerAdBW + antennagainAdBi - lossesAdB;
|
||||
let erpBdBW = outputpowerBdBW + antennagainBdBi - lossesBdB;
|
||||
let rxlevAdBm = erpBdBm - freespacelossdB + antennagainAdBi;
|
||||
let rxlevBdBm = erpAdBm - freespacelossdB + antennagainBdBi;
|
||||
let rxlevAdBW = erpBdBW - freespacelossdB + antennagainAdBi;
|
||||
let rxlevBdBW = erpAdBW - freespacelossdB + antennagainBdBi;
|
||||
let johnsonNoisedBm = -174 + (10 * Math.log10(channelwidthMHz * 1000 * 1000));
|
||||
let johnsonNoisedBW = johnsonNoisedBm - 30;
|
||||
let snrAdB = rxlevAdBW - johnsonNoisedBW;
|
||||
let snrBdB = rxlevBdBW - johnsonNoisedBW;
|
||||
let snrnumberA = Math.pow(10, snrAdB / 10);
|
||||
let snrnumberB = Math.pow(10, snrBdB / 10);
|
||||
let datarateAMbps = ((channelwidthMHz * 1000 * 1000) * Math.log2(1 + snrnumberA)) / 1000000;
|
||||
let datarateBMbps = ((channelwidthMHz * 1000 * 1000) * Math.log2(1 + snrnumberB)) / 1000000;
|
||||
let xElevations = linkData[20] === undefined ? '' : linkData[20].toString().split('@');
|
||||
let xDataset = [];
|
||||
let minYaxis = 50000;
|
||||
let losBreak = false;
|
||||
let fzoneBreak = false;
|
||||
let f6zoneBreak = false;
|
||||
for (let x = 0; x < xElevations.length; x++) {
|
||||
let xElevationm = Number(xElevations[x].split('&')[3]);
|
||||
let xCdistanceKm = Number(xElevations[x].split('&')[2]);
|
||||
if (minYaxis > xElevationm) { minYaxis = xElevationm; }
|
||||
let xLoS = ((x * (deviceheightBm - deviceheightAm)) /
|
||||
(xElevations.length)) + deviceheightAm;
|
||||
let xMaxx = xElevations.length - 1;
|
||||
let xFresnelFactor = 17.3 * Math.sqrt((xCdistanceKm *
|
||||
(xDistanceKm - xCdistanceKm)) / (xDistanceKm * xFrequencyGHz));
|
||||
let xFresnelZone = xLoS - xFresnelFactor;
|
||||
let xFZTop = xLoS + xFresnelFactor;
|
||||
let xFZ6 = xLoS - (xFresnelFactor * 0.6);
|
||||
let xFZ6Top = xLoS + (xFresnelFactor * 0.6);
|
||||
if (xLoS - xElevationm < 0) { losBreak = true; }
|
||||
if (xFresnelZone - xElevationm < 0) { fzoneBreak = true; }
|
||||
if (xFZ6 - xElevationm < 0) { f6zoneBreak = true; }
|
||||
xDataset.push({
|
||||
Tower: (x === 0 ? deviceheightAm : x === xMaxx ? deviceheightBm : xElevationm),
|
||||
TowerBackgroundColor: (x === 0 ? 'rgba(57,204,100,1)' :
|
||||
x === xMaxx ? 'rgba(57,204,100,1)' : 'rgba(57,204,100,0)'),
|
||||
TowerBorderColor: (x === 0 ? 'rgba(57,204,100,1)' :
|
||||
x === xMaxx ? 'rgba(57,204,100,1)' : 'rgba(57,204,100,0)'),
|
||||
TowerBorderWidth: (x === 0 ? 6 : x === xMaxx ? 6 : 3),
|
||||
TowerBarThickness: (x === 0 ? 6 : x === xMaxx ? 6 : 3),
|
||||
Location: [Number(xElevations[x].split('&')[0]), Number(xElevations[x].split('&')[1])],
|
||||
Distance: xCdistanceKm,
|
||||
Elevation: xElevationm,
|
||||
LoS: xLoS,
|
||||
FresnelZone: xFresnelZone,
|
||||
FZTop: xFZTop,
|
||||
FZ6: xFZ6,
|
||||
FZ6Top: xFZ6Top
|
||||
});
|
||||
}
|
||||
if (!losBreak) {
|
||||
document.getElementById('effca').innerHTML = '';
|
||||
document.getElementById('ratea').innerHTML = round(datarateAMbps, 0);
|
||||
document.getElementById('leva').innerHTML = round(rxlevAdBm, 0);
|
||||
document.getElementById('effcb').innerHTML = '';
|
||||
document.getElementById('rateb').innerHTML = round(datarateBMbps, 0);
|
||||
document.getElementById('levb').innerHTML = round(rxlevBdBm, 0);
|
||||
document.getElementById('connectivityInfo').innerHTML = '';
|
||||
}
|
||||
else {
|
||||
document.getElementById('effca').innerHTML = '';
|
||||
document.getElementById('ratea').innerHTML = '';
|
||||
document.getElementById('leva').innerHTML = '';
|
||||
document.getElementById('effcb').innerHTML = '';
|
||||
document.getElementById('rateb').innerHTML = '';
|
||||
document.getElementById('levb').innerHTML = '';
|
||||
document.getElementById('connectivityInfo').innerHTML = 'Link Obstructed';
|
||||
}
|
||||
let chartData = {
|
||||
labels: xDataset.map(d => d.Distance),
|
||||
datasets: [
|
||||
{
|
||||
type: 'bar',
|
||||
label: 'Towers',
|
||||
data: xDataset.map(d => d.Tower),
|
||||
backgroundColor: xDataset.map(d => d.TowerBackgroundColor),
|
||||
borderColor: xDataset.map(d => d.TowerBorderColor),
|
||||
borderWidth: xDataset.map(d => d.TowerBorderWidth),
|
||||
barThickness: xDataset.map(d => d.TowerBarThickness)
|
||||
}, {
|
||||
label: 'Location',
|
||||
data: xDataset.map(d => d.Location),
|
||||
showLine: false
|
||||
}, {
|
||||
label: 'Elevation',
|
||||
data: xDataset.map(d => d.Elevation),
|
||||
borderWidth: 0,
|
||||
pointRadius: 0
|
||||
}, {
|
||||
label: 'LosHeight',
|
||||
data: xDataset.map(d => d.LoS),
|
||||
borderWidth: 2,
|
||||
pointRadius: 1,
|
||||
borderColor: losBreak ? 'rgba(255, 0, 0, 0.7)' : 'rgba(114,119,122,1)',
|
||||
fill: false
|
||||
}, {
|
||||
label: 'FresnelZone',
|
||||
data: xDataset.map(d => d.FresnelZone),
|
||||
borderWidth: 1,
|
||||
pointRadius: 0,
|
||||
fill: false,
|
||||
borderColor: fzoneBreak ? 'rgba(255,165,0,1)' : 'rgba(0,255,0,1)'
|
||||
}, {
|
||||
label: 'FZTop',
|
||||
data: xDataset.map(d => d.FZTop),
|
||||
borderWidth: 1,
|
||||
pointRadius: 0,
|
||||
fill: false,
|
||||
borderColor: fzoneBreak ? 'rgba(255,165,0,1)' : 'rgba(0,255,0,1)'
|
||||
}, {
|
||||
label: 'FZ6',
|
||||
data: xDataset.map(d => d.FZ6),
|
||||
borderWidth: 1,
|
||||
pointRadius: 0,
|
||||
fill: false,
|
||||
borderColor: f6zoneBreak ? 'rgba(255,165,0,1)' : 'rgba(0,255,0,1)',
|
||||
borderDash: [7, 7]
|
||||
}, {
|
||||
label: 'FZ6Top',
|
||||
data: xDataset.map(d => d.FZ6Top),
|
||||
borderWidth: 1,
|
||||
pointRadius: 0,
|
||||
fill: false,
|
||||
borderColor: f6zoneBreak ? 'rgba(255,165,0,1)' : 'rgba(0,255,0,1)',
|
||||
borderDash: [7, 7]
|
||||
}]
|
||||
};
|
||||
let elevChartContext = document.getElementById('chart1').getContext('2d');
|
||||
if (elevChart) { elevChart.destroy(); }
|
||||
elevChart = new Chart(elevChartContext, {
|
||||
type: 'LineWithLine',
|
||||
data: chartData,
|
||||
options: {
|
||||
animation: {
|
||||
duration: 0
|
||||
},
|
||||
responsive: false,
|
||||
tooltips: {
|
||||
enabled: false,
|
||||
mode: 'index',
|
||||
intersect: false,
|
||||
custom: customTooltips
|
||||
},
|
||||
hover: {
|
||||
mode: 'index',
|
||||
intersect: false
|
||||
},
|
||||
onHover: function (e, elements) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (elements) {
|
||||
if (elements.length > 0) {
|
||||
if (elements[0]._index) {
|
||||
$("#chart1").css("cursor", elements[0] ? "pointer" : "default");
|
||||
window.parent.highlightPoint(
|
||||
elevChart.data.datasets[1].data[elements[0]._index]);
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
legend: {
|
||||
display: false
|
||||
},
|
||||
scales: {
|
||||
xAxes: [{
|
||||
display: false
|
||||
}],
|
||||
yAxes: [{
|
||||
display: false,
|
||||
ticks: {
|
||||
min: minYaxis
|
||||
}
|
||||
}]
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
function refreshLinkData(refreshType, Idx = null) {
|
||||
let currLinkId = linkData === undefined ? 0 : linkData[0].toString();
|
||||
linkData = undefined; linksCount = '0';
|
||||
linksCount = window.parent.getLinksCount();
|
||||
if (Idx !== null) { currLink = Idx.toString(); } else {
|
||||
if (refreshType === 'start') { currLink = '0'; }
|
||||
else if (refreshType === 'add') {
|
||||
currLink = (Number(linksCount) - 1).toString();
|
||||
}
|
||||
else if (refreshType === 'cursor') {
|
||||
currLink = window.parent.getLinkIdxById(currLinkId).toString();
|
||||
}
|
||||
else if (refreshType === 'delete') /*delete*/ {
|
||||
if (Number(currLink) > Number(linksCount) - 1) {
|
||||
currLink = (Number(linksCount) - 1).toString();
|
||||
}
|
||||
}
|
||||
}
|
||||
linkData = window.parent.getLinkProfileByIdx(currLink).split('\t');
|
||||
let siteida = linkData[3] === undefined ? -1 : linkData[3].toString();
|
||||
let siteidb = linkData[11] === undefined ? -1 : linkData[11].toString();
|
||||
let linktype = linkData[2] === undefined ? '' : linkData[2].toString();
|
||||
let email = linkData[22] === undefined ? '' : linkData[22].toString();
|
||||
siteAData = window.parent.getSiteDataById(siteida).split('\t');
|
||||
if (linktype === 'public') {
|
||||
siteBData = window.parent.getPublicSiteData(siteidb, email).split('\t');
|
||||
} else {
|
||||
siteBData = window.parent.getSiteDataById(siteidb).split('\t');
|
||||
}
|
||||
fillLinkData(linkData);
|
||||
}
|
||||
function refreshLinkDataById(linkid) {
|
||||
refreshLinkData('', window.parent.getLinkIdxById(linkid).toString());
|
||||
}
|
||||
86
software/cnip/cnip/Scripts/cnip/webui/dialogs/noteoptions.js
Normal file
86
software/cnip/cnip/Scripts/cnip/webui/dialogs/noteoptions.js
Normal file
@@ -0,0 +1,86 @@
|
||||
/* global variables*/
|
||||
var userDisplay = false;
|
||||
var noteData;
|
||||
var notesCount;
|
||||
var currNote;
|
||||
/* setup listeners*/
|
||||
$('#description').keypress(function (event) {
|
||||
if (event.keyCode === 13) {
|
||||
event.preventDefault();
|
||||
}
|
||||
});
|
||||
document.getElementById('defaultOpen').click();
|
||||
initSelectOpt(document.getElementById('notetype'), '100%', 'Public\tPrivate', 'Public');
|
||||
document.getElementById('notename').addEventListener('change', noteNameChange);
|
||||
document.getElementById('notetype').addEventListener('change', saveNoteData);
|
||||
document.getElementById('description').addEventListener('change', descriptionChange);
|
||||
function noteNameChange(e) {
|
||||
document.getElementById('notename').value = fixStringName(document.getElementById('notename').value);
|
||||
saveNoteData(e);
|
||||
}
|
||||
function descriptionChange(e) {
|
||||
document.getElementById('description').value = fixStringName(document.getElementById('description').value);
|
||||
saveNoteData(e);
|
||||
}
|
||||
/* noteoptions functions*/
|
||||
function fillNoteData(noteData) {
|
||||
document.getElementById('noteid').value = noteData[0].toString();
|
||||
document.getElementById('notename').value = noteData[1] === undefined ? '' : noteData[1].toString();
|
||||
document.getElementById('notetype').setOpt(noteData[2] === undefined ? '' : noteData[2].toString());
|
||||
document.getElementById('description').value = noteData[3] === undefined ? '' : noteData[3].toString();
|
||||
}
|
||||
function refreshNoteData(refreshType, Idx = null) {
|
||||
let currNoteId = noteData === undefined ? 0 : noteData[0].toString();
|
||||
noteData = undefined; notesCount = '0';
|
||||
notesCount = window.parent.getNotesCount();
|
||||
if (Idx !== null) { currNote = Idx.toString(); }
|
||||
else {
|
||||
if (refreshType === 'start') { currNote = '0'; }
|
||||
else if (refreshType === 'add') {
|
||||
currNote = (Number(notesCount) - 1).toString();
|
||||
}
|
||||
else if (refreshType === 'cursor') {
|
||||
currNote = window.parent.getNoteIdxById(currNoteId).toString();
|
||||
}
|
||||
else if (refreshType === 'delete') /*delete*/ {
|
||||
if (Number(currNote) > Number(notesCount) - 1) {
|
||||
currNote = (Number(notesCount) - 1).toString();
|
||||
}
|
||||
}
|
||||
}
|
||||
noteData = window.parent.getNoteDataByIdx(currNote).split('\t');
|
||||
fillNoteData(noteData);
|
||||
}
|
||||
function refreshNoteDataById(noteid) {
|
||||
refreshNoteData('', window.parent.getNoteIdxById(noteid).toString());
|
||||
}
|
||||
function nextNote(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (Number(notesCount) - 1 > Number(currNote)) {
|
||||
refreshNoteData('', (Number(currNote) + 1).toString());
|
||||
}
|
||||
}
|
||||
function previousNote(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (Number(currNote) > 0) {
|
||||
refreshNoteData('', (Number(currNote) - 1).toString());
|
||||
}
|
||||
}
|
||||
function saveNoteData(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let notename = document.getElementById('notename').value;
|
||||
let notetype = document.getElementById('notetype').value;
|
||||
let description = document.getElementById('description').value;
|
||||
window.parent.updateNoteDataByIdx(currNote, notename, notetype, description);
|
||||
refreshNoteData('cursor');
|
||||
}
|
||||
function deleteNote(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.deleteNoteByIdx(currNote);
|
||||
refreshNoteData('delete');
|
||||
}
|
||||
function zoomToNote(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.document.getElementById('noteOptions').style.display = 'none';
|
||||
window.parent.zoomToNoteByIdx(currNote);
|
||||
}
|
||||
70
software/cnip/cnip/Scripts/cnip/webui/dialogs/polyoptions.js
Normal file
70
software/cnip/cnip/Scripts/cnip/webui/dialogs/polyoptions.js
Normal file
@@ -0,0 +1,70 @@
|
||||
/* global variables*/
|
||||
var userDisplay = false;
|
||||
var polygonData;
|
||||
var polygonsCount;
|
||||
var currPolygon;
|
||||
/* setup listeners*/
|
||||
document.getElementById('defaultOpen').click();
|
||||
document.getElementById('polygonname').addEventListener('change', polygonNameChange);
|
||||
function polygonNameChange(e) {
|
||||
document.getElementById('polygonname').value = fixStringName(document.getElementById('polygonname').value);
|
||||
savePolygonData(e);
|
||||
}
|
||||
/* polyoptions functions*/
|
||||
function fillPolygonData(polygonData) {
|
||||
document.getElementById('polygonid').value = polygonData[0].toString();
|
||||
document.getElementById('polygonname').value = polygonData[1] === undefined ? '' : polygonData[1].toString();
|
||||
}
|
||||
function refreshPolygonData(refreshType, Idx = null) {
|
||||
let currPolygonId = polygonData === undefined ? 0 : polygonData[0].toString();
|
||||
polygonData = undefined; polygonsCount = '0';
|
||||
polygonsCount = window.parent.getPolygonsCount();
|
||||
if (Idx !== null) { currPolygon = Idx.toString(); }
|
||||
else {
|
||||
if (refreshType === 'start') { currPolygon = '0'; }
|
||||
else if (refreshType === 'add') {
|
||||
currPolygon = (Number(polygonsCount) - 1).toString();
|
||||
}
|
||||
else if (refreshType === 'cursor') {
|
||||
currPolygon = window.parent.getPolygonIdxById(currPolygonId).toString();
|
||||
}
|
||||
else if (refreshType === 'delete') /*delete*/ {
|
||||
if (Number(currPolygon) > Number(polygonsCount) - 1) {
|
||||
currPolygon = (Number(polygonsCount) - 1).toString();
|
||||
}
|
||||
}
|
||||
}
|
||||
polygonData = window.parent.getPolygonDataByIdx(currPolygon).split('\t');
|
||||
fillPolygonData(polygonData);
|
||||
}
|
||||
function refreshPolygonDataById(polygonid) {
|
||||
refreshPolygonData('', window.parent.getPolygonIdxById(polygonid).toString());
|
||||
}
|
||||
function nextPolygon(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (Number(polygonsCount) - 1 > Number(currPolygon)) {
|
||||
refreshPolygonData('', (Number(currPolygon) + 1).toString());
|
||||
}
|
||||
}
|
||||
function previousPolygon(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (Number(currPolygon) > 0) {
|
||||
refreshPolygonData('', (Number(currPolygon) - 1).toString());
|
||||
}
|
||||
}
|
||||
function savePolygonData(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let polygonname = document.getElementById('polygonname').value;
|
||||
window.parent.updatePolygonDataByIdx(currPolygon, polygonname);
|
||||
refreshPolygonData('cursor');
|
||||
}
|
||||
function deletePolygon(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.deletePolygonByIdx(currPolygon);
|
||||
refreshPolygonData('delete');
|
||||
}
|
||||
function zoomToPolygon(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.document.getElementById('polyOptions').style.display = 'none';
|
||||
window.parent.zoomToPolygonByIdx(currPolygon);
|
||||
}
|
||||
199
software/cnip/cnip/Scripts/cnip/webui/dialogs/predict.js
Normal file
199
software/cnip/cnip/Scripts/cnip/webui/dialogs/predict.js
Normal file
@@ -0,0 +1,199 @@
|
||||
function showPredict(e, predict) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (!document.getElementById('pcDiv')) {
|
||||
let pcDiv = document.createElement('div');
|
||||
let pcTable = document.createElement('table');
|
||||
let pcTBody = document.createElement('tbody');
|
||||
let pcTr = document.createElement('tr');
|
||||
let pcTd1 = document.createElement('td');
|
||||
let pcTitleDiv = document.createElement('div');
|
||||
pcTd1.appendChild(pcTitleDiv);
|
||||
let pcTd2 = document.createElement('td');
|
||||
let pcCloseDiv = document.createElement('div');
|
||||
let pcCloseButton = document.createElement('button');
|
||||
let pcCloseButtonI = document.createElement('i');
|
||||
pcCloseButton.appendChild(pcCloseButtonI);
|
||||
pcCloseDiv.appendChild(pcCloseButton);
|
||||
pcTd2.appendChild(pcCloseDiv);
|
||||
pcTr.appendChild(pcTd1);
|
||||
pcTr.appendChild(pcTd2);
|
||||
pcTBody.appendChild(pcTr);
|
||||
pcTable.appendChild(pcTBody);
|
||||
pcDiv.appendChild(pcTable);
|
||||
let pcBodyDiv = document.createElement('div');
|
||||
pcBodyDiv.appendChild(document.createTextNode('Select Sites'));
|
||||
|
||||
let pcContainer = document.createElement('div');
|
||||
//
|
||||
let pcList1Div = document.createElement('div');
|
||||
let pcList1 = document.createElement('select');
|
||||
let sites = myNetworkLayer.getSource().getFeatures();
|
||||
pcList1Option = [];
|
||||
for (let i = 0; i < sites.length; i++) {
|
||||
pcList1Option.push(document.createElement('option'));
|
||||
pcList1.appendChild(pcList1Option[i]);
|
||||
}
|
||||
pcList1Div.appendChild(document.createTextNode('Available Sites'));
|
||||
pcList1Div.appendChild(pcList1);
|
||||
pcContainer.appendChild(pcList1Div);
|
||||
|
||||
let pcTransferDiv = document.createElement('div');
|
||||
let buttonRight = document.createElement('button');
|
||||
let buttonLeft = document.createElement('button');
|
||||
pcTransferDiv.appendChild(buttonRight);
|
||||
pcTransferDiv.appendChild(document.createElement('br'));
|
||||
pcTransferDiv.appendChild(document.createElement('br'));
|
||||
pcTransferDiv.appendChild(buttonLeft);
|
||||
pcContainer.appendChild(pcTransferDiv);
|
||||
|
||||
let pcList2 = document.createElement('select');
|
||||
let pcList2Div = document.createElement('div');
|
||||
pcList2Div.appendChild(document.createTextNode('Selected Sites'));
|
||||
pcList2Div.appendChild(pcList2);
|
||||
pcContainer.appendChild(pcList2Div);
|
||||
|
||||
pcBodyDiv.appendChild(pcContainer);
|
||||
|
||||
pcButtonRun = document.createElement('button');
|
||||
pcBodyDiv.appendChild(pcButtonRun);
|
||||
pcButtonCancel = document.createElement('button');
|
||||
pcBodyDiv.appendChild(pcButtonCancel);
|
||||
pcDiv.appendChild(pcBodyDiv);
|
||||
|
||||
document.getElementById('myMap').insertBefore(pcDiv,
|
||||
document.getElementsByClassName('ol-viewport')[0]);
|
||||
pcDiv.id = 'pcDiv';
|
||||
pcDiv.className = 'predictBestCan panel panel-primary draggable';
|
||||
pcDiv.style.display = 'block';
|
||||
pcDiv.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
setDialogZIndex(e, 'pcDiv');
|
||||
};
|
||||
pcTable.style.width = '100%';
|
||||
pcTd1.style.width = '98%';
|
||||
pcTd2.style.width = '2%';
|
||||
pcTitleDiv.id = pcDiv.id + 'Title';
|
||||
pcTitleDiv.className = 'panel-heading draggable-handler';
|
||||
if (predict === 'Coverage') {
|
||||
pcTitleDiv.innerHTML = ' Predict Coverage Options...';
|
||||
}
|
||||
if (predict === 'RadioPlan') {
|
||||
pcTitleDiv.innerHTML = ' Predict Radio Plan Options...';
|
||||
}
|
||||
if (predict === 'Links') {
|
||||
pcTitleDiv.innerHTML = ' Predict Links Options...';
|
||||
}
|
||||
pcCloseDiv.className = 'panel-action';
|
||||
pcCloseButton.className = 'panel-action-button';
|
||||
pcCloseButton.title = 'Close';
|
||||
pcCloseButtonI.className = 'fas fa-window-close';
|
||||
pcCloseButton.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
closePredict();
|
||||
};
|
||||
pcDiv.style.height = '243px';
|
||||
pcBodyDiv.className = 'panel-body';
|
||||
pcBodyDiv.style.width =
|
||||
(Number(pcDiv.style.width.replace('px')) - 6).toString() + 'px';
|
||||
pcBodyDiv.style.height =
|
||||
(Number(pcDiv.style.height.replace('px')) - 37).toString() + 'px';
|
||||
pcBodyDiv.style.padding = '15px 10px';
|
||||
pcBodyDiv.style.color = 'var(--fontcolor)';
|
||||
pcBodyDiv.style.fontSize = '12px';
|
||||
pcButtonRun.className = 'btn btn-default';
|
||||
pcButtonRun.style.position = 'absolute';
|
||||
pcButtonRun.style.right = '10px';
|
||||
pcButtonRun.style.bottom = '10px';
|
||||
pcButtonRun.title = 'Run';
|
||||
pcButtonRun.innerHTML = 'Run';
|
||||
pcButtonRun.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
var testSites = [];
|
||||
testSites = $('#lstBox2pc option').map(function () {
|
||||
return $(this).val();
|
||||
}).get();
|
||||
if (testSites) {
|
||||
if (testSites.length > 50) {
|
||||
testSites = testSites.slice(0, 50);
|
||||
}
|
||||
}
|
||||
closePredict();
|
||||
if (testSites.length > 0) {
|
||||
if (predict === 'Coverage') {
|
||||
predictCoverage(testSites);
|
||||
}
|
||||
if (predict === 'RadioPlan') {
|
||||
predictRadioPlan(testSites);
|
||||
}
|
||||
if (predict === 'Links') {
|
||||
predictLinks(testSites);
|
||||
}
|
||||
}
|
||||
};
|
||||
pcButtonCancel.className = 'btn btn-default';
|
||||
pcButtonCancel.style.position = 'absolute';
|
||||
pcButtonCancel.style.right = '70px';
|
||||
pcButtonCancel.style.bottom = '10px';
|
||||
pcButtonCancel.title = 'Cancel';
|
||||
pcButtonCancel.innerHTML = 'Cancel';
|
||||
pcButtonCancel.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
closePredict();
|
||||
};
|
||||
pcContainer.className = 'transferContainer';
|
||||
pcList1.className = 'listBox';
|
||||
pcList1.id = 'lstBox1pc';
|
||||
pcList1.multiple = 'multiple';
|
||||
pcList2.id = 'lstBox2pc';
|
||||
pcList2.className = 'listBox';
|
||||
pcList2.multiple = 'multiple';
|
||||
for (let i = 0; i < sites.length; i++) {
|
||||
pcList1Option[i].innerHTML = sites[i].getProperties().sitename;
|
||||
pcList1Option[i].value = sites[i].getProperties().siteid;
|
||||
}
|
||||
pcTransferDiv.className = 'transferButtons';
|
||||
buttonRight.id = 'btnRightpc';
|
||||
buttonRight.innerHTML = ' > ';
|
||||
buttonRight.value = ' > ';
|
||||
buttonRight.type = 'button';
|
||||
buttonLeft.id = 'btnLeftpc';
|
||||
buttonLeft.innerHTML = ' < ';
|
||||
buttonLeft.value = ' < ';
|
||||
buttonLeft.type = 'button';
|
||||
buttonRight.className = 'btn btn-default';
|
||||
buttonLeft.className = 'btn btn-default';
|
||||
|
||||
// set draggable
|
||||
$(document).ready(function () {
|
||||
$('#btnRightpc').click(function (e) {
|
||||
let selectedOpts = $('#lstBox1pc option:selected');
|
||||
if (selectedOpts.length === 0) {
|
||||
e.preventDefault();
|
||||
}
|
||||
$('#lstBox2pc').append($(selectedOpts).clone());
|
||||
$(selectedOpts).remove();
|
||||
e.preventDefault();
|
||||
});
|
||||
$('#btnLeftpc').click(function (e) {
|
||||
let selectedOpts = $('#lstBox2pc option:selected');
|
||||
if (selectedOpts.length === 0) {
|
||||
e.preventDefault();
|
||||
}
|
||||
$('#lstBox1pc').append($(selectedOpts).clone());
|
||||
$(selectedOpts).remove();
|
||||
e.preventDefault();
|
||||
});
|
||||
});
|
||||
setDraggable();
|
||||
setDialogZIndex(null, pcDiv.id);
|
||||
}
|
||||
}
|
||||
function closePredict() {
|
||||
let pcd = document.getElementById('pcDiv');
|
||||
if (pcd) {
|
||||
while (pcd.firstChild) {
|
||||
pcd.firstChild.remove();
|
||||
}
|
||||
document.getElementById('myMap').removeChild(pcd);
|
||||
}
|
||||
}
|
||||
203
software/cnip/cnip/Scripts/cnip/webui/dialogs/predictbestcan.js
Normal file
203
software/cnip/cnip/Scripts/cnip/webui/dialogs/predictbestcan.js
Normal file
@@ -0,0 +1,203 @@
|
||||
function showPredictBestCan(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (!document.getElementById('pbcDiv')) {
|
||||
let bcDiv = document.createElement('div');
|
||||
let bcTable = document.createElement('table');
|
||||
let bcTBody = document.createElement('tbody');
|
||||
let bcTr = document.createElement('tr');
|
||||
let bcTd1 = document.createElement('td');
|
||||
let bcTitleDiv = document.createElement('div');
|
||||
bcTd1.appendChild(bcTitleDiv);
|
||||
let bcTd2 = document.createElement('td');
|
||||
let bcCloseDiv = document.createElement('div');
|
||||
let bcCloseButton = document.createElement('button');
|
||||
let bcCloseButtonI = document.createElement('i');
|
||||
bcCloseButton.appendChild(bcCloseButtonI);
|
||||
bcCloseDiv.appendChild(bcCloseButton);
|
||||
bcTd2.appendChild(bcCloseDiv);
|
||||
bcTr.appendChild(bcTd1);
|
||||
bcTr.appendChild(bcTd2);
|
||||
bcTBody.appendChild(bcTr);
|
||||
bcTable.appendChild(bcTBody);
|
||||
bcDiv.appendChild(bcTable);
|
||||
let bcBodyDiv = document.createElement('div');
|
||||
let bcPolygonDiv = document.createElement('div');
|
||||
bcBodyDiv.appendChild(document.createTextNode('Select Polygon'));
|
||||
bcBodyDiv.appendChild(bcPolygonDiv);
|
||||
bcBodyDiv.appendChild(document.createTextNode('Select Candidate Sites'));
|
||||
|
||||
let bcContainer = document.createElement('div');
|
||||
//
|
||||
let bcList1Div = document.createElement('div');
|
||||
let bcList1 = document.createElement('select');
|
||||
let sites = myNetworkLayer.getSource().getFeatures();
|
||||
bcList1Option = [];
|
||||
for (let i = 0; i < sites.length; i++) {
|
||||
bcList1Option.push(document.createElement('option'));
|
||||
bcList1.appendChild(bcList1Option[i]);
|
||||
}
|
||||
bcList1Div.appendChild(document.createTextNode('Available Sites'));
|
||||
bcList1Div.appendChild(bcList1);
|
||||
bcContainer.appendChild(bcList1Div);
|
||||
|
||||
let bcTransferDiv = document.createElement('div');
|
||||
let buttonRight = document.createElement('button');
|
||||
let buttonLeft = document.createElement('button');
|
||||
bcTransferDiv.appendChild(buttonRight);
|
||||
bcTransferDiv.appendChild(document.createElement('br'));
|
||||
bcTransferDiv.appendChild(document.createElement('br'));
|
||||
bcTransferDiv.appendChild(buttonLeft);
|
||||
bcContainer.appendChild(bcTransferDiv);
|
||||
|
||||
let bcList2 = document.createElement('select');
|
||||
let bcList2Div = document.createElement('div');
|
||||
bcList2Div.appendChild(document.createTextNode('Selected Sites'));
|
||||
bcList2Div.appendChild(bcList2);
|
||||
bcContainer.appendChild(bcList2Div);
|
||||
|
||||
bcBodyDiv.appendChild(bcContainer);
|
||||
|
||||
bcButtonRun = document.createElement('button');
|
||||
bcBodyDiv.appendChild(bcButtonRun);
|
||||
bcButtonCancel = document.createElement('button');
|
||||
bcBodyDiv.appendChild(bcButtonCancel);
|
||||
bcDiv.appendChild(bcBodyDiv);
|
||||
|
||||
document.getElementById('myMap').insertBefore(bcDiv,
|
||||
document.getElementsByClassName('ol-viewport')[0]);
|
||||
bcDiv.id = 'pbcDiv';
|
||||
bcDiv.className = 'predictBestCan panel panel-primary draggable';
|
||||
bcDiv.style.display = 'block';
|
||||
bcDiv.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
setDialogZIndex(e, 'pbcDiv');
|
||||
};
|
||||
bcTable.style.width = '100%';
|
||||
bcTd1.style.width = '98%';
|
||||
bcTd2.style.width = '2%';
|
||||
bcTitleDiv.id = bcDiv.id + 'Title';
|
||||
bcTitleDiv.className = 'panel-heading draggable-handler';
|
||||
bcTitleDiv.innerHTML = ' Best Candidate Options...';
|
||||
bcCloseDiv.className = 'panel-action';
|
||||
bcCloseButton.className = 'panel-action-button';
|
||||
bcCloseButton.title = 'Close';
|
||||
bcCloseButtonI.className = 'fas fa-window-close';
|
||||
bcCloseButton.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
closePredictBestCan();
|
||||
};
|
||||
bcBodyDiv.className = 'panel-body';
|
||||
bcBodyDiv.style.width =
|
||||
(Number(bcDiv.style.width.replace('px')) - 6).toString() + 'px';
|
||||
bcBodyDiv.style.height =
|
||||
(Number(bcDiv.style.height.replace('px')) - 37).toString() + 'px';
|
||||
bcBodyDiv.style.padding = '15px 10px';
|
||||
bcBodyDiv.style.color = 'var(--fontcolor)';
|
||||
bcBodyDiv.style.fontSize = '12px';
|
||||
bcPolygonDiv.id = 'pbcPolygon';
|
||||
bcButtonRun.className = 'btn btn-default';
|
||||
bcButtonRun.style.position = 'absolute';
|
||||
bcButtonRun.style.right = '10px';
|
||||
bcButtonRun.style.bottom = '10px';
|
||||
bcButtonRun.title = 'Run';
|
||||
bcButtonRun.innerHTML = 'Run';
|
||||
bcButtonRun.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
var testSites = [];
|
||||
var testPolygon = undefined;
|
||||
testSites = $('#lstBox2 option').map(function () {
|
||||
return $(this).val();
|
||||
}).get();
|
||||
if (testSites) {
|
||||
if (testSites.length > 50) {
|
||||
testSites = testSites.slice(0, 50);
|
||||
}
|
||||
}
|
||||
let feature = myPolygonsLayer.getSource().getFeatureByProperty('polygonname',
|
||||
document.getElementById('pbcPolygon').value);
|
||||
if (feature) {
|
||||
if (feature.get('polygonid') !== undefined) {
|
||||
testPolygon = feature.get('polygonid');
|
||||
}
|
||||
}
|
||||
closePredictBestCan();
|
||||
if (testPolygon) {
|
||||
if (testSites.length > 0) {
|
||||
analyseBestCan(testSites, testPolygon);
|
||||
}
|
||||
}
|
||||
};
|
||||
bcButtonCancel.className = 'btn btn-default';
|
||||
bcButtonCancel.style.position = 'absolute';
|
||||
bcButtonCancel.style.right = '70px';
|
||||
bcButtonCancel.style.bottom = '10px';
|
||||
bcButtonCancel.title = 'Cancel';
|
||||
bcButtonCancel.innerHTML = 'Cancel';
|
||||
bcButtonCancel.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
closePredictBestCan();
|
||||
};
|
||||
bcContainer.className = 'transferContainer';
|
||||
bcList1.className = 'listBox';
|
||||
bcList1.id = 'lstBox1';
|
||||
bcList1.multiple = 'multiple';
|
||||
bcList2.id = 'lstBox2';
|
||||
bcList2.className = 'listBox';
|
||||
bcList2.multiple = 'multiple';
|
||||
for (let i = 0; i < sites.length; i++) {
|
||||
bcList1Option[i].innerHTML = sites[i].getProperties().sitename;
|
||||
bcList1Option[i].value = sites[i].getProperties().siteid;
|
||||
}
|
||||
bcTransferDiv.className = 'transferButtons';
|
||||
buttonRight.id = 'btnRight';
|
||||
buttonRight.innerHTML = ' > ';
|
||||
buttonRight.value = ' > ';
|
||||
buttonRight.type = 'button';
|
||||
buttonLeft.id = 'btnLeft';
|
||||
buttonLeft.innerHTML = ' < ';
|
||||
buttonLeft.value = ' < ';
|
||||
buttonLeft.type = 'button';
|
||||
buttonRight.className = 'btn btn-default';
|
||||
buttonLeft.className = 'btn btn-default';
|
||||
|
||||
let polygons = myPolygonsLayer.getSource().getFeatures();
|
||||
let polygonslst = "";
|
||||
for (let i = 0; i < polygons.length; i++) {
|
||||
polygonslst += polygons[i].getProperties().polygonname + '\t';
|
||||
}
|
||||
polygonslst = polygonslst.substr(0, polygonslst.length - 1);
|
||||
initSelectOpt(bcPolygonDiv, '100%', polygonslst, '');
|
||||
// set draggable
|
||||
$(document).ready(function () {
|
||||
$('#btnRight').click(function (e) {
|
||||
let selectedOpts = $('#lstBox1 option:selected');
|
||||
if (selectedOpts.length === 0) {
|
||||
e.preventDefault();
|
||||
}
|
||||
$('#lstBox2').append($(selectedOpts).clone());
|
||||
$(selectedOpts).remove();
|
||||
e.preventDefault();
|
||||
});
|
||||
$('#btnLeft').click(function (e) {
|
||||
let selectedOpts = $('#lstBox2 option:selected');
|
||||
if (selectedOpts.length === 0) {
|
||||
e.preventDefault();
|
||||
}
|
||||
$('#lstBox1').append($(selectedOpts).clone());
|
||||
$(selectedOpts).remove();
|
||||
e.preventDefault();
|
||||
});
|
||||
});
|
||||
setDraggable();
|
||||
setDialogZIndex(null, bcDiv.id);
|
||||
}
|
||||
}
|
||||
function closePredictBestCan() {
|
||||
let bcd = document.getElementById('pbcDiv');
|
||||
if (bcd) {
|
||||
while (bcd.firstChild) {
|
||||
bcd.firstChild.remove();
|
||||
}
|
||||
document.getElementById('myMap').removeChild(bcd);
|
||||
}
|
||||
}
|
||||
122
software/cnip/cnip/Scripts/cnip/webui/dialogs/predictsites.js
Normal file
122
software/cnip/cnip/Scripts/cnip/webui/dialogs/predictsites.js
Normal file
@@ -0,0 +1,122 @@
|
||||
function showPredictSites(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (!document.getElementById('pnDiv')) {
|
||||
let psDiv = document.createElement('div');
|
||||
let psTable = document.createElement('table');
|
||||
let psTBody = document.createElement('tbody');
|
||||
let psTr = document.createElement('tr');
|
||||
let psTd1 = document.createElement('td');
|
||||
let psTitleDiv = document.createElement('div');
|
||||
psTd1.appendChild(psTitleDiv);
|
||||
let psTd2 = document.createElement('td');
|
||||
let psCloseDiv = document.createElement('div');
|
||||
let psCloseButton = document.createElement('button');
|
||||
let psCloseButtonI = document.createElement('i');
|
||||
psCloseButton.appendChild(psCloseButtonI);
|
||||
psCloseDiv.appendChild(psCloseButton);
|
||||
psTd2.appendChild(psCloseDiv);
|
||||
psTr.appendChild(psTd1);
|
||||
psTr.appendChild(psTd2);
|
||||
psTBody.appendChild(psTr);
|
||||
psTable.appendChild(psTBody);
|
||||
psDiv.appendChild(psTable);
|
||||
let psBodyDiv = document.createElement('div');
|
||||
let psPolygonDiv = document.createElement('div');
|
||||
let psTechnologyDiv = document.createElement('div');
|
||||
psBodyDiv.appendChild(document.createTextNode('Select Polygon'));
|
||||
psBodyDiv.appendChild(psPolygonDiv);
|
||||
psBodyDiv.appendChild(document.createTextNode('Select Technology'));
|
||||
psBodyDiv.appendChild(psTechnologyDiv);
|
||||
psButtonCancel = document.createElement('button');
|
||||
psBodyDiv.appendChild(psButtonCancel);
|
||||
psButtonRun = document.createElement('button');
|
||||
psBodyDiv.appendChild(psButtonRun);
|
||||
psDiv.appendChild(psBodyDiv);
|
||||
document.getElementById('myMap').insertBefore(psDiv,
|
||||
document.getElementsByClassName('ol-viewport')[0]);
|
||||
psDiv.id = 'pnDiv';
|
||||
psDiv.className = 'predictSites panel panel-primary draggable';
|
||||
psDiv.style.display = 'block';
|
||||
psDiv.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
setDialogZIndex(e, 'pnDiv');
|
||||
};
|
||||
psTable.style.width = '100%';
|
||||
psTd1.style.width = '98%';
|
||||
psTd2.style.width = '2%';
|
||||
psTitleDiv.id = psDiv.id + 'Title';
|
||||
psTitleDiv.className = 'panel-heading draggable-handler';
|
||||
psTitleDiv.innerHTML = ' Predict Sites Options...';
|
||||
psCloseDiv.className = 'panel-action';
|
||||
psCloseButton.className = 'panel-action-button';
|
||||
psCloseButton.title = 'Close';
|
||||
psCloseButtonI.className = 'fas fa-window-close';
|
||||
psCloseButton.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
closePredictSites();
|
||||
};
|
||||
psBodyDiv.className = 'panel-body';
|
||||
psBodyDiv.style.width =
|
||||
(Number(psDiv.style.width.replace('px')) - 6).toString() + 'px';
|
||||
psBodyDiv.style.height =
|
||||
(Number(psDiv.style.height.replace('px')) - 37).toString() + 'px';
|
||||
psBodyDiv.style.padding = '15px 10px';
|
||||
psBodyDiv.style.color = 'var(--fontcolor)';
|
||||
psBodyDiv.style.fontSize = '12px';
|
||||
psPolygonDiv.id = 'pnPolygon';
|
||||
psTechnologyDiv.id = 'pnTechnology';
|
||||
psButtonRun.className = 'btn btn-default';
|
||||
psButtonRun.style.position = 'absolute';
|
||||
psButtonRun.style.right = '10px';
|
||||
psButtonRun.style.bottom = '10px';
|
||||
psButtonRun.title = 'Run';
|
||||
psButtonRun.innerHTML = 'Run';
|
||||
psButtonRun.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
var testPolygon = undefined;
|
||||
var testTechnology = undefined;
|
||||
testTechnology = document.getElementById('pnTechnology').value;
|
||||
let feature = myPolygonsLayer.getSource().getFeatureByProperty('polygonname',
|
||||
document.getElementById('pnPolygon').value);
|
||||
if (feature) {
|
||||
if (feature.get('polygonid') !== undefined) {
|
||||
testPolygon = feature.get('polygonid');
|
||||
}
|
||||
}
|
||||
closePredictSites();
|
||||
if (testPolygon) {
|
||||
analysePredictSites(testPolygon, testTechnology);
|
||||
}
|
||||
};
|
||||
psButtonCancel.className = 'btn btn-default';
|
||||
psButtonCancel.style.position = 'absolute';
|
||||
psButtonCancel.style.right = '70px';
|
||||
psButtonCancel.style.bottom = '10px';
|
||||
psButtonCancel.title = 'Cancel';
|
||||
psButtonCancel.innerHTML = 'Cancel';
|
||||
psButtonCancel.onclick = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
closePredictSites();
|
||||
};
|
||||
let polygons = myPolygonsLayer.getSource().getFeatures();
|
||||
let polygonsList = "";
|
||||
for (let i = 0; i < polygons.length; i++) {
|
||||
polygonsList += polygons[i].getProperties().polygonname + '\t';
|
||||
}
|
||||
polygonsList = polygonsList.substr(0, polygonsList.length - 1);
|
||||
initSelectOpt(psPolygonDiv, '100%', polygonsList, '');
|
||||
initSelectOpt(psTechnologyDiv, '100%', '2G\t4G', '');
|
||||
// set draggable
|
||||
setDraggable();
|
||||
setDialogZIndex(null, psDiv.id);
|
||||
}
|
||||
}
|
||||
function closePredictSites() {
|
||||
let psd = document.getElementById('pnDiv');
|
||||
if (psd) {
|
||||
while (psd.firstChild) {
|
||||
psd.firstChild.remove();
|
||||
}
|
||||
document.getElementById('myMap').removeChild(psd);
|
||||
}
|
||||
}
|
||||
303
software/cnip/cnip/Scripts/cnip/webui/dialogs/siteoptions.js
Normal file
303
software/cnip/cnip/Scripts/cnip/webui/dialogs/siteoptions.js
Normal file
@@ -0,0 +1,303 @@
|
||||
/* global variables*/
|
||||
var userDisplay = false;
|
||||
var siteData;
|
||||
var sitesCount;
|
||||
var currSite;
|
||||
/* initialize controls*/
|
||||
document.getElementById('defaultOpen').click();
|
||||
initSelectOpt(document.getElementById('antennamodel'), '100%', 'LT OD9-5 890-950 MHz\tLT OD9-6 865-945 MHz\tLT OD9-6 860-960 MHz\tLT OD9-8 865-945 MHz\tLT OD9-8 860-960 MHz\tLT OD9-11 860-960 MHz\tLT OD9-11D1 860-960 MHz', 'LT OD9-5 890-950 MHz');
|
||||
/* setup listeners*/
|
||||
document.getElementById('sitename').addEventListener('change', siteNameChange);
|
||||
document.getElementById('longitude').addEventListener('change', longitudeChange);
|
||||
document.getElementById('latitude').addEventListener('change', latitudeChange);
|
||||
document.getElementById('height').addEventListener('change', heightChange);
|
||||
document.getElementById('region').addEventListener('change', propertyChange);
|
||||
document.getElementById('country').addEventListener('change', propertyChange);
|
||||
document.getElementById('city').addEventListener('change', propertyChange);
|
||||
document.getElementById('district').addEventListener('change', propertyChange);
|
||||
document.getElementById('province').addEventListener('change', propertyChange);
|
||||
document.getElementById('address').addEventListener('change', propertyChange);
|
||||
document.getElementById('comments').addEventListener('change', propertyChange);
|
||||
document.getElementById('rfcn').addEventListener('change', rfcnChange);
|
||||
document.getElementById('rfid').addEventListener('change', rfidChange);
|
||||
document.getElementById('rfpower').addEventListener('change', rfPowerChange);
|
||||
document.getElementById('hba').addEventListener('change', hbaChange);
|
||||
document.getElementById('antennamodel').addEventListener('change', antennaModelChange);
|
||||
document.getElementById('azimuth').addEventListener('change', azimuthChange);
|
||||
document.getElementById('feederloss').addEventListener('change', feederLossChange);
|
||||
/* siteoptions functions*/
|
||||
function siteNameChange(e) {
|
||||
document.getElementById('sitename').value = fixStringName(document.getElementById('sitename').value);
|
||||
saveSiteData(e);
|
||||
}
|
||||
function propertyChange(e) {
|
||||
document.getElementById('region').value = fixStringName(document.getElementById('region').value);
|
||||
document.getElementById('country').value = fixStringName(document.getElementById('country').value);
|
||||
document.getElementById('city').value = fixStringName(document.getElementById('city').value);
|
||||
document.getElementById('district').value = fixStringName(document.getElementById('district').value);
|
||||
document.getElementById('province').value = fixStringName(document.getElementById('province').value);
|
||||
document.getElementById('address').value = fixStringName(document.getElementById('address').value);
|
||||
document.getElementById('comments').value = fixStringName(document.getElementById('comments').value);
|
||||
saveSiteData(e);
|
||||
}
|
||||
function longitudeChange(e) {
|
||||
document.getElementById('longitude').value = Number(document.getElementById('longitude').value);
|
||||
if (document.getElementById('longitude').value.toString() !== siteData[2].toString()) {
|
||||
window.parent.deleteLinksBySiteId(siteData[0].toString());
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function latitudeChange(e) {
|
||||
document.getElementById('latitude').value = Number(document.getElementById('latitude').value);
|
||||
if (document.getElementById('latitude').value.toString() !== siteData[3].toString()) {
|
||||
window.parent.deleteLinksBySiteId(siteData[0].toString());
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function feederLossChange(e) {
|
||||
document.getElementById('feederloss').value = Number(document.getElementById('feederloss').value);
|
||||
if (Number(document.getElementById('feederloss').value) > 50) {
|
||||
document.getElementById('feederloss').value = 50;
|
||||
} else if (Number(document.getElementById('feederloss').value) < 0) {
|
||||
document.getElementById('feederloss').value = 0;
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function azimuthChange(e) {
|
||||
document.getElementById('azimuth').value = Number(document.getElementById('azimuth').value);
|
||||
if (Number(document.getElementById('azimuth').value) > 359) {
|
||||
document.getElementById('azimuth').value = 359;
|
||||
} else if (Number(document.getElementById('azimuth').value) < 0) {
|
||||
document.getElementById('azimuth').value = 0;
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function rfidChange(e) {
|
||||
document.getElementById('rfid').value = Number(document.getElementById('rfid').value);
|
||||
switch (document.getElementById('technology').value) {
|
||||
case '2G':
|
||||
if (Number(document.getElementById('rfid').value) > 77) {
|
||||
document.getElementById('rfid').value = 77;
|
||||
} else if (Number(document.getElementById('rfid').value) < 0) {
|
||||
document.getElementById('rfid').value = 0;
|
||||
}
|
||||
break;
|
||||
case '4G':
|
||||
if (Number(document.getElementById('rfid').value) > 503) {
|
||||
document.getElementById('rfid').value = 503;
|
||||
} else if (Number(document.getElementById('rfid').value) < 0) {
|
||||
document.getElementById('rfid').value = 0;
|
||||
}
|
||||
break;
|
||||
default: break;
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function rfcnChange(e) {
|
||||
document.getElementById('rfcn').value = Number(document.getElementById('rfcn').value);
|
||||
switch (document.getElementById('technology').value) {
|
||||
case '2G':
|
||||
if (Number(document.getElementById('rfcn').value) > 124) {
|
||||
document.getElementById('rfcn').value = 124;
|
||||
} else if (Number(document.getElementById('rfcn').value) < 1) {
|
||||
document.getElementById('rfcn').value = 1;
|
||||
}
|
||||
document.getElementById('dlfrequency').value = window.parent.getGSMDlfrequency(document.getElementById('rfcn').value);
|
||||
document.getElementById('ulfrequency').value = window.parent.getGSMUlfrequency(document.getElementById('rfcn').value);
|
||||
break;
|
||||
case '4G':
|
||||
if (Number(document.getElementById('rfcn').value) > 3799) {
|
||||
document.getElementById('rfcn').value = 3799;
|
||||
} else if (Number(document.getElementById('rfcn').value) < 3450) {
|
||||
document.getElementById('rfcn').value = 3450;
|
||||
}
|
||||
document.getElementById('dlfrequency').value = window.parent.getLTEDlfrequency(document.getElementById('rfcn').value);
|
||||
document.getElementById('ulfrequency').value = window.parent.getLTEUlfrequency(document.getElementById('rfcn').value);
|
||||
break;
|
||||
default: break;
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function rfPowerChange(e) {
|
||||
document.getElementById('rfpower').value = Number(document.getElementById('rfpower').value);
|
||||
if (Number(document.getElementById('rfpower').value) > 40) {
|
||||
document.getElementById('rfpower').value = 40;
|
||||
} else if (Number(document.getElementById('rfpower').value) < 1) {
|
||||
document.getElementById('rfpower').value = 1;
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function hbaChange(e) {
|
||||
document.getElementById('hba').value = Number(document.getElementById('hba').value);
|
||||
if (Number(document.getElementById('hba').value) > Number(document.getElementById('height').value)) {
|
||||
document.getElementById('height').value = document.getElementById('hba').value;
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function heightChange(e) {
|
||||
document.getElementById('height').value = Number(document.getElementById('height').value);
|
||||
if (Number(document.getElementById('height').value) < Number(document.getElementById('hba').value)) {
|
||||
document.getElementById('hba').value = document.getElementById('height').value;
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function antennaModelChange(e) {
|
||||
let antennaOptions = window.parent.getAntennaOptions(document.getElementById('antennamodel').value);
|
||||
document.getElementById('antennatype').value = antennaOptions.antennaType;
|
||||
document.getElementById('polarization').value = antennaOptions.polarization;
|
||||
document.getElementById('vbeamwidth').value = antennaOptions.vBeamWidth;
|
||||
document.getElementById('hbeamwidth').value = antennaOptions.hBeamWidth;
|
||||
document.getElementById('downtilt').value = antennaOptions.downTilt;
|
||||
document.getElementById('antennagain').value = antennaOptions.antennaGain;
|
||||
document.getElementById('azimuth').value = '0';
|
||||
if (document.getElementById('antennatype').value === 'Omni') {
|
||||
document.getElementById('azimuth').readonly = true;
|
||||
document.getElementById('azimuth').disabled = true;
|
||||
} else {
|
||||
document.getElementById('azimuth').readonly = false;
|
||||
document.getElementById('azimuth').disabled = false;
|
||||
}
|
||||
saveSiteData(e);
|
||||
}
|
||||
function fillSiteData(siteData) {
|
||||
// site
|
||||
document.getElementById('siteid').value = siteData[0] === undefined ? '' : siteData[0].toString();
|
||||
document.getElementById('sitename').value = siteData[1] === undefined ? '' : siteData[1].toString();
|
||||
document.getElementById('sitename1').value = siteData[1] === undefined ? '' : siteData[1].toString();
|
||||
document.getElementById('longitude').value = siteData[2] === undefined ? '' : siteData[2].toString();
|
||||
document.getElementById('latitude').value = siteData[3] === undefined ? '' : siteData[3].toString();
|
||||
// tower
|
||||
document.getElementById('height').value = siteData[4] === undefined ? '' : siteData[4].toString();
|
||||
// property
|
||||
document.getElementById('region').value = siteData[5] === undefined ? '' : siteData[5].toString();
|
||||
document.getElementById('country').value = siteData[6] === undefined ? '' : siteData[6].toString();
|
||||
document.getElementById('city').value = siteData[7] === undefined ? '' : siteData[7].toString();
|
||||
document.getElementById('district').value = siteData[8] === undefined ? '' : siteData[8].toString();
|
||||
document.getElementById('province').value = siteData[9] === undefined ? '' : siteData[9].toString();
|
||||
document.getElementById('address').value = siteData[10] === undefined ? '' : siteData[10].toString();
|
||||
document.getElementById('comments').value = siteData[11] === undefined ? '' : siteData[11].toString();
|
||||
// radio
|
||||
document.getElementById('technology').value = siteData[12] === undefined ? '' : siteData[12].toString();
|
||||
document.getElementById('technology1').value = siteData[12] === undefined ? '' : siteData[12].toString();
|
||||
document.getElementById('band').value = siteData[13] === undefined ? '' : siteData[13].toString();
|
||||
document.getElementById('bandwidth').value = siteData[14] === undefined ? '' : siteData[14].toString();
|
||||
document.getElementById('cellid').value = siteData[15] === undefined ? '' : siteData[15].toString();
|
||||
document.getElementById('lac').value = siteData[16] === undefined ? '' : siteData[16].toString();
|
||||
document.getElementById('rfcn').value = siteData[17] === undefined ? '' : siteData[17].toString();
|
||||
document.getElementById('rfid').value = siteData[18] === undefined ? '' : siteData[18].toString();
|
||||
document.getElementById('dlfrequency').value = siteData[19] === undefined ? '' : siteData[19].toString();
|
||||
document.getElementById('ulfrequency').value = siteData[20] === undefined ? '' : siteData[20].toString();
|
||||
document.getElementById('rfpower').value = siteData[21] === undefined ? '' : siteData[21].toString();
|
||||
// antenna
|
||||
document.getElementById('hba').value = siteData[22] === undefined ? '' : siteData[22].toString();
|
||||
document.getElementById('azimuth').value = siteData[23] === undefined ? '' : siteData[23].toString();
|
||||
document.getElementById('antennamodel').setOpt(siteData[24] === undefined ? '' : siteData[24].toString());
|
||||
document.getElementById('antennatype').value = siteData[25] === undefined ? '' : siteData[25].toString();
|
||||
document.getElementById('polarization').value = siteData[26] === undefined ? '' : siteData[26].toString();
|
||||
document.getElementById('vbeamwidth').value = siteData[27] === undefined ? '' : siteData[27].toString();
|
||||
document.getElementById('hbeamwidth').value = siteData[28] === undefined ? '' : siteData[28].toString();
|
||||
document.getElementById('downtilt').value = siteData[29] === undefined ? '' : siteData[29].toString();
|
||||
document.getElementById('antennagain').value = siteData[30] === undefined ? '' : siteData[30].toString();
|
||||
document.getElementById('feederloss').value = siteData[31] === undefined ? '' : siteData[31].toString();
|
||||
if (document.getElementById('antennatype').value === 'Omni') {
|
||||
document.getElementById('azimuth').readonly = true;
|
||||
document.getElementById('azimuth').disabled = true;
|
||||
} else {
|
||||
document.getElementById('azimuth').readonly = false;
|
||||
document.getElementById('azimuth').disabled = false;
|
||||
}
|
||||
}
|
||||
function refreshSiteData(refreshType, Idx = null) {
|
||||
let currSiteId = siteData === undefined ? 0 : siteData[0].toString();
|
||||
siteData = undefined; sitesCount = '0';
|
||||
sitesCount = window.parent.getSitesCount();
|
||||
if (Idx !== null) { currSite = Idx.toString(); }
|
||||
else {
|
||||
if (refreshType === 'start') { currSite = '0'; }
|
||||
else if (refreshType === 'add') { /* update */
|
||||
currSite = (Number(sitesCount) - 1).toString();
|
||||
}
|
||||
else if (refreshType === 'cursor') { /* update */
|
||||
currSite = window.parent.getSiteIdxById(currSiteId).toString();
|
||||
}
|
||||
else if (refreshType === 'delete') /*delete*/ {
|
||||
if (Number(currSite) > Number(sitesCount) - 1) {
|
||||
currSite = (Number(sitesCount) - 1).toString();
|
||||
}
|
||||
}
|
||||
}
|
||||
siteData = window.parent.getSiteDataByIdx(currSite).split('\t');
|
||||
fillSiteData(siteData);
|
||||
}
|
||||
function refreshSiteDataById(siteid) {
|
||||
refreshSiteData('', window.parent.getSiteIdxById(siteid).toString());
|
||||
}
|
||||
function nextSite(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (Number(sitesCount) - 1 > Number(currSite)) {
|
||||
refreshSiteData('', (Number(currSite) + 1).toString());
|
||||
}
|
||||
}
|
||||
function previousSite(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (Number(currSite) > 0) {
|
||||
refreshSiteData('', (Number(currSite) - 1).toString());
|
||||
}
|
||||
}
|
||||
function saveSiteData(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.updateSiteDataByIdx({
|
||||
//site
|
||||
idx: currSite,
|
||||
sitename: document.getElementById('sitename').value,
|
||||
longitude: document.getElementById('longitude').value,
|
||||
latitude: document.getElementById('latitude').value,
|
||||
// tower
|
||||
height: document.getElementById('height').value,
|
||||
// property
|
||||
region: document.getElementById('region').value,
|
||||
country: document.getElementById('country').value,
|
||||
city: document.getElementById('city').value,
|
||||
district: document.getElementById('district').value,
|
||||
province: document.getElementById('province').value,
|
||||
address: document.getElementById('address').value,
|
||||
comments: document.getElementById('comments').value,
|
||||
//radio
|
||||
technology: document.getElementById('technology').value,
|
||||
band: document.getElementById('band').value,
|
||||
bandwidth: document.getElementById('bandwidth').value,
|
||||
cellid: document.getElementById('cellid').value,
|
||||
lac: document.getElementById('lac').value,
|
||||
rfcn: document.getElementById('rfcn').value,
|
||||
rfid: document.getElementById('rfid').value,
|
||||
dlfrequency: document.getElementById('dlfrequency').value,
|
||||
ulfrequency: document.getElementById('ulfrequency').value,
|
||||
rfpower: document.getElementById('rfpower').value,
|
||||
//antenna
|
||||
hba: document.getElementById('hba').value,
|
||||
azimuth: document.getElementById('azimuth').value,
|
||||
antennamodel: document.getElementById('antennamodel').value,
|
||||
antennatype: document.getElementById('antennatype').value,
|
||||
polarization: document.getElementById('polarization').value,
|
||||
vbeamwidth: document.getElementById('vbeamwidth').value,
|
||||
hbeamwidth: document.getElementById('hbeamwidth').value,
|
||||
downtilt: document.getElementById('downtilt').value,
|
||||
antennagain: document.getElementById('antennagain').value,
|
||||
feederloss: document.getElementById('feederloss').value
|
||||
});
|
||||
refreshSiteData('cursor');
|
||||
window.parent.document.getElementById('linkOptionsFrame').contentWindow.refreshLinkData('cursor');
|
||||
window.parent.document.getElementById('linkProfileFrame').contentWindow.refreshLinkData('cursor');
|
||||
}
|
||||
function deleteSite(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.deleteSiteByIdx(currSite);
|
||||
refreshSiteData('delete');
|
||||
window.parent.document.getElementById('linkOptionsFrame').contentWindow.refreshLinkData('delete');
|
||||
window.parent.document.getElementById('linkProfileFrame').contentWindow.refreshLinkData('delete');
|
||||
}
|
||||
function zoomToSite(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
window.parent.document.getElementById('siteOptions').style.display = 'none';
|
||||
window.parent.zoomToSiteByIdx(currSite);
|
||||
}
|
||||
293
software/cnip/cnip/Scripts/cnip/webui/generic.js
Normal file
293
software/cnip/cnip/Scripts/cnip/webui/generic.js
Normal file
@@ -0,0 +1,293 @@
|
||||
var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;
|
||||
setDraggable();
|
||||
function setDraggable() {
|
||||
$('.draggable-handler').mousedown(function (e) {
|
||||
drag = $(this).closest('.draggable');
|
||||
drag.addClass('dragging');
|
||||
e = e || window.event;
|
||||
e.preventDefault();
|
||||
pos3 = e.clientX;
|
||||
pos4 = e.clientY;
|
||||
$(this).on('mousemove', function (e) {
|
||||
e = e || window.event;
|
||||
e.preventDefault();
|
||||
pos1 = pos3 - e.clientX;
|
||||
pos2 = pos4 - e.clientY;
|
||||
pos3 = e.clientX;
|
||||
pos4 = e.clientY;
|
||||
drag.css('top', $(this).offset().top - pos2 - /* border width*/3);
|
||||
drag.css('left', $(this).offset().left - pos1 - /* border width*/3);
|
||||
window.getSelection().removeAllRanges();
|
||||
});
|
||||
});
|
||||
$('.draggable-handler').mouseleave(stopDragging);
|
||||
$('.draggable-handler').mouseup(stopDragging);
|
||||
}
|
||||
function stopDragging(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
drag = $(this).closest('.draggable');
|
||||
drag.removeClass('dragging');
|
||||
$(this).off('mousemove');
|
||||
}
|
||||
function openPage(e, pageName, elmnt) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
var i, tabContent, tabLinks;
|
||||
tabContent = document.getElementsByClassName('pageTabContent');
|
||||
for (i = 0; i < tabContent.length; i++) {
|
||||
tabContent[i].style.display = 'none';
|
||||
}
|
||||
tabLinks = document.getElementsByClassName('pageTabLink');
|
||||
for (i = 0; i < tabLinks.length; i++) {
|
||||
tabLinks[i].style.backgroundColor = '';
|
||||
tabLinks[i].style.color = '';
|
||||
}
|
||||
document.getElementById(pageName).style.display = 'block';
|
||||
elmnt.style.backgroundColor = '#555';
|
||||
elmnt.style.color = 'white';
|
||||
}
|
||||
function round(value, precision) {
|
||||
return +(Math.round(value + 'e+' + precision) + 'e-' + precision);
|
||||
}
|
||||
function colorWithAlpha(color, alpha) {
|
||||
const [r, g, b] = Array.from(ol.color.asArray(color));
|
||||
return ol.color.asString([r, g, b, alpha]);
|
||||
}
|
||||
function sleep(milliseconds) {
|
||||
const date = Date.now();
|
||||
let currentDate = null;
|
||||
do {
|
||||
currentDate = Date.now();
|
||||
} while (currentDate - date < milliseconds);
|
||||
}
|
||||
var browser = (function (agent) {
|
||||
switch (true) {
|
||||
case agent.indexOf('edge') > -1: return 'edge';
|
||||
case agent.indexOf('edg') > -1: return 'chromium based edge (dev or canary)';
|
||||
case agent.indexOf('opr') > -1 && !!window.opr: return 'opera';
|
||||
case agent.indexOf('chrome') > -1 && !!window.chrome: return 'chrome';
|
||||
case agent.indexOf('trident') > -1: return 'ie';
|
||||
case agent.indexOf('firefox') > -1: return 'firefox';
|
||||
case agent.indexOf('safari') > -1: return 'safari';
|
||||
default: return 'other';
|
||||
}
|
||||
})(window.navigator.userAgent.toLowerCase());
|
||||
// digits obly check
|
||||
const digits_only = string => [...string].every(c => '.0123456789'.includes(c));
|
||||
// number check
|
||||
function isANumber(str) {
|
||||
return !/\D/.test(str);
|
||||
}
|
||||
// isnumeric
|
||||
var isNumber = function (value) { return /^\d+\.\d+$/.test(value); };
|
||||
// convert to title case
|
||||
function titleCase(str) {
|
||||
if (str) {
|
||||
return str.toString().toLowerCase().split(' ').map(function (word) {
|
||||
return word.replace(word[0], word[0].toUpperCase());
|
||||
}).join(' ');
|
||||
} else {
|
||||
return '';
|
||||
}
|
||||
}
|
||||
function fixStringName(stringName) {
|
||||
if (stringName) {
|
||||
return stringName.toString().replace(/[^A-Za-z0-9\s!?]/g, '');
|
||||
} else {
|
||||
return '';
|
||||
}
|
||||
}
|
||||
|
||||
function allLetter(inputtxt) {
|
||||
var letters = /^[A-Za-z]+$/;
|
||||
if (inputtxt.toString().match(letters)) {
|
||||
return true;
|
||||
}
|
||||
else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
var truncate = function (str, length) {
|
||||
if (str.length > length) {
|
||||
return str.substr(0, length - 3) + '...';
|
||||
} else {
|
||||
return str;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
/* no ui slider extension with value span control */
|
||||
function initSingleSlider(target, width, minValue, maxValue, stepSize, defaultValue) {
|
||||
if (!target.hasChildNodes()) {
|
||||
let sliTable = document.createElement('table');
|
||||
let sliTbody = document.createElement('tbody');
|
||||
let sliTr = document.createElement('tr');
|
||||
let sliTd1 = document.createElement('td');
|
||||
let sliTd2 = document.createElement('td');
|
||||
let sliDiv = document.createElement('div');
|
||||
let sliSpan = document.createElement('span');
|
||||
sliTd1.appendChild(sliDiv);
|
||||
sliTd2.appendChild(sliSpan);
|
||||
sliTr.appendChild(sliTd1);
|
||||
sliTr.appendChild(sliTd2);
|
||||
sliTbody.appendChild(sliTr);
|
||||
sliTable.appendChild(sliTbody);
|
||||
target.appendChild(sliTable);
|
||||
sliTable.id = target.id + '_table';
|
||||
sliDiv.id = target.id + '_slider';
|
||||
sliSpan.id = target.id + '_span';
|
||||
sliTable.style.width = '100%';
|
||||
sliTable.style.marginBottom = '5px';
|
||||
sliTd1.style.width = '85%';
|
||||
sliTd1.style.verticalAlign = 'middle';
|
||||
sliTd2.style.width = '15%';
|
||||
sliTd2.style.verticalAlign = 'middle';
|
||||
sliSpan.style.backgroundColor = 'var(--facecolor)';
|
||||
sliSpan.style.display = 'flex';
|
||||
sliSpan.style.padding = '5px 10px 5px 10px';
|
||||
sliSpan.style.marginLeft = '17px';
|
||||
sliSpan.style.justifyContent = 'center';
|
||||
sliSpan.style.width = '50px';
|
||||
sliSpan.style.fontSize = 'x-small';
|
||||
sliSpan.style.borderRadius = '4px';
|
||||
}
|
||||
let table_ = document.getElementById(target.id + '_table');
|
||||
let slider_ = document.getElementById(target.id + '_slider');
|
||||
let span_ = document.getElementById(target.id + '_span');
|
||||
if (width !== '') {
|
||||
table_.style.width = width;
|
||||
}
|
||||
span_.innerHTML = round(parseFloat(defaultValue), 1);
|
||||
target.value = parseFloat(defaultValue);
|
||||
noUiSlider.create(slider_, {
|
||||
start: parseFloat(defaultValue),
|
||||
connect: true,
|
||||
step: parseFloat(stepSize),
|
||||
range: {
|
||||
'min': parseFloat(minValue),
|
||||
'max': parseFloat(maxValue)
|
||||
}
|
||||
});
|
||||
slider_.noUiSlider.on('change', function (values, handle) {
|
||||
let value = values[handle];
|
||||
span_.innerHTML = round(value, 1);
|
||||
target.value = value;
|
||||
if ('createEvent' in document) {
|
||||
let evt = document.createEvent('Event');
|
||||
evt.initEvent('change', true, true);
|
||||
target.dispatchEvent(evt);
|
||||
} else {
|
||||
target.fireEvent('onchange');
|
||||
}
|
||||
});
|
||||
slider_.noUiSlider.on('set', function (values, handle) {
|
||||
let value = values[handle];
|
||||
span_.innerHTML = round(value, 1);
|
||||
target.value = value;
|
||||
});
|
||||
target.setValue = function (value) {
|
||||
if (this.hasChildNodes) {
|
||||
if (this.firstChild.id.includes('_table')) {
|
||||
this.firstChild.firstChild.firstChild.firstChild.firstChild.noUiSlider.set(value);
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
/* Select Option no ui control */
|
||||
function initSelectOpt(target, width, lstOpt, defaultValue) {
|
||||
if (!target.hasChildNodes()) {
|
||||
let sopButton = document.createElement('button');
|
||||
let sopDiv = document.createElement('div');
|
||||
target.appendChild(sopButton);
|
||||
target.appendChild(sopDiv);
|
||||
sopButton.id = target.id + '_selectBar';
|
||||
sopButton.className = 'selectBar collapsed';
|
||||
sopButton.setAttribute('data-toggle', 'collapse');
|
||||
sopDiv.id = target.id + '_selectDiv';
|
||||
sopDiv.className = 'selectDiv collapse';
|
||||
}
|
||||
let selectBar = target.firstChild;
|
||||
let selectDiv = selectBar.nextElementSibling;
|
||||
let dataset = [];
|
||||
lstOpt.split('\t').forEach(function (item, index) {
|
||||
dataset.push({ columnname: item, datatype: 'str', class: 'datatypstr' });
|
||||
});
|
||||
if (width !== '') {
|
||||
selectBar.style.width = width;
|
||||
}
|
||||
selectBar.dataset.target = '#' + selectDiv.id;
|
||||
target.value = '';
|
||||
selectBar.innerHTML = '<i class="fa fa-caret-down" style="float: right"></i>';
|
||||
selectDiv.innerHTML = '';
|
||||
for (let i = 0; i < dataset.length; i++) {
|
||||
selectDiv.innerHTML += '<div class="selectList" onclick="this.parentElement.choose(event);" data-value="'
|
||||
+ dataset[i].columnname + '">' + dataset[i].columnname + '</div>';
|
||||
if (dataset[i].columnname === defaultValue) {
|
||||
target.value = defaultValue;
|
||||
selectBar.innerHTML = defaultValue + '<i class="fa fa-caret-down" style="float: right"></i>';
|
||||
}
|
||||
}
|
||||
if (target.value === '' && dataset.length > 0) {
|
||||
target.value = dataset[0].columnname;
|
||||
selectBar.innerHTML = dataset[0].columnname + '<i class="fa fa-caret-down" style="float: right"></i>';
|
||||
}
|
||||
selectBar.hide = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let selectBar = e.currentTarget;
|
||||
let selectDiv = selectBar.nextElementSibling;
|
||||
if (selectDiv.mouseIsOver === false) {
|
||||
selectDiv.className = 'selectDiv collapse';
|
||||
selectBar.className = 'selectBar collapsed';
|
||||
}
|
||||
};
|
||||
selectBar.focus = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let selectBar = e.currentTarget;
|
||||
let selectDiv = selectBar.nextElementSibling;
|
||||
selectDiv.style.width = selectBar.offsetWidth + 'px';
|
||||
};
|
||||
selectDiv.choose = function (e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let target = e.currentTarget.parentElement.parentElement;
|
||||
let selectBar = e.currentTarget.parentElement.previousElementSibling;
|
||||
let selectDiv = e.currentTarget.parentElement;
|
||||
target.value = e.currentTarget.dataset.value;
|
||||
selectBar.innerHTML = e.currentTarget.dataset.value + '<i class="fa fa-caret-down" style="float: right"></i>';
|
||||
selectDiv.className = 'selectDiv collapse';
|
||||
selectBar.className = 'selectBar collapsed';
|
||||
if ('createEvent' in document) {
|
||||
var evt = document.createEvent('Event');
|
||||
evt.initEvent('change', true, true);
|
||||
target.dispatchEvent(evt);
|
||||
} else {
|
||||
target.fireEvent('onchange');
|
||||
}
|
||||
};
|
||||
selectBar.addEventListener('focus', selectBar.focus);
|
||||
selectBar.addEventListener('focusout', selectBar.hide);
|
||||
selectDiv.mouseIsOver = false;
|
||||
selectDiv.onmouseover = () => {
|
||||
selectDiv.mouseIsOver = true;
|
||||
};
|
||||
selectDiv.onmouseout = () => {
|
||||
selectDiv.mouseIsOver = false;
|
||||
};
|
||||
target.setOpt = function (value) {
|
||||
if (this.hasChildNodes) {
|
||||
if (this.firstChild.className.includes('selectBar') && this.firstChild.id.includes('selectBar')) {
|
||||
this.firstChild.innerHTML = value + '<i class="fa fa-caret-down" style="float: right"></i>';
|
||||
this.value = value;
|
||||
}
|
||||
}
|
||||
};
|
||||
target.reloadOpt = function (value) {
|
||||
if (this.hasChildNodes) {
|
||||
if (this.firstChild.className.includes('selectBar') && this.firstChild.id.includes('selectBar')) {
|
||||
initSelectOpt(this, '', value, '');
|
||||
}
|
||||
}
|
||||
};
|
||||
selectBar.addEventListener('click', function () {
|
||||
$(selectBar.getAttribute('data-target')).collapse('toggle');
|
||||
});
|
||||
}
|
||||
318
software/cnip/cnip/Scripts/cnip/webui/interactions.js
Normal file
318
software/cnip/cnip/Scripts/cnip/webui/interactions.js
Normal file
@@ -0,0 +1,318 @@
|
||||
// Select interaction
|
||||
var select = new ol.interaction.Select({
|
||||
condition: ol.events.condition.singleClick,
|
||||
hitTolerance: 10,
|
||||
wrapX: false,
|
||||
toggleCondition: ol.events.condition.shiftKeyOnly,
|
||||
style: selectStyle
|
||||
});
|
||||
myMap.addInteraction(select);
|
||||
select.setActive(false);
|
||||
selection = select.getFeatures();
|
||||
selection.on('add', function (e) {
|
||||
if (actionRunning) { return; }
|
||||
let feature = e.target.getArray()[0];
|
||||
if (feature.get('linkid') !== undefined) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
//display link profile
|
||||
document.getElementById('linkProfile').style.display = 'block';
|
||||
document.getElementById('linkProfileFrame').contentWindow.refreshLinkDataById(feature.get('linkid'));
|
||||
document.getElementById('linkProfileFrame').contentWindow.userDisplay = true;
|
||||
setDialogZIndex(null, 'linkProfile');
|
||||
clearInteractions();
|
||||
}
|
||||
if (feature.get('noteid') !== undefined) {
|
||||
if (feature.get('email') === undefined) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
document.getElementById('noteOptions').style.display = 'block';
|
||||
document.getElementById('noteOptionsFrame').contentWindow.refreshNoteDataById(feature.get('noteid'));
|
||||
document.getElementById('noteOptionsFrame').contentWindow.userDisplay = true;
|
||||
setDialogZIndex(null, 'noteOptions');
|
||||
clearInteractions();
|
||||
}
|
||||
}
|
||||
if (feature.get('polygonid') !== undefined) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
document.getElementById('polyOptions').style.display = 'block';
|
||||
document.getElementById('polyOptionsFrame').contentWindow.refreshPolygonDataById(feature.get('polygonid'));
|
||||
document.getElementById('polyOptionsFrame').contentWindow.userDisplay = true;
|
||||
setDialogZIndex(null, 'polyOptions');
|
||||
clearInteractions();
|
||||
}
|
||||
if (feature.get('siteid') !== undefined) {
|
||||
if (feature.get('email') === undefined) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
document.getElementById('siteOptions').style.display = 'block';
|
||||
document.getElementById('siteOptionsFrame').contentWindow.refreshSiteDataById(feature.get('siteid'));
|
||||
document.getElementById('siteOptionsFrame').contentWindow.userDisplay = true;
|
||||
setDialogZIndex(null, 'siteOptions');
|
||||
clearInteractions();
|
||||
}
|
||||
}
|
||||
});
|
||||
// ******* Link interactions
|
||||
var addLink = new ol.interaction.Select({
|
||||
condition: ol.events.condition.singleClick,
|
||||
hitTolerance: 1,
|
||||
wrapX: false,
|
||||
layers: function (layer) { return layer === myNetworkLayer; },
|
||||
style: drawLinkSiteStyle
|
||||
});
|
||||
myMap.addInteraction(addLink);
|
||||
addLink.setActive(false);
|
||||
var siteASelected = undefined;
|
||||
var pointCount = 0;
|
||||
var addedLink = addLink.getFeatures();
|
||||
addedLink.on('add', function (e) {
|
||||
if (!siteASelected) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
drawLink.setActive(true);
|
||||
let feature = e.target.getArray()[0];
|
||||
siteASelected = feature;
|
||||
let coordinate = feature.getGeometry().getCoordinates();
|
||||
let clickEvent = $.Event('click');
|
||||
clickEvent.map = myMap;
|
||||
clickEvent.coordinate = coordinate;
|
||||
drawLink.startDrawing_(clickEvent);
|
||||
}
|
||||
else {
|
||||
if (e) { e.stopPropagation(); }
|
||||
drawLink.finishDrawing();
|
||||
drawLink.setActive(false);
|
||||
let feature = e.target.getArray()[0];
|
||||
createLink({
|
||||
siteida: siteASelected.get('siteid'),
|
||||
locationA: ol.proj.toLonLat(siteASelected.getGeometry().getCoordinates()),
|
||||
siteidb: feature.get('siteid'),
|
||||
locationB: ol.proj.toLonLat(feature.getGeometry().getCoordinates())
|
||||
});
|
||||
document.getElementById('linkOptionsFrame').contentWindow.refreshLinkData('add');
|
||||
clearInteractions();
|
||||
}
|
||||
});
|
||||
//document.addEventListener('click', function (e) {
|
||||
// //if (siteASelected) {
|
||||
// // if (e) { e.stopPropagation(); }
|
||||
// // pointCount = pointCount + 1;
|
||||
// // if (pointCount > 1) {
|
||||
// // drawLink.removeLastPoint();
|
||||
// // pointCount = pointCount - 1;
|
||||
// // }
|
||||
// //}
|
||||
//});
|
||||
var drawLink = new ol.interaction.Draw({ source: myLinksLayer.getSource(), type: 'LineString', style: drawLinkLineStyle });
|
||||
myMap.addInteraction(drawLink);
|
||||
drawLink.setActive(false);
|
||||
var drawLinkTip = new ol.Overlay.Tooltip();
|
||||
myMap.addOverlay(drawLinkTip);
|
||||
drawLink.on('drawstart', function () { drawLinkTip.setInfo('Select site B to create link'); drawLinkTip.setFeature.bind(drawLinkTip); pointCount = 1; });
|
||||
drawLink.on(['change:active', 'drawend'], function () { drawLinkTip.setInfo(''); drawLinkTip.removeFeature.bind(drawLinkTip); });
|
||||
var selectLink = new ol.interaction.Select({
|
||||
condition: ol.events.condition.singleClick,
|
||||
hitTolerance: 5,
|
||||
wrapX: false,
|
||||
toggleCondition: ol.events.condition.shiftKeyOnly,
|
||||
layers: function (layer) { return layer === myLinksLayer; },
|
||||
style: selectStyle
|
||||
});
|
||||
myMap.addInteraction(selectLink);
|
||||
selectLink.setActive(false);
|
||||
var deleteLinkActive = false;
|
||||
var snapLink = new ol.interaction.Snap({ source: myLinksLayer.getSource() });
|
||||
myMap.addInteraction(snapLink);
|
||||
snapLink.setActive(false);
|
||||
var selectedLink = selectLink.getFeatures();
|
||||
selectedLink.on('add', function (e) {
|
||||
if (deleteLinkActive === true) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
selectLink.getFeatures().forEach(function (feature) {
|
||||
myLinksLayer.getSource().removeFeature(feature);
|
||||
myMap.render();
|
||||
});
|
||||
loadLinksTreeFromSource();
|
||||
document.getElementById('linkOptionsFrame').contentWindow.refreshLinkData('delete');
|
||||
document.getElementById('linkProfileFrame').contentWindow.refreshLinkData('delete');
|
||||
// clear all tools here
|
||||
clearInteractions();
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
// ******* Polygon interactions
|
||||
var selectPolygon = new ol.interaction.Select({
|
||||
condition: ol.events.condition.singleClick,
|
||||
hitTolerance: 5,
|
||||
wrapX: false,
|
||||
toggleCondition: ol.events.condition.shiftKeyOnly,
|
||||
layers: function (layer) { return layer === myPolygonsLayer; },
|
||||
style: selectStyle
|
||||
});
|
||||
myMap.addInteraction(selectPolygon);
|
||||
selectPolygon.setActive(false);
|
||||
var drawPolygon = new ol.interaction.Draw({ source: myPolygonsLayer.getSource(), type: 'Polygon', style: drawPolygonStyle });
|
||||
myMap.addInteraction(drawPolygon);
|
||||
drawPolygon.setActive(false);
|
||||
document.addEventListener('keydown', function (e) {
|
||||
if (e.which === 27) {
|
||||
if (drawPolygon.getActive()) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
drawPolygon.removeLastPoint();
|
||||
}
|
||||
if (addLink.getActive()) {
|
||||
drawLink.removeLastPoint();
|
||||
drawLink.setActive(false);
|
||||
clearInteractions();
|
||||
}
|
||||
}
|
||||
});
|
||||
var drawPolygonTip = new ol.Overlay.Tooltip();
|
||||
myMap.addOverlay(drawPolygonTip);
|
||||
drawPolygon.on('drawstart', function () { drawPolygonTip.setInfo('Click ESC to remove last point'); drawPolygonTip.setFeature.bind(drawPolygonTip); });
|
||||
drawPolygon.on(['change:active', 'drawend'], function () { drawPolygonTip.setInfo(''); drawPolygonTip.removeFeature.bind(drawPolygonTip); });
|
||||
var modifyPolygon = new ol.interaction.Modify({ features: selectPolygon.getFeatures() });
|
||||
myMap.addInteraction(modifyPolygon);
|
||||
modifyPolygon.setActive(false);
|
||||
var transformPolygon = new ol.interaction.Transform({ features: selectPolygon.getFeatures() });
|
||||
myMap.addInteraction(transformPolygon);
|
||||
transformPolygon.setActive(false);
|
||||
var deletePolygonActive = false;
|
||||
var snapPolygon = new ol.interaction.Snap({ source: myPolygonsLayer.getSource() });
|
||||
myMap.addInteraction(snapPolygon);
|
||||
snapPolygon.setActive(false);
|
||||
var selectedPolygon = selectPolygon.getFeatures();
|
||||
selectedPolygon.on('add', function (e) {
|
||||
if (transformPolygon.getActive() === true) {
|
||||
transformPolygon.setSelection(selectPolygon.getFeatures());
|
||||
}
|
||||
if (deletePolygonActive === true) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
selectPolygon.getFeatures().forEach(function (feature) {
|
||||
myPolygonsLayer.getSource().removeFeature(feature);
|
||||
myMap.render();
|
||||
});
|
||||
loadPolygonsTreeFromSource();
|
||||
document.getElementById('polyOptionsFrame').contentWindow.refreshPolygonData('delete');
|
||||
// clear all tools here
|
||||
clearInteractions();
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
// ******* Site interactions
|
||||
var selectSite = new ol.interaction.Select({
|
||||
condition: ol.events.condition.singleClick,
|
||||
hitTolerance: 5,
|
||||
wrapX: false,
|
||||
toggleCondition: ol.events.condition.shiftKeyOnly,
|
||||
layers: function (layer) { return layer === myNetworkLayer; },
|
||||
style: selectStyle
|
||||
});
|
||||
myMap.addInteraction(selectSite);
|
||||
selectSite.setActive(false);
|
||||
var drawSite2G = new ol.interaction.Draw({ source: myNetworkLayer.getSource(), type: 'Point', style: drawSiteStyle });
|
||||
myMap.addInteraction(drawSite2G);
|
||||
drawSite2G.setActive(false);
|
||||
var drawSite4G = new ol.interaction.Draw({ source: myNetworkLayer.getSource(), type: 'Point', style: drawSiteStyle });
|
||||
myMap.addInteraction(drawSite4G);
|
||||
drawSite4G.setActive(false);
|
||||
var modifySite = new ol.interaction.Modify({ features: selectSite.getFeatures() });
|
||||
myMap.addInteraction(modifySite);
|
||||
modifySite.setActive(false);
|
||||
var deleteSiteActive = false;
|
||||
var snapSite = new ol.interaction.Snap({ source: myNetworkLayer.getSource() });
|
||||
myMap.addInteraction(snapSite);
|
||||
snapSite.setActive(false);
|
||||
var selectedSite = selectSite.getFeatures();
|
||||
selectedSite.on('add', function (e) {
|
||||
if (deleteSiteActive === true) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
selectSite.getFeatures().forEach(function (feature) {
|
||||
deleteLinksBySiteId(feature.get('siteid'));
|
||||
myNetworkLayer.getSource().removeFeature(feature);
|
||||
myMap.render();
|
||||
});
|
||||
loadSitesTreeFromSource();
|
||||
document.getElementById('siteOptionsFrame').contentWindow.refreshSiteData('delete');
|
||||
document.getElementById('linkOptionsFrame').contentWindow.refreshLinkData('delete');
|
||||
document.getElementById('linkProfileFrame').contentWindow.refreshLinkData('delete');
|
||||
// clear all tools here
|
||||
clearInteractions();
|
||||
}
|
||||
});
|
||||
modifySite.on('modifyend', function (e) {
|
||||
let feature = e.features.getArray()[0];
|
||||
if (feature.get('siteid') !== undefined) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let coordinates3857 = feature.getGeometry().getCoordinates();
|
||||
let coordinates4326 = ol.proj.transform(coordinates3857, 'EPSG:3857', 'EPSG:4326');
|
||||
feature.setProperties({
|
||||
'longitude': coordinates4326[0],
|
||||
'latitude': coordinates4326[1]
|
||||
});
|
||||
myMap.render();
|
||||
deleteLinksBySiteId(feature.get('siteid'));
|
||||
loadSitesTreeFromSource();
|
||||
document.getElementById('siteOptionsFrame').contentWindow.refreshSiteData('cursor');
|
||||
document.getElementById('linkOptionsFrame').contentWindow.refreshLinkData('delete');
|
||||
document.getElementById('linkProfileFrame').contentWindow.refreshLinkData('delete');
|
||||
// clear all tools here
|
||||
clearInteractions();
|
||||
}
|
||||
});
|
||||
|
||||
// notes interactions
|
||||
// ******* Note interactions
|
||||
var selectNote = new ol.interaction.Select({
|
||||
condition: ol.events.condition.singleClick,
|
||||
hitTolerance: 5,
|
||||
wrapX: false,
|
||||
toggleCondition: ol.events.condition.shiftKeyOnly,
|
||||
layers: function (layer) { return layer === myNotesLayer; },
|
||||
style: selectStyle
|
||||
});
|
||||
myMap.addInteraction(selectNote);
|
||||
selectNote.setActive(false);
|
||||
var drawNote = new ol.interaction.Draw({
|
||||
source: myNotesLayer.getSource(),
|
||||
type: 'Point', style: drawNoteStyle
|
||||
});
|
||||
myMap.addInteraction(drawNote);
|
||||
drawNote.setActive(false);
|
||||
var modifyNote = new ol.interaction.Modify({ features: selectNote.getFeatures() });
|
||||
myMap.addInteraction(modifyNote);
|
||||
modifyNote.setActive(false);
|
||||
var deleteNoteActive = false;
|
||||
var snapNote = new ol.interaction.Snap({ source: myNotesLayer.getSource() });
|
||||
myMap.addInteraction(snapNote);
|
||||
snapNote.setActive(false);
|
||||
var selectedNote = selectNote.getFeatures();
|
||||
selectedNote.on('add', function (e) {
|
||||
if (deleteNoteActive === true) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
selectNote.getFeatures().forEach(function (feature) {
|
||||
myNotesLayer.getSource().removeFeature(feature);
|
||||
myMap.render();
|
||||
});
|
||||
loadNotesTreeFromSource();
|
||||
document.getElementById('noteOptionsFrame').contentWindow.refreshNoteData('delete');
|
||||
// clear all tools here
|
||||
clearInteractions();
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
|
||||
|
||||
// measure line && area interactions
|
||||
var measureLine = new ol.interaction.Draw({ type: 'LineString' });
|
||||
myMap.addInteraction(measureLine);
|
||||
measureLine.setActive(false);
|
||||
var measureArea = new ol.interaction.Draw({ type: 'Polygon' });
|
||||
myMap.addInteraction(measureArea);
|
||||
measureArea.setActive(false);
|
||||
var measureTip = new ol.Overlay.Tooltip();
|
||||
myMap.addOverlay(measureTip);
|
||||
measureLine.on('drawstart', measureTip.setFeature.bind(measureTip));
|
||||
measureLine.on(['change:active', 'drawend'], measureTip.removeFeature.bind(measureTip));
|
||||
measureArea.on('drawstart', measureTip.setFeature.bind(measureTip));
|
||||
measureArea.on(['change:active', 'drawend'], measureTip.removeFeature.bind(measureTip));
|
||||
79
software/cnip/cnip/Scripts/cnip/webui/legend.js
Normal file
79
software/cnip/cnip/Scripts/cnip/webui/legend.js
Normal file
@@ -0,0 +1,79 @@
|
||||
var myLegend = new ol.control.Legend({
|
||||
title: 'Legend',
|
||||
collapsed: true,
|
||||
margin: 5,
|
||||
size: [20, 10]
|
||||
});
|
||||
myMap.addControl(myLegend);
|
||||
myLegend.addRow({ title: 'Legend' });
|
||||
function setLegend(thematicString) {
|
||||
// ,&$#@>
|
||||
// result : thematicString>pngString>polygonsString@polygonsString
|
||||
// thematicString
|
||||
// rate&r,g,b$rate&r,g,b
|
||||
// pngString
|
||||
// png,1,2,3,4
|
||||
// polygonsString
|
||||
// polygonid,polygonname#siteid,sitename#png,1,2,3,4#
|
||||
// cttrue,ctext1234#rate&value&r,g,b$rate&value&r,g,b#bestcandidate
|
||||
clearLegend();
|
||||
if (thematicString) {
|
||||
if (thematicString.length > 0) {
|
||||
let rows = thematicString.split('$');
|
||||
let lastTitleValue = '+s';
|
||||
for (let i = 0; i < rows.length; i++) {
|
||||
let titleValue = rows[i].split('&')[0];
|
||||
let rgb = rows[i].split('&')[1].split(',');
|
||||
myLegend.addRow(
|
||||
{
|
||||
title: allLetter(titleValue) ? titleValue : lastTitleValue + ' to ' + titleValue,
|
||||
typeGeom: 'Point',
|
||||
style: new ol.style.Style({
|
||||
image: new ol.style.RegularShape({
|
||||
points: 4,
|
||||
radius: 5,
|
||||
stroke: new ol.style.Stroke({ color: [rgb[0], rgb[1], rgb[2], 1], width: 1.5 }),
|
||||
fill: new ol.style.Fill({ color: [rgb[0], rgb[1], rgb[2], 0.85] })
|
||||
})
|
||||
})
|
||||
}
|
||||
);
|
||||
lastTitleValue = titleValue;
|
||||
}
|
||||
myLegend.show();
|
||||
}
|
||||
}
|
||||
}
|
||||
function clearLegend() {
|
||||
while (myLegend.getLength() > 0) {
|
||||
for (let i = 0; i < myLegend.getLength(); i++) {
|
||||
myLegend.removeRow(i);
|
||||
}
|
||||
}
|
||||
}
|
||||
function showLegend() {
|
||||
let button = document.getElementById('myMap').querySelector(
|
||||
'div.ol-legend.ol-unselectable.ol-control.ol-collapsed button'
|
||||
);
|
||||
if (button) {
|
||||
fireClick(button);
|
||||
}
|
||||
}
|
||||
var fireClick = function (node) {
|
||||
if (typeof MouseEvent === 'function') {
|
||||
var mevt = new MouseEvent('click', {
|
||||
bubbles: false,
|
||||
cancelable: true
|
||||
});
|
||||
node.dispatchEvent(mevt);
|
||||
} else if (document.createEvent) {
|
||||
// Fallback
|
||||
var evt = document.createEvent('MouseEvents');
|
||||
evt.initEvent('click', false, false);
|
||||
node.dispatchEvent(evt);
|
||||
} else if (document.createEventObject) {
|
||||
node.fireEvent('onclick');
|
||||
} else if (typeof node.onclick === 'function') {
|
||||
node.onclick();
|
||||
}
|
||||
};
|
||||
83
software/cnip/cnip/Scripts/cnip/webui/ol.vector.extension.js
Normal file
83
software/cnip/cnip/Scripts/cnip/webui/ol.vector.extension.js
Normal file
@@ -0,0 +1,83 @@
|
||||
ol.source.Vector.prototype.clone = function () {
|
||||
let JsonFeatures = new ol.format.GeoJSON().writeFeaturesObject(
|
||||
this.getFeatures(),
|
||||
{ featureProjection: 'EPSG:3857', dataProjection: 'EPSG:4326' });
|
||||
let source = new ol.source.Vector({
|
||||
features: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}).readFeatures(JsonFeatures),
|
||||
wrapX: false
|
||||
});
|
||||
return source;
|
||||
};
|
||||
ol.source.Vector.prototype.getJSONString = function (beautify = false) {
|
||||
let JSONString;
|
||||
if (beautify) {
|
||||
JSONString = JSON.stringify(
|
||||
new ol.format.GeoJSON().writeFeaturesObject(
|
||||
this.getFeatures(),
|
||||
{ featureProjection: 'EPSG:3857', dataProjection: 'EPSG:4326' }
|
||||
), undefined, '\t'
|
||||
);
|
||||
} else {
|
||||
JSONString = JSON.stringify(
|
||||
new ol.format.GeoJSON().writeFeaturesObject(
|
||||
this.getFeatures(),
|
||||
{ featureProjection: 'EPSG:3857', dataProjection: 'EPSG:4326' }
|
||||
)
|
||||
);
|
||||
}
|
||||
return JSONString;
|
||||
};
|
||||
ol.source.Vector.prototype.getKMLString = function (beautify = false) {
|
||||
let KMLString;
|
||||
if (beautify) {
|
||||
KMLString =
|
||||
JSON.stringify(
|
||||
new ol.format.KML({
|
||||
extractStyles: true,
|
||||
showPointNames: true,
|
||||
writeStyles: true
|
||||
}).writeFeatures(
|
||||
this.getFeatures(),
|
||||
{ featureProjection: 'EPSG:3857', dataProjection: 'EPSG:4326' }
|
||||
), undefined, '\t'
|
||||
);
|
||||
} else {
|
||||
KMLString =
|
||||
JSON.stringify(
|
||||
new ol.format.KML({
|
||||
extractStyles: true,
|
||||
showPointNames: true,
|
||||
writeStyles: true
|
||||
}).writeFeatures(
|
||||
this.getFeatures(),
|
||||
{ featureProjection: 'EPSG:3857', dataProjection: 'EPSG:4326' }
|
||||
)
|
||||
);
|
||||
}
|
||||
KMLString = KMLString.replace(/\\/g, '');
|
||||
KMLString = KMLString.slice(1, -1);
|
||||
return KMLString;
|
||||
};
|
||||
ol.source.Vector.prototype.getFeatureByProperty = function (propertyname, propertyvalue) {
|
||||
let matchedfeature = undefined;
|
||||
if (propertyname && propertyvalue) {
|
||||
let features = this.getFeatures();
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
if (features[i].get(propertyname).toString() === propertyvalue.toString()) {
|
||||
matchedfeature = features[i]; break;
|
||||
}
|
||||
}
|
||||
}
|
||||
return matchedfeature;
|
||||
};
|
||||
ol.source.Vector.prototype.clearFeatures = function () {
|
||||
while (this.getFeatures().length > 0) {
|
||||
let features = this.getFeatures();
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
this.removeFeature(features[i]);
|
||||
}
|
||||
}
|
||||
};
|
||||
99
software/cnip/cnip/Scripts/cnip/webui/rendermap.js
Normal file
99
software/cnip/cnip/Scripts/cnip/webui/rendermap.js
Normal file
@@ -0,0 +1,99 @@
|
||||
$('.ol-control.ol-bar button[title]').tooltip({
|
||||
placement: 'bottom', trigger: 'hover'
|
||||
});
|
||||
$('#activeInteraction').tooltip({
|
||||
placement: 'bottom', trigger: 'hover'
|
||||
});
|
||||
$('.ol-zoom button[title]').tooltip({
|
||||
placement: 'left', trigger: 'hover'
|
||||
});
|
||||
$('.ol-search button[title]').tooltip({
|
||||
placement: 'left', trigger: 'hover'
|
||||
});
|
||||
$('.ol-legend.ol-unselectable.ol-control.ol-collapsed').attr('title', 'Legend');
|
||||
$('.ol-legend.ol-unselectable.ol-control.ol-collapsed').tooltip({
|
||||
placement: 'left', trigger: 'hover'
|
||||
});
|
||||
$('.ol-full-screen-false').html('<i class=\"fas fa-expand-arrows-alt\"></i>');
|
||||
|
||||
while (!select) { let i = 0; }
|
||||
while (!addedLink) { let i = 0; }
|
||||
myMap.on('pointermove', function (e) {
|
||||
if (actionRunning) { return; }
|
||||
if (e.dragging) {
|
||||
//featureTip.attr('data-original-title', '').tooltip('hide');
|
||||
locationInfo.style.opacity = 0; locationInfo.innerHTML = '';
|
||||
noteInfo.style.opacity = 0; noteInfo.innerHTML = '';
|
||||
return;
|
||||
}
|
||||
setPointerStyle(e);
|
||||
if (select.getActive()) {
|
||||
displayElevation(e);
|
||||
}
|
||||
if (select.getActive() || addLink.getActive() ||
|
||||
deleteSiteActive || deleteLinkActive ||
|
||||
deletePolygonActive || deleteNoteActive) {
|
||||
displayFeatureInfo(e);
|
||||
}
|
||||
});
|
||||
myMap.on('click', function (e) {
|
||||
if (siteASelected) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
pointCount = pointCount + 1;
|
||||
if (pointCount > 1) {
|
||||
drawLink.removeLastPoint();
|
||||
pointCount = pointCount - 1;
|
||||
}
|
||||
}
|
||||
|
||||
if (actionRunning) { return; }
|
||||
if (!select.getActive()) { return; }
|
||||
let pixel = myMap.getEventPixel(e.originalEvent);
|
||||
let feature = myMap.forEachFeatureAtPixel(pixel,
|
||||
function (feature) { return feature; });
|
||||
if (!feature) { return; }
|
||||
if (feature.get('linkid') !== undefined) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
document.getElementById('linkOptionsFrame').contentWindow.refreshLinkDataById(feature.get('linkid'));
|
||||
}
|
||||
//if (feature.get('polygonid') !== undefined) {
|
||||
// if (e) { e.stopPropagation(); }
|
||||
// document.getElementById('polyOptionsFrame').contentWindow.refreshPolygonDataById(feature.get('polygonid'));
|
||||
//}
|
||||
//if (feature.get('siteid') !== undefined) {
|
||||
// if (e) { e.stopPropagation(); }
|
||||
// document.getElementById('siteOptionsFrame').contentWindow.refreshSiteDataById(feature.get('siteid'));
|
||||
//}
|
||||
//if (feature.get('noteid') !== undefined) {
|
||||
// if (e) { e.stopPropagation(); }
|
||||
// document.getElementById('noteOptionsFrame').contentWindow.refreshNoteDataById(feature.get('noteid'));
|
||||
//}
|
||||
});
|
||||
|
||||
while (!document.getElementById('siteOptionsFrame').contentWindow.document) { let i = 0; }
|
||||
while (!document.getElementById('polyOptionsFrame').contentWindow.document) { let i = 0; }
|
||||
while (!document.getElementById('noteOptionsFrame').contentWindow.document) { let i = 0; }
|
||||
while (!document.getElementById('linkOptionsFrame').contentWindow.document) { let i = 0; }
|
||||
while (!document.getElementById('linkProfileFrame').contentWindow.document) { let i = 0; }
|
||||
document.getElementById('siteOptionsFrame').contentWindow.document.onclick =
|
||||
function () {
|
||||
setDialogZIndex(null, 'siteOptions');
|
||||
};
|
||||
document.getElementById('polyOptionsFrame').contentWindow.document.onclick =
|
||||
function () {
|
||||
setDialogZIndex(null, 'polyOptions');
|
||||
};
|
||||
document.getElementById('noteOptionsFrame').contentWindow.document.onclick =
|
||||
function () {
|
||||
setDialogZIndex(null, 'noteOptions');
|
||||
};
|
||||
document.getElementById('linkOptionsFrame').contentWindow.document.onclick =
|
||||
function () {
|
||||
setDialogZIndex(null, 'linkOptions');
|
||||
};
|
||||
document.getElementById('linkProfileFrame').contentWindow.document.onclick =
|
||||
function () {
|
||||
setDialogZIndex(null, 'linkProfile');
|
||||
};
|
||||
|
||||
myMap.render();
|
||||
9
software/cnip/cnip/Scripts/cnip/webui/sidebar/account.js
Normal file
9
software/cnip/cnip/Scripts/cnip/webui/sidebar/account.js
Normal file
@@ -0,0 +1,9 @@
|
||||
document.getElementById('uname').innerHTML = username;
|
||||
document.getElementById('uemail').innerHTML = email;
|
||||
/* account functions*/
|
||||
function Logoff(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
Ajax_runccmd("Logoff", "");
|
||||
window.open('../pages/glavni.aspx', '_self');
|
||||
}
|
||||
@@ -0,0 +1 @@
|
||||
|
||||
253
software/cnip/cnip/Scripts/cnip/webui/sidebar/mylinks.js
Normal file
253
software/cnip/cnip/Scripts/cnip/webui/sidebar/mylinks.js
Normal file
@@ -0,0 +1,253 @@
|
||||
$('#linksDiv').collapse({
|
||||
toggle: true
|
||||
});
|
||||
var linksTree = document.getElementById('linksUl');
|
||||
initSingleSlider(document.getElementById('linksStrokeOpacity'), '', '0', '1', '0.1', '1');
|
||||
document.getElementById('linksStrokeOpacity').addEventListener('change', setLinksStyle);
|
||||
loadLinksTreeFromFile();
|
||||
/* link functions*/
|
||||
function setLinksStyle(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let custStyle = function (feature) {
|
||||
let strokeOpacity = Number($('#linksStrokeOpacity').val());
|
||||
return [new ol.style.Style({
|
||||
stroke: new ol.style.Stroke({
|
||||
color: feature.get('linktype') === 'internal' ?
|
||||
colorWithAlpha('#00ffff', strokeOpacity) :
|
||||
colorWithAlpha('#ffe300', strokeOpacity),
|
||||
lineDash: [7, 7],
|
||||
width: 4
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
text: feature.get('linkname'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: 'rgba(0,0,0,' + strokeOpacity + ')' }),
|
||||
stroke: new ol.style.Stroke({ color: 'rgba(0,0,0,' + strokeOpacity + ')', width: 2 })
|
||||
})
|
||||
})];
|
||||
};
|
||||
myLinksLayer.setStyle(custStyle);
|
||||
myMap.render();
|
||||
}
|
||||
function loadLinksTreeFromFile() {
|
||||
let httpRequest = new XMLHttpRequest();
|
||||
httpRequest.open('GET', '../' + vectorsPath + 'mylinks.geojson', true);
|
||||
httpRequest.send();
|
||||
httpRequest.onload = function () {
|
||||
let source = JSON.parse(httpRequest.responseText);
|
||||
linksTree.innerHTML = '';
|
||||
if (typeof source.features !== 'undefined') {
|
||||
for (let i = 0; i < source.features.length; i++) {
|
||||
linksTree.innerHTML = linksTree.innerHTML +
|
||||
'<li class="visualLi" onclick="showLinkOptionsByIdx(event,' +
|
||||
i.toString() + ');"><i class="fas fa-link"></i> ' +
|
||||
source.features[i].properties.linkname + '</li>';
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
function loadLinksTreeFromSource() {
|
||||
let features = myLinksLayer.getSource().getFeatures();
|
||||
linksTree.innerHTML = '';
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
linksTree.innerHTML = linksTree.innerHTML +
|
||||
'<li class="visualLi" onclick="showLinkOptionsByIdx(event,' +
|
||||
i.toString() + ');"><i class="fas fa-link"></i> ' +
|
||||
features[i].getProperties().linkname + '</li>';
|
||||
}
|
||||
}
|
||||
function showLinkOptionsByIdx(e, Idx) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
document.getElementById('linkOptions').style.display = 'block';
|
||||
document.getElementById('linkOptions').style.left = 'calc(50vw - 651px / 2)';
|
||||
document.getElementById('linkOptions').style.top = 'calc(50vh - 432px / 2)';
|
||||
document.getElementById('linkOptions').style.width = '651px';
|
||||
document.getElementById('linkOptions').style.height = '432px';
|
||||
document.getElementById('linkOptionsFrame').contentWindow.userDisplay = true;
|
||||
document.getElementById('linkOptionsFrame').contentWindow.refreshLinkData('', Idx);
|
||||
setDialogZIndex(null, 'linkOptions');
|
||||
}
|
||||
function getLinkDataByIdx(Idx) {
|
||||
return getDataByIdx(myLinksLayer.getSource(), Idx);
|
||||
}
|
||||
function getLinkProfileByIdx(Idx) {
|
||||
let returnString = '';
|
||||
if (Idx) {
|
||||
if (Number(Idx) > -1) {
|
||||
let feature = myLinksLayer.getSource().getFeatures()[Idx];
|
||||
let keys = feature.getKeys();
|
||||
for (let j = 0; j < keys.length; j++) {
|
||||
if (keys[j] !== 'geometry') {
|
||||
returnString += feature.get(keys[j]).toString() + '\t';
|
||||
}
|
||||
}
|
||||
returnString = returnString.substring(0, returnString.length - 1);
|
||||
}
|
||||
}
|
||||
return returnString;
|
||||
}
|
||||
function getPublicSiteData(siteidb, email) {
|
||||
let feature = getPublicSite(siteidb, email);
|
||||
let returnString = '';
|
||||
if (feature) {
|
||||
let keys = feature.getKeys();
|
||||
for (let j = 0; j < keys.length; j++) {
|
||||
if (keys[j] !== 'geometry') {
|
||||
returnString += feature.get(keys[j]).toString() + '\t';
|
||||
}
|
||||
}
|
||||
returnString = returnString.substring(0, returnString.length - 1);
|
||||
}
|
||||
return returnString;
|
||||
}
|
||||
function getPublicSite(siteidb, email) {
|
||||
if (siteidb) {
|
||||
if (Number(siteidb) > -1) {
|
||||
if (email) {
|
||||
let features = publicNetworkLayer.getSource().getFeatures();
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
if (features[i].get('siteid') === siteidb && features[i].get('email') === email) {
|
||||
return features[i];
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
function getLinkIdxById(linkid) {
|
||||
return getIdxById(myLinksLayer.getSource(), 'linkid', linkid);
|
||||
}
|
||||
function zoomToLinkByIdx(Idx) {
|
||||
zoomToFeatureByIdx(myLinksLayer.getSource(), Idx);
|
||||
}
|
||||
function updateLinkDataByIdx(options) {
|
||||
if (options.idx) {
|
||||
if (Number(options.idx) > -1) {
|
||||
let feature = myLinksLayer.getSource().getFeatures()[options.idx];
|
||||
feature.set('linkname', options.linkname.toString());
|
||||
feature.set('channelwidtha', options.channelwidtha.toString());
|
||||
feature.set('frequencya', options.frequencya.toString());
|
||||
feature.set('outputpowera', options.outputpowera.toString());
|
||||
feature.set('antennagaina', options.antennagaina.toString());
|
||||
feature.set('lossesa', options.lossesa.toString());
|
||||
feature.set('channelwidthb', options.channelwidthb.toString());
|
||||
feature.set('frequencyb', options.frequencyb.toString());
|
||||
feature.set('outputpowerb', options.outputpowerb.toString());
|
||||
feature.set('antennagainb', options.antennagainb.toString());
|
||||
feature.set('lossesb', options.lossesb.toString());
|
||||
myMap.render();
|
||||
loadLinksTreeFromSource();
|
||||
}
|
||||
}
|
||||
}
|
||||
function getLinksCount() {
|
||||
return getFeaturesCount(myLinksLayer.getSource());
|
||||
}
|
||||
function deleteLinkByIdx(Idx) {
|
||||
deleteFeatureByIdx(myLinksLayer.getSource(), Idx);
|
||||
loadLinksTreeFromSource();
|
||||
clearInteractions();
|
||||
}
|
||||
function deleteLinksBySiteId(siteid) {
|
||||
let feature = undefined;
|
||||
feature = myLinksLayer.getSource().getFeatureByProperty('siteida', siteid);
|
||||
while (feature) {
|
||||
myLinksLayer.getSource().removeFeature(feature);
|
||||
feature = myLinksLayer.getSource().getFeatureByProperty('siteida', siteid);
|
||||
}
|
||||
feature = myLinksLayer.getSource().getFeatureByProperty('siteidb', siteid);
|
||||
while (feature) {
|
||||
myLinksLayer.getSource().removeFeature(feature);
|
||||
feature = myLinksLayer.getSource().getFeatureByProperty('siteidb', siteid);
|
||||
}
|
||||
myMap.render();
|
||||
loadLinksTreeFromSource();
|
||||
clearInteractions();
|
||||
}
|
||||
myLinksLayer.getSource().on('addfeature', function (event) {
|
||||
if (event.feature.get('linkid') === undefined) {
|
||||
myLinksLayer.getSource().removeFeature(event.feature);
|
||||
}
|
||||
});
|
||||
function downloadLinksCSV(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting CSV');
|
||||
setTimeout(function () {
|
||||
download.CSV(myLinksLayer.getSource(), 'mylinks');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function downloadLinksJson(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting JSON');
|
||||
setTimeout(function () {
|
||||
download.JSON(myLinksLayer.getSource(), 'mylinks');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function downloadLinksKML(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting KML');
|
||||
setTimeout(function () {
|
||||
download.KML(myLinksLayer.getSource(), 'mylinks');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function saveVectorsToServer(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (getActionRunning()) { return; }
|
||||
showProgress('Saving Vectors');
|
||||
setTimeout(function () {
|
||||
saveAllVectors();
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function createLink(options) {
|
||||
let linkid = getNewIdx(myLinksLayer.getSource(), 'linkid');
|
||||
let elevationString = Ajax_runccmd("GetElevationStringFromLineString",
|
||||
"{'lineString':'LINESTRING(" +
|
||||
options.locationA[0] + " " +
|
||||
options.locationA[1] + "," +
|
||||
options.locationB[0] + " " +
|
||||
options.locationB[1] + ")'}").split('#');
|
||||
let distanceToLocationB = Ajax_runccmd("Distance",
|
||||
"{'longitude1':'" + options.locationA[0] +
|
||||
"','latitude1':'" + options.locationA[1] +
|
||||
"','longitude2':'" + options.locationB[0] +
|
||||
"','latitude2':'" + options.locationB[1] + "'}") / 1000;
|
||||
let feature = new ol.Feature({
|
||||
'linkid': linkid,
|
||||
'linkname': 'my link ' + linkid,
|
||||
'linktype': 'internal',
|
||||
'siteida': options.siteida,
|
||||
'locheighta': elevationString[0],
|
||||
'bearinga': round(turf.bearingToAzimuth(turf.bearing(
|
||||
turf.point(options.locationA), turf.point(options.locationB))), 2),
|
||||
'channelwidtha': document.getElementById('opt_channelwidth').value,
|
||||
'frequencya': document.getElementById('opt_frequency').value,
|
||||
'outputpowera': document.getElementById('opt_outputpower').value,
|
||||
'antennagaina': document.getElementById('opt_antennagain').value,
|
||||
'lossesa': document.getElementById('opt_losses').value,
|
||||
'siteidb': options.siteidb,
|
||||
'locheightb': elevationString[1],
|
||||
'bearingb': round(turf.bearingToAzimuth(turf.bearing(
|
||||
turf.point(options.locationB), turf.point(options.locationA))), 2),
|
||||
'channelwidthb': document.getElementById('opt_channelwidth').value,
|
||||
'frequencyb': document.getElementById('opt_frequency').value,
|
||||
'outputpowerb': document.getElementById('opt_outputpower').value,
|
||||
'antennagainb': document.getElementById('opt_antennagain').value,
|
||||
'lossesb': document.getElementById('opt_losses').value,
|
||||
'distance': distanceToLocationB,
|
||||
'elevstr': elevationString[2],
|
||||
geometry: new ol.geom.LineString(
|
||||
[options.locationA, options.locationB]).transform('EPSG:4326', 'EPSG:3857')
|
||||
});
|
||||
myLinksLayer.getSource().addFeature(feature);
|
||||
myMap.render();
|
||||
loadLinksTreeFromSource();
|
||||
}
|
||||
323
software/cnip/cnip/Scripts/cnip/webui/sidebar/mynetwork.js
Normal file
323
software/cnip/cnip/Scripts/cnip/webui/sidebar/mynetwork.js
Normal file
@@ -0,0 +1,323 @@
|
||||
$('#sitesDiv').collapse({
|
||||
toggle: true
|
||||
});
|
||||
var sitesTree = document.getElementById('sitesUl');
|
||||
initSingleSlider(document.getElementById('sitesIconOpacity'), '', '0', '1', '0.1', '1');
|
||||
document.getElementById('sitesIconOpacity').addEventListener('change', setSitesStyle);
|
||||
loadSitesTreeFromFile();
|
||||
/* site functions*/
|
||||
function setSitesStyle(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let custStyle = function (feature) {
|
||||
let iconOpacity = Number($('#sitesIconOpacity').val());
|
||||
return [new ol.style.Style({
|
||||
image: feature.get('technology') === '4G' ? new ol.style.Icon({
|
||||
scale: .6,
|
||||
src: '../img/site4G.png',
|
||||
opacity: iconOpacity
|
||||
}) : new ol.style.Icon({
|
||||
scale: .6,
|
||||
src: '../img/site2G.png',
|
||||
opacity: iconOpacity
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
offsetY: 25,
|
||||
text: feature.get('sitename'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: 'rgba(0,0,0,' + iconOpacity + ')' }),
|
||||
stroke: new ol.style.Stroke({ color: 'rgba(255,255,255,' + iconOpacity + ')', width: 2 })
|
||||
})
|
||||
})];
|
||||
};
|
||||
myNetworkLayer.setStyle(custStyle);
|
||||
myMap.render();
|
||||
}
|
||||
function loadSitesTreeFromFile() {
|
||||
let httpRequest = new XMLHttpRequest();
|
||||
httpRequest.open('GET', '../' + vectorsPath + 'mynetwork.geojson', true);
|
||||
httpRequest.send();
|
||||
httpRequest.onload = function () {
|
||||
let source = JSON.parse(httpRequest.responseText);
|
||||
sitesTree.innerHTML = '';
|
||||
if (typeof source.features !== 'undefined') {
|
||||
for (let i = 0; i < source.features.length; i++) {
|
||||
sitesTree.innerHTML = sitesTree.innerHTML +
|
||||
'<li class="visualLi" onclick="showSiteOptionsByIdx(event,' +
|
||||
i.toString() + ');"><i class="fas fa-broadcast-tower"' +
|
||||
(source.features[i].properties.technology === '4G' ?
|
||||
' style="color:rgb(255,106,0);" ' : '') + '></i> ' +
|
||||
truncate(source.features[i].properties.sitename,27) + '</li>';
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
function loadSitesTreeFromSource() {
|
||||
let features = myNetworkLayer.getSource().getFeatures();
|
||||
sitesTree.innerHTML = '';
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
sitesTree.innerHTML = sitesTree.innerHTML +
|
||||
'<li class="visualLi" onclick="showSiteOptionsByIdx(event,' +
|
||||
i.toString() + ');"><i class="fas fa-broadcast-tower"' +
|
||||
(features[i].getProperties().technology === '4G' ?
|
||||
' style="color:rgb(255,106,0);" ' : '') + '></i> ' +
|
||||
truncate(features[i].getProperties().sitename,27) + '</li>';
|
||||
}
|
||||
}
|
||||
function showSiteOptionsByIdx(e,Idx) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
document.getElementById('siteOptions').style.display = 'block';
|
||||
document.getElementById('siteOptions').style.left = 'calc(50vw - 651px / 2)';
|
||||
document.getElementById('siteOptions').style.top = 'calc(50vh - 432px / 2)';
|
||||
document.getElementById('siteOptions').style.width = '651px';
|
||||
document.getElementById('siteOptions').style.height = '432px';
|
||||
document.getElementById('siteOptionsFrame').contentWindow.userDisplay = true;
|
||||
document.getElementById('siteOptionsFrame').contentWindow.refreshSiteData('', Idx);
|
||||
setDialogZIndex(null,'siteOptions');
|
||||
}
|
||||
myNetworkLayer.getSource().on('addfeature', function (event) {
|
||||
if (event.feature.get('siteid') === undefined) {
|
||||
let newid = getNewIdx(myNetworkLayer.getSource(), 'siteid');
|
||||
let coordinates3857 = event.feature.getGeometry().getCoordinates();
|
||||
let coordinates4326 = ol.proj.transform(
|
||||
coordinates3857, 'EPSG:3857', 'EPSG:4326');
|
||||
let antennaOptions = getAntennaOptions(
|
||||
document.getElementById('opt_antennamodel').value);
|
||||
event.feature.setProperties({
|
||||
//site
|
||||
'siteid': newid,
|
||||
'sitename': 'new site ' + newid,
|
||||
'longitude': coordinates4326[0],
|
||||
'latitude': coordinates4326[1],
|
||||
//tower
|
||||
'height': '',
|
||||
//property
|
||||
'region': '',
|
||||
'country': '',
|
||||
'city': '',
|
||||
'district': '',
|
||||
'province': '',
|
||||
'address': '',
|
||||
'comments': '',
|
||||
//radio
|
||||
'technology': drawSite2G.getActive() ? '2G' : '4G',
|
||||
'band': drawSite2G.getActive() ?
|
||||
document.getElementById('opt_gsmband').value :
|
||||
document.getElementById('opt_lteband').value,
|
||||
'bandwidth': drawSite2G.getActive() ?
|
||||
document.getElementById('opt_gsmbandwidth').value :
|
||||
document.getElementById('opt_ltebandwidth').value,
|
||||
'cellid': 10000 + parseInt(newid),
|
||||
'lac': LAC,
|
||||
'rfcn': '',
|
||||
'rfid': '',
|
||||
'dlfrequency': '',
|
||||
'ulfrequency': '',
|
||||
'rfpower': '',
|
||||
//antenna
|
||||
'hba': '',
|
||||
'azimuth': '0',
|
||||
'antennamodel': antennaOptions.antennaModel,
|
||||
'antennatype': antennaOptions.antennaType,
|
||||
'polarization': antennaOptions.polarization,
|
||||
'vbeamwidth': antennaOptions.vBeamWidth,
|
||||
'hbeamwidth': antennaOptions.hBeamWidth,
|
||||
'downtilt': antennaOptions.downTilt,
|
||||
'antennagain': antennaOptions.antennaGain,
|
||||
'feederloss': '0'
|
||||
});
|
||||
loadSitesTreeFromSource();
|
||||
document.getElementById('siteOptionsFrame').contentWindow.refreshSiteData('add');
|
||||
}
|
||||
});
|
||||
function getSiteDataByIdx(Idx) {
|
||||
return getDataByIdx(myNetworkLayer.getSource(), Idx);
|
||||
}
|
||||
function getSiteIdxById(siteid) {
|
||||
return getIdxById(myNetworkLayer.getSource(), 'siteid', siteid);
|
||||
}
|
||||
function getSiteDataById(siteid) {
|
||||
return getSiteDataByIdx(getSiteIdxById(siteid));
|
||||
}
|
||||
function zoomToSiteByIdx(Idx) {
|
||||
zoomToFeatureByIdx(myNetworkLayer.getSource(), Idx);
|
||||
}
|
||||
function updateSiteDataByIdx(options) {
|
||||
if (options.idx) {
|
||||
if (Number(options.idx) > -1) {
|
||||
let feature = myNetworkLayer.getSource().getFeatures()[options.idx];
|
||||
//site
|
||||
feature.set('sitename', options.sitename.toString());
|
||||
feature.set('longitude', options.longitude.toString());
|
||||
feature.set('latitude', options.latitude.toString());
|
||||
//tower
|
||||
feature.set('height', options.height.toString());
|
||||
//property
|
||||
feature.set('region', options.region.toString());
|
||||
feature.set('country', options.country.toString());
|
||||
feature.set('city', options.city.toString());
|
||||
feature.set('district', options.district.toString());
|
||||
feature.set('province', options.province.toString());
|
||||
feature.set('address', options.address.toString());
|
||||
feature.set('comments', options.comments.toString());
|
||||
//radio
|
||||
feature.set('technology', options.technology.toString());
|
||||
feature.set('band', options.band.toString());
|
||||
feature.set('bandwidth', options.bandwidth.toString());
|
||||
feature.set('cellid', options.cellid.toString());
|
||||
feature.set('lac', options.lac.toString());
|
||||
feature.set('rfcn', options.rfcn.toString());
|
||||
feature.set('rfid', options.rfid.toString());
|
||||
feature.set('dlfrequency', options.dlfrequency.toString());
|
||||
feature.set('ulfrequency', options.ulfrequency.toString());
|
||||
feature.set('rfpower', options.rfpower.toString());
|
||||
//antenna
|
||||
feature.set('hba', options.hba.toString());
|
||||
feature.set('azimuth', options.azimuth.toString());
|
||||
feature.set('antennamodel', options.antennamodel.toString());
|
||||
feature.set('antennatype', options.antennatype.toString());
|
||||
feature.set('polarization', options.polarization.toString());
|
||||
feature.set('vbeamwidth', options.vbeamwidth.toString());
|
||||
feature.set('hbeamwidth', options.hbeamwidth.toString());
|
||||
feature.set('downtilt', options.downtilt.toString());
|
||||
feature.set('antennagain', options.antennagain.toString());
|
||||
feature.set('feederloss', options.feederloss.toString());
|
||||
//geometry
|
||||
feature.set('geometry', new ol.geom.Point(ol.proj.fromLonLat(
|
||||
[Number(options.longitude), Number(options.latitude)])));
|
||||
myMap.render();
|
||||
loadSitesTreeFromSource();
|
||||
}
|
||||
}
|
||||
}
|
||||
function getSitesCount() {
|
||||
return getFeaturesCount(myNetworkLayer.getSource());
|
||||
}
|
||||
function deleteSiteByIdx(Idx) {
|
||||
let siteData = getSiteDataByIdx(Idx);
|
||||
if (siteData) { deleteLinksBySiteId(siteData[0].toString()); }
|
||||
deleteFeatureByIdx(myNetworkLayer.getSource(), Idx);
|
||||
loadSitesTreeFromSource();
|
||||
clearInteractions();
|
||||
}
|
||||
function downloadSitesCSV(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting CSV');
|
||||
setTimeout(function () {
|
||||
download.CSV(myNetworkLayer.getSource(), 'mynetwork');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function downloadSitesJson(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting JSON');
|
||||
setTimeout(function () {
|
||||
download.JSON(myNetworkLayer.getSource(), 'mynetwork');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function downloadSitesKML(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting KML');
|
||||
setTimeout(function () {
|
||||
download.KML(myNetworkLayer.getSource(), 'mynetwork');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function getAntennaOptions(antennaModel) {
|
||||
let Options;
|
||||
switch (antennaModel.toString()) {
|
||||
case 'LT OD9-5 890-950 MHz':
|
||||
Options = {
|
||||
antennaModel: 'LT OD9-5 890-950 MHz',
|
||||
antennaType: 'Omni',
|
||||
polarization: 'Vertical',
|
||||
vBeamWidth: '36',
|
||||
hBeamWidth: '360',
|
||||
downTilt: '0',
|
||||
antennaGain: '5'
|
||||
};
|
||||
break;
|
||||
case 'LT OD9-6 865-945 MHz':
|
||||
Options = {
|
||||
antennaModel: 'LT OD9-6 865-945 MHz',
|
||||
antennaType: 'Omni',
|
||||
polarization: 'Vertical',
|
||||
vBeamWidth: '16',
|
||||
hBeamWidth: '360',
|
||||
downTilt: '0',
|
||||
antennaGain: '6'
|
||||
};
|
||||
break;
|
||||
case 'LT OD9-6 860-960 MHz':
|
||||
Options = {
|
||||
antennaModel: 'LT OD9-6 860-960 MHz',
|
||||
antennaType: 'Omni',
|
||||
polarization: 'Vertical',
|
||||
vBeamWidth: '16',
|
||||
hBeamWidth: '360',
|
||||
downTilt: '0',
|
||||
antennaGain: '6'
|
||||
};
|
||||
break;
|
||||
case 'LT OD9-8 865-945 MHz':
|
||||
Options = {
|
||||
antennaModel: 'LT OD9-8 865-945 MHz',
|
||||
antennaType: 'Omni',
|
||||
polarization: 'Vertical',
|
||||
vBeamWidth: '10',
|
||||
hBeamWidth: '360',
|
||||
downTilt: '0',
|
||||
antennaGain: '8'
|
||||
};
|
||||
break;
|
||||
case 'LT OD9-8 860-960 MHz':
|
||||
Options = {
|
||||
antennaModel: 'LT OD9-8 860-960 MHz',
|
||||
antennaType: 'Omni',
|
||||
polarization: 'Vertical',
|
||||
vBeamWidth: '10',
|
||||
hBeamWidth: '360',
|
||||
downTilt: '0',
|
||||
antennaGain: '8'
|
||||
};
|
||||
break;
|
||||
case 'LT OD9-11 860-960 MHz':
|
||||
Options = {
|
||||
antennaModel: 'LT OD9-11 860-960 MHz',
|
||||
antennaType: 'Omni',
|
||||
polarization: 'Vertical',
|
||||
vBeamWidth: '7',
|
||||
hBeamWidth: '360',
|
||||
downTilt: '0',
|
||||
antennaGain: '11'
|
||||
};
|
||||
break;
|
||||
case 'LT OD9-11D1 860-960 MHz':
|
||||
Options = {
|
||||
antennaModel: 'LT OD9-11D1 860-960 MHz',
|
||||
antennaType: 'Omni',
|
||||
polarization: 'Vertical',
|
||||
vBeamWidth: '7',
|
||||
hBeamWidth: '360',
|
||||
downTilt: '1',
|
||||
antennaGain: '11'
|
||||
};
|
||||
break;
|
||||
default:
|
||||
Options = {
|
||||
antennaModel: 'LT OD9-5 890-950 MHz',
|
||||
antennaType: 'Omni',
|
||||
polarization: 'Vertical',
|
||||
vBeamWidth: '36',
|
||||
hBeamWidth: '360',
|
||||
downTilt: '0',
|
||||
antennaGain: '5'
|
||||
};
|
||||
break;
|
||||
}
|
||||
return Options;
|
||||
}
|
||||
140
software/cnip/cnip/Scripts/cnip/webui/sidebar/mynotes.js
Normal file
140
software/cnip/cnip/Scripts/cnip/webui/sidebar/mynotes.js
Normal file
@@ -0,0 +1,140 @@
|
||||
$('#notesDiv').collapse({
|
||||
toggle: true
|
||||
});
|
||||
var notesTree = document.getElementById('notesUl');
|
||||
initSingleSlider(document.getElementById('notesOpacity'), '', '0', '1', '0.1', '1');
|
||||
document.getElementById('notesOpacity').addEventListener('change', setNotesStyle);
|
||||
loadNotesTreeFromFile();
|
||||
/* note functions*/
|
||||
function setNotesStyle(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let custStyle = function (feature) {
|
||||
let noteOpacity = Number($('#notesOpacity').val());
|
||||
return [new ol.style.Style({
|
||||
image: feature.get('notetype') === 'Public' ? new ol.style.Icon({
|
||||
scale: 1,
|
||||
src: '../img/notePublic.png',
|
||||
opacity: noteOpacity
|
||||
}) : new ol.style.Icon({
|
||||
scale: 1,
|
||||
src: '../img/notePrivate.png',
|
||||
opacity: noteOpacity
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
offsetY: 25,
|
||||
text: feature.get('notename'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: 'rgba(0,0,0,'+noteOpacity+')' }),
|
||||
stroke: new ol.style.Stroke({ color: 'rgba(255,255,255,' + noteOpacity + ')', width: 2 })
|
||||
})
|
||||
})];
|
||||
};
|
||||
myNotesLayer.setStyle(custStyle);
|
||||
myMap.render();
|
||||
}
|
||||
function loadNotesTreeFromFile() {
|
||||
let httpRequest = new XMLHttpRequest();
|
||||
httpRequest.open('GET', '../' + vectorsPath + 'mynotes.geojson', true);
|
||||
httpRequest.send();
|
||||
httpRequest.onload = function () {
|
||||
let source = JSON.parse(httpRequest.responseText);
|
||||
notesTree.innerHTML = '';
|
||||
if (typeof source.features !== 'undefined') {
|
||||
for (let i = 0; i < source.features.length; i++) {
|
||||
notesTree.innerHTML = notesTree.innerHTML +
|
||||
'<li class="visualLi" onclick="showNoteOptionsByIdx(event,' + i.toString() + ');"><i class="fas fa-flag"></i> ' +
|
||||
truncate(source.features[i].properties.notename,27) + '</li>';
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
function loadNotesTreeFromSource() {
|
||||
let features = myNotesLayer.getSource().getFeatures();
|
||||
notesTree.innerHTML = '';
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
notesTree.innerHTML = notesTree.innerHTML +
|
||||
'<li class="visualLi" onclick="showNoteOptionsByIdx(event,' + i.toString() + ');"><i class="fas fa-flag"></i> ' +
|
||||
truncate(features[i].getProperties().notename,27) + '</li>';
|
||||
}
|
||||
}
|
||||
function showNoteOptionsByIdx(e, Idx) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
document.getElementById('noteOptions').style.display = 'block';
|
||||
document.getElementById('noteOptions').style.left = 'calc(50vw - 451px / 2)';
|
||||
document.getElementById('noteOptions').style.top = 'calc(50vh - 236px / 2)';
|
||||
document.getElementById('noteOptions').style.width = '451px';
|
||||
document.getElementById('noteOptions').style.height = '236px';
|
||||
document.getElementById('noteOptionsFrame').contentWindow.userDisplay = true;
|
||||
document.getElementById('noteOptionsFrame').contentWindow.refreshNoteData('', Idx);
|
||||
setDialogZIndex(null, 'noteOptions');
|
||||
}
|
||||
myNotesLayer.getSource().on('addfeature', function (event) {
|
||||
if (event.feature.get('noteid') === undefined) {
|
||||
let newid = getNewIdx(myNotesLayer.getSource(), 'noteid');
|
||||
event.feature.setProperties({
|
||||
'noteid': newid,
|
||||
'notename': 'new note ' + newid,
|
||||
'notetype': 'Private',
|
||||
'description': 'new note'
|
||||
});
|
||||
loadNotesTreeFromSource();
|
||||
document.getElementById('noteOptionsFrame').contentWindow.refreshNoteData('add');
|
||||
}
|
||||
});
|
||||
function getNoteDataByIdx(Idx) {
|
||||
return getDataByIdx(myNotesLayer.getSource(), Idx);
|
||||
}
|
||||
function getNoteIdxById(noteid) {
|
||||
return getIdxById(myNotesLayer.getSource(), 'noteid', noteid);
|
||||
}
|
||||
function zoomToNoteByIdx(Idx) {
|
||||
zoomToFeatureByIdx(myNotesLayer.getSource(), Idx);
|
||||
}
|
||||
function updateNoteDataByIdx(Idx, notename, notetype, description) {
|
||||
if (Idx) {
|
||||
if (Number(Idx) > -1) {
|
||||
let feature = myNotesLayer.getSource().getFeatures()[Idx];
|
||||
feature.set('notename', notename.toString());
|
||||
feature.set('notetype', notetype.toString());
|
||||
feature.set('description', description.toString());
|
||||
myMap.render();
|
||||
loadNotesTreeFromSource();
|
||||
}
|
||||
}
|
||||
}
|
||||
function getNotesCount() {
|
||||
return getFeaturesCount(myNotesLayer.getSource());
|
||||
}
|
||||
function deleteNoteByIdx(Idx) {
|
||||
deleteFeatureByIdx(myNotesLayer.getSource(), Idx);
|
||||
loadNotesTreeFromSource();
|
||||
clearInteractions();
|
||||
}
|
||||
function downloadNotesCSV(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting CSV');
|
||||
setTimeout(function () {
|
||||
download.CSV(myNotesLayer.getSource(), 'mynotes');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function downloadNotesJson(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting JSON');
|
||||
setTimeout(function () {
|
||||
download.JSON(myNotesLayer.getSource(), 'mynotes');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function downloadNotesKML(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting KML');
|
||||
setTimeout(function () {
|
||||
download.KML(myNotesLayer.getSource(), 'mynotes');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
181
software/cnip/cnip/Scripts/cnip/webui/sidebar/mypolygons.js
Normal file
181
software/cnip/cnip/Scripts/cnip/webui/sidebar/mypolygons.js
Normal file
@@ -0,0 +1,181 @@
|
||||
$('#polygonsDiv').collapse({
|
||||
toggle: true
|
||||
});
|
||||
var polygonsTree = document.getElementById('polygonsUl');
|
||||
|
||||
var fileupload = document.getElementById("FileUpload1");
|
||||
var button = document.getElementById("btnFileUpload");
|
||||
button.onclick = function () {
|
||||
fileupload.click();
|
||||
};
|
||||
fileupload.onchange = function (evt) {
|
||||
if (evt) { evt.stopPropagation(); }
|
||||
if (getActionRunning()) { return; }
|
||||
if (evt.target.files) {
|
||||
var reader = new FileReader();
|
||||
var file = evt.currentTarget.files[0];
|
||||
var filename = file.name;
|
||||
if (!filename.includes('json') ||
|
||||
!filename.includes('geojson')) {
|
||||
showMessage("Polygon Upload", "Please provide polygons in Geojson format.");
|
||||
}
|
||||
else {
|
||||
reader.readAsText(file, "UTF-8");
|
||||
reader.onload = function (evt) {
|
||||
showProgress('Loading Polygons');
|
||||
setTimeout(function () {
|
||||
// save current polygons
|
||||
uploadDataToUrl(myPolygonsLayer.getSource().getJSONString(),
|
||||
vectorsPath + 'mypolygons.geojson');
|
||||
Ajax_runccmd("UploadPolygonsToDB", "");
|
||||
myMap.render();
|
||||
loadPolygonsTreeFromFile();
|
||||
// load user polygons
|
||||
uploadDataToUrl(evt.target.result,
|
||||
vectorsPath + "t" + filename);
|
||||
Ajax_runccmd("UploadUserPolygonsToDB",
|
||||
"{'polygonname':'t" + filename + "'}");
|
||||
// reload polygons from server
|
||||
Ajax_runccmd("GetPolygonsFromDB", "");
|
||||
Ajax_loadSourceFromFile(myPolygonsLayer.getSource(),
|
||||
"../" + vectorsPath + "mypolygons.geojson");
|
||||
myMap.render();
|
||||
loadPolygonsTreeFromFile();
|
||||
closeProgress();
|
||||
}, 500);
|
||||
};
|
||||
}
|
||||
fileupload.value = null;
|
||||
}
|
||||
};
|
||||
initSingleSlider(document.getElementById('polygonsFillOpacity'), '', '0', '1', '0.1', '0.2');
|
||||
initSingleSlider(document.getElementById('polygonsStrokeOpacity'), '', '0', '1', '0.1', '1');
|
||||
document.getElementById('polygonsFillOpacity').addEventListener('change', setPolygonsStyle);
|
||||
document.getElementById('polygonsStrokeOpacity').addEventListener('change', setPolygonsStyle);
|
||||
loadPolygonsTreeFromFile();
|
||||
/* polygon functions*/
|
||||
function setPolygonsStyle(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let custStyle = function (feature) {
|
||||
let fillOpacity = Number($('#polygonsFillOpacity').val());
|
||||
let strokeOpacity = Number($('#polygonsStrokeOpacity').val());
|
||||
return [new ol.style.Style({
|
||||
fill: new ol.style.Fill({
|
||||
color: colorWithAlpha('#ffffff', fillOpacity)
|
||||
}),
|
||||
stroke: new ol.style.Stroke({
|
||||
color: colorWithAlpha('#ffcc33', strokeOpacity),
|
||||
width: 3
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
text: feature.get('polygonname'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: 'rgba(0,0,0,' + strokeOpacity + ')' }),
|
||||
stroke: new ol.style.Stroke({ color: 'rgba(255,255,255,' + strokeOpacity + ')', width: 2 })
|
||||
})
|
||||
})];
|
||||
};
|
||||
myPolygonsLayer.setStyle(custStyle);
|
||||
myMap.render();
|
||||
}
|
||||
function loadPolygonsTreeFromFile() {
|
||||
let httpRequest = new XMLHttpRequest();
|
||||
httpRequest.open('GET', '../' + vectorsPath + 'mypolygons.geojson', true);
|
||||
httpRequest.send();
|
||||
httpRequest.onload = function () {
|
||||
let source = JSON.parse(httpRequest.responseText);
|
||||
polygonsTree.innerHTML = '';
|
||||
if (typeof source.features !== 'undefined') {
|
||||
for (let i = 0; i < source.features.length; i++) {
|
||||
polygonsTree.innerHTML = polygonsTree.innerHTML +
|
||||
'<li class="visualLi" onclick="showPolygonOptionsByIdx(event,' +
|
||||
i.toString() + ');"><i class="fas fa-draw-polygon"></i> ' +
|
||||
truncate(source.features[i].properties.polygonname, 27) + '</li>';
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
function loadPolygonsTreeFromSource() {
|
||||
let features = myPolygonsLayer.getSource().getFeatures();
|
||||
polygonsTree.innerHTML = '';
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
polygonsTree.innerHTML = polygonsTree.innerHTML +
|
||||
'<li class="visualLi" onclick="showPolygonOptionsByIdx(event,' +
|
||||
i.toString() + ');"><i class="fas fa-draw-polygon"></i> ' +
|
||||
truncate(features[i].getProperties().polygonname, 27) + '</li>';
|
||||
}
|
||||
}
|
||||
function showPolygonOptionsByIdx(e, Idx) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
document.getElementById('polyOptions').style.display = 'block';
|
||||
document.getElementById('polyOptions').style.left = 'calc(50vw - 351px / 2)';
|
||||
document.getElementById('polyOptions').style.top = 'calc(50vh - 236px / 2)';
|
||||
document.getElementById('polyOptions').style.width = '351px';
|
||||
document.getElementById('polyOptions').style.height = '236px';
|
||||
document.getElementById('polyOptionsFrame').contentWindow.userDisplay = true;
|
||||
document.getElementById('polyOptionsFrame').contentWindow.refreshPolygonData('', Idx);
|
||||
setDialogZIndex(null, 'polyOptions');
|
||||
}
|
||||
myPolygonsLayer.getSource().on('addfeature', function (event) {
|
||||
if (event.feature.get('polygonid') === undefined) {
|
||||
let newid = getNewIdx(myPolygonsLayer.getSource(), 'polygonid');
|
||||
event.feature.setProperties({ 'polygonid': newid, 'polygonname': 'new polygon ' + newid });
|
||||
loadPolygonsTreeFromSource();
|
||||
document.getElementById('polyOptionsFrame').contentWindow.refreshPolygonData('add');
|
||||
}
|
||||
});
|
||||
function getPolygonDataByIdx(Idx) {
|
||||
return getDataByIdx(myPolygonsLayer.getSource(), Idx);
|
||||
}
|
||||
function getPolygonIdxById(polygonid) {
|
||||
return getIdxById(myPolygonsLayer.getSource(), 'polygonid', polygonid);
|
||||
}
|
||||
function zoomToPolygonByIdx(Idx) {
|
||||
zoomToFeatureByIdx(myPolygonsLayer.getSource(), Idx);
|
||||
}
|
||||
function updatePolygonDataByIdx(Idx, polygonname) {
|
||||
if (Idx) {
|
||||
if (Number(Idx) > -1) {
|
||||
let feature = myPolygonsLayer.getSource().getFeatures()[Idx];
|
||||
feature.set('polygonname', polygonname.toString());
|
||||
myMap.render();
|
||||
loadPolygonsTreeFromSource();
|
||||
}
|
||||
}
|
||||
}
|
||||
function getPolygonsCount() {
|
||||
return getFeaturesCount(myPolygonsLayer.getSource());
|
||||
}
|
||||
function deletePolygonByIdx(Idx) {
|
||||
deleteFeatureByIdx(myPolygonsLayer.getSource(), Idx);
|
||||
loadPolygonsTreeFromSource();
|
||||
clearInteractions();
|
||||
}
|
||||
function downloadPolygonsCSV(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting CSV');
|
||||
setTimeout(function () {
|
||||
download.CSV(myPolygonsLayer.getSource(), 'mypolygons');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function downloadPolygonsJson(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting JSON');
|
||||
setTimeout(function () {
|
||||
download.JSON(myPolygonsLayer.getSource(), 'mypolygons');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function downloadPolygonsKML(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showProgress('Exporting KML');
|
||||
setTimeout(function () {
|
||||
download.KML(myPolygonsLayer.getSource(), 'mypolygons');
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
333
software/cnip/cnip/Scripts/cnip/webui/sidebar/myresults.js
Normal file
333
software/cnip/cnip/Scripts/cnip/webui/sidebar/myresults.js
Normal file
@@ -0,0 +1,333 @@
|
||||
$('#resultsDiv').collapse({
|
||||
toggle: true
|
||||
});
|
||||
var raster;
|
||||
var resultsTree = document.getElementById('resultsUl');
|
||||
initSingleSlider(document.getElementById('rasterOpacity'), '', '0', '1', '0.1', '0.8');
|
||||
document.getElementById('rasterOpacity').addEventListener('change', setRasterStyle);
|
||||
loadResultsTreeFromFile();
|
||||
/* polygon functions*/
|
||||
|
||||
function setRasterVisiblity() {
|
||||
if (raster) {
|
||||
if (document.getElementById("rasterVisibility").checked === true) {
|
||||
raster.setVisible(true);
|
||||
} else {
|
||||
raster.setVisible(false);
|
||||
}
|
||||
myMap.render();
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
}
|
||||
}
|
||||
function setLinksVisiblity() {
|
||||
if (myLinksLayer) {
|
||||
if (document.getElementById("linksVisibility").checked === true) {
|
||||
myLinksLayer.setVisible(true);
|
||||
} else {
|
||||
myLinksLayer.setVisible(false);
|
||||
}
|
||||
myMap.render();
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
}
|
||||
}
|
||||
|
||||
function setPolygonsVisiblity() {
|
||||
if (myPolygonsLayer) {
|
||||
if (document.getElementById("polygonsVisibility").checked === true) {
|
||||
myPolygonsLayer.setVisible(true);
|
||||
} else {
|
||||
myPolygonsLayer.setVisible(false);
|
||||
}
|
||||
myMap.render();
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
}
|
||||
}
|
||||
|
||||
function setNotesVisiblity() {
|
||||
if (myNotesLayer) {
|
||||
if (document.getElementById("notesVisibility").checked === true) {
|
||||
myNotesLayer.setVisible(true);
|
||||
} else {
|
||||
myNotesLayer.setVisible(false);
|
||||
}
|
||||
myMap.render();
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
}
|
||||
}
|
||||
function setSitesVisiblity() {
|
||||
if (myNetworkLayer) {
|
||||
if (document.getElementById("sitesVisibility").checked === true) {
|
||||
myNetworkLayer.setVisible(true);
|
||||
} else {
|
||||
myNetworkLayer.setVisible(false);
|
||||
}
|
||||
myMap.render();
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
}
|
||||
}
|
||||
|
||||
function setPublicNotesVisiblity() {
|
||||
if (publicNotesLayer) {
|
||||
if (document.getElementById("publicNotesVisibility").checked === true) {
|
||||
publicNotesLayer.setVisible(true);
|
||||
} else {
|
||||
publicNotesLayer.setVisible(false);
|
||||
}
|
||||
myMap.render();
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
}
|
||||
}
|
||||
|
||||
function setPublicSitesVisiblity() {
|
||||
if (publicNetworkLayer) {
|
||||
if (document.getElementById("publicSitesVisibility").checked === true) {
|
||||
publicNetworkLayer.setVisible(true);
|
||||
} else {
|
||||
publicNetworkLayer.setVisible(false);
|
||||
}
|
||||
myMap.render();
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
}
|
||||
}
|
||||
|
||||
function setRasterStyle(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (raster) {
|
||||
let opacity = Number($('#rasterOpacity').val());
|
||||
raster.setOpacity(opacity);
|
||||
myMap.render();
|
||||
}
|
||||
}
|
||||
function loadResultsTreeFromFile() {
|
||||
let httpRequest = new XMLHttpRequest();
|
||||
httpRequest.open('GET', '../' + vectorsPath + 'results.geojson', true);
|
||||
httpRequest.send();
|
||||
httpRequest.onload = function () {
|
||||
let source = JSON.parse(httpRequest.responseText);
|
||||
resultsTree.innerHTML = '';
|
||||
if (typeof source.features !== 'undefined') {
|
||||
for (let i = 0; i < source.features.length; i++) {
|
||||
resultsTree.innerHTML = resultsTree.innerHTML +
|
||||
'<li class="visualLi">' +
|
||||
'<button class="toolsButton" style="width:auto;height:auto;"' +
|
||||
' onclick="showResultByIdx(event,' + i.toString() + ');">' +
|
||||
'<i class="fas fa-poll" style="font-size:14px !important;"></i>' +
|
||||
' ' + truncate(source.features[i].properties.resultname, 23) +
|
||||
'</button>' +
|
||||
' ' +
|
||||
'<button class="toolsButton" style="width:auto;height:auto;float:right;"' +
|
||||
' onclick="deleteResultByIdx(event,' + i.toString() + ');">' +
|
||||
'<i class="fas fa-trash-alt" style="font-size:14px !important;"></i>' +
|
||||
'</button>' +
|
||||
'</li>';
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
function loadResultsTreeFromSource() {
|
||||
let features = resultsLayer.getSource().getFeatures();
|
||||
resultsTree.innerHTML = '';
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
resultsTree.innerHTML = resultsTree.innerHTML +
|
||||
'<li class="visualLi">' +
|
||||
'<button class="toolsButton" style="width:auto;height:auto;"' +
|
||||
' onclick="showResultByIdx(event,' + i.toString() + ');">' +
|
||||
'<i class="fas fa-poll" style="font-size:14px !important;"></i>' +
|
||||
' ' + truncate(features[i].getProperties().resultname, 23) +
|
||||
'</button>' +
|
||||
' ' +
|
||||
'<button class="toolsButton" style="width:auto;height:auto;float:right;"' +
|
||||
' onclick="deleteResultByIdx(event,' + i.toString() + ');">' +
|
||||
'<i class="fas fa-trash-alt" style="font-size:14px !important;"></i>' +
|
||||
'</button>' +
|
||||
'</li>';
|
||||
}
|
||||
}
|
||||
var deleteResultIdx = null;
|
||||
function deleteResultByIdx(e, Idx) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (getActionRunning()) { return; }
|
||||
deleteResultIdx = Idx;
|
||||
document.getElementById("yesMessageBox").addEventListener("click", deleteResult);
|
||||
document.getElementById("okcancelMessageBox").addEventListener("click", removeDeleteResult);
|
||||
let feature = resultsLayer.getSource().getFeatures()[deleteResultIdx];
|
||||
showMessage('Delete Result', 'Are you sure you want to permanently delete<br/> "'
|
||||
+ feature.get('resultname') + '" ?', true);
|
||||
}
|
||||
function removeDeleteResult() {
|
||||
document.getElementById("yesMessageBox").removeEventListener("click", deleteResult);
|
||||
document.getElementById("okcancelMessageBox").removeEventListener("click", removeDeleteResult);
|
||||
}
|
||||
function deleteResult() {
|
||||
showProgress('Deleting Result');
|
||||
setTimeout(function () {
|
||||
let feature = resultsLayer.getSource().getFeatures()[deleteResultIdx];
|
||||
let result = feature.get('resultstring').split('>');
|
||||
let pngString = result[1];
|
||||
let polygonsString = result[2];
|
||||
let pngs = [];
|
||||
pngs.push(pngString.split(',')[0]);
|
||||
if (polygonsString.length > 0) {
|
||||
polygonsString.split('@').forEach(function (ps) {
|
||||
pngs.push(ps.split('#')[2].split(',')[0]);
|
||||
});
|
||||
}
|
||||
pngs = [...new Set(pngs)];
|
||||
Ajax_runccmd("DeleteResult", "{'resultid':'" +
|
||||
feature.get('resultid') + "','pngs':'" + pngs.join(',') + "'}");
|
||||
loadResultsFromDB();
|
||||
deleteResultIdx = null;
|
||||
document.getElementById("yesMessageBox").removeEventListener("click", deleteResult);
|
||||
document.getElementById("okcancelMessageBox").removeEventListener("click", removeDeleteResult);
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
function showResultByIdx(e, Idx) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (actionRunning) { return; }
|
||||
showResult(resultsLayer.getSource().getFeatures()[Idx].get('resultstring'));
|
||||
}
|
||||
function showResult(resultstring) {
|
||||
if (resultstring) {
|
||||
if (resultstring.length == 0) {
|
||||
return;
|
||||
}
|
||||
let result = resultstring.split('>');
|
||||
let thematicString = result[0];
|
||||
let pngString = result[1];
|
||||
let polygonsString = result[2];
|
||||
setLegend(thematicString);
|
||||
if (polygonsString.length === 0) {
|
||||
loadRaster(pngString);
|
||||
}
|
||||
showPolygonsCoverageReport(polygonsString);
|
||||
}
|
||||
}
|
||||
function loadResultsFromDB() {
|
||||
Ajax_runccmd("GetResultsFromDB", "");
|
||||
Ajax_loadSourceFromFile(resultsLayer.getSource(),
|
||||
"../" + vectorsPath + "results.geojson");
|
||||
loadResultsTreeFromSource();
|
||||
}
|
||||
function loadRaster(pngString) {
|
||||
// ,&$#@>
|
||||
// result : thematicString>pngString>polygonsString@polygonsString
|
||||
|
||||
// thematicString
|
||||
// rate&r,g,b$rate&r,g,b
|
||||
|
||||
// pngString
|
||||
// png,1,2,3,4
|
||||
|
||||
// polygonsString
|
||||
// polygonid,polygonname#siteid,sitename#png,1,2,3,4#cttrue,ctext1234#rate&value&r,g,b$rate&value&r,g,b#bestcandidate
|
||||
if (pngString) {
|
||||
if (pngString.length > 0) {
|
||||
let png = pngString.split(',');
|
||||
let extent = [png[1], png[2], png[3], png[4]];
|
||||
if (raster) {
|
||||
overlayLayers.getLayers().pop(raster);
|
||||
}
|
||||
raster = new ol.layer.Image({
|
||||
title: 'Result',
|
||||
visible: true,
|
||||
name: 'Result',
|
||||
opacity: 0.8,
|
||||
crossOrigin: '',
|
||||
source: new ol.source.ImageStatic({
|
||||
url: '../' + resultsPath + png[0],
|
||||
imageExtent: extent,
|
||||
projection: 'EPSG:4326'
|
||||
})
|
||||
});
|
||||
document.getElementById('rasterOpacity').setValue('0.8');
|
||||
overlayLayers.getLayers().push(raster);
|
||||
myNetworkLayer.setZIndex(9);
|
||||
publicNetworkLayer.setZIndex(6);
|
||||
myLinksLayer.setZIndex(5);
|
||||
myNotesLayer.setZIndex(4);
|
||||
publicNotesLayer.setZIndex(3);
|
||||
myPolygonsLayer.setZIndex(2);
|
||||
raster.setZIndex(1);
|
||||
myMap.updateSize();
|
||||
myMap.render();
|
||||
document.getElementById("rasterVisibility").checked = true;
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
}
|
||||
}
|
||||
}
|
||||
function showPolygonsCoverageReport(polygonsString) {
|
||||
// ,&$#@>
|
||||
// result : thematicString>pngString>polygonsString@polygonsString
|
||||
|
||||
// thematicString
|
||||
// rate&r,g,b$rate&r,g,b
|
||||
|
||||
// pngString
|
||||
// png,1,2,3,4
|
||||
|
||||
// polygonsString
|
||||
// polygonid,polygonname#siteid,sitename#png,1,2,3,4#cttrue,ctext1234#rate&value&r,g,b$rate&value&r,g,b#bestcandidate
|
||||
if (polygonsString) {
|
||||
if (polygonsString.length > 0) {
|
||||
let loadObj = []; let i = 0; let bestCandidate = 0; let bestCandidateCT = 0;
|
||||
let reportTitle = 'Polygons Coverage Report';
|
||||
polygonsString.split('@').forEach(function (ps) {
|
||||
if (i < 20) {
|
||||
let coverageTestExt = Number(ps.split('#')[3].split(',')[1]);
|
||||
if (bestCandidateCT < coverageTestExt) {
|
||||
bestCandidateCT = coverageTestExt;
|
||||
bestCandidate = i;
|
||||
}
|
||||
i += 1;
|
||||
}
|
||||
});
|
||||
i = 0;
|
||||
polygonsString.split('@').forEach(function (ps) {
|
||||
if (i < 20) {
|
||||
let polygonid = ps.split('#')[0].split(',')[0];
|
||||
let polygonname = ps.split('#')[0].split(',')[1];
|
||||
let sites = ps.split('#')[1].split('&');
|
||||
let siteids = '', sitenames = '';
|
||||
sites.forEach(function (site) {
|
||||
siteids += site.split(',')[0] + ', ';
|
||||
sitenames += site.split(',')[1] + ', ';
|
||||
});
|
||||
siteids = siteids.substr(0, siteids.length - 2);
|
||||
sitenames = sitenames.substr(0, sitenames.length - 2);
|
||||
let pngString = ps.split('#')[2];
|
||||
let coverageTest = ps.split('#')[3].split(',')[0];
|
||||
let coverageTestExt = ps.split('#')[3].split(',')[1];
|
||||
let dataString = ps.split('#')[4];
|
||||
let bestCandidateType = ps.split('#')[5];
|
||||
let tabTitle = '';
|
||||
coverageTest =
|
||||
coverageTest.toLowerCase() === 'true' ? 'Coverage Test: <b>Passed</b>' :
|
||||
coverageTest.toLowerCase() === 'false' ? 'Coverage Test: <b>Failed</b>' :
|
||||
coverageTest.toLowerCase() === 'n/a' ? 'Coverage Test: <b>Not Applicable</b>' :
|
||||
'Coverage Test: <b>Failed</b>';
|
||||
if (bestCandidateType !== '') {
|
||||
if (bestCandidate === i) {
|
||||
coverageTest = '<span style="color: #000000; background-color: #ffff00;"><strong><Best Candidate></strong></span>' + ' <b>' + polygonname + '</b>, <b>' + sitenames + '</b>, ' + coverageTest;
|
||||
} else {
|
||||
coverageTest = '<b>' + polygonname + '</b>, <b>' + sitenames + '</b>, ' + coverageTest;
|
||||
}
|
||||
tabTitle = 'Polygon Id: ' + polygonid + ', Site Id: ' + siteids;
|
||||
reportTitle = 'Best Candidate Report';
|
||||
} else {
|
||||
coverageTest = 'Site Ids: <b>' + siteids + '</b>, ' + coverageTest;
|
||||
tabTitle = 'Polygon Id: ' + polygonid + ', ' + polygonname;
|
||||
}
|
||||
loadObj.push({
|
||||
title: tabTitle,
|
||||
contentType: 'chart', contentTitle: coverageTest,
|
||||
contentPadding: '0', dataString: dataString,
|
||||
pngString: pngString
|
||||
});
|
||||
i += 1;
|
||||
}
|
||||
});
|
||||
ddsCreate(reportTitle, loadObj);
|
||||
}
|
||||
}
|
||||
}
|
||||
196
software/cnip/cnip/Scripts/cnip/webui/sidebar/settings.js
Normal file
196
software/cnip/cnip/Scripts/cnip/webui/sidebar/settings.js
Normal file
@@ -0,0 +1,196 @@
|
||||
$('#coverage').collapse({
|
||||
toggle: true
|
||||
});
|
||||
$('#radioOptions').collapse({
|
||||
toggle: true
|
||||
});
|
||||
// initialize controls
|
||||
initSelectOpt(document.getElementById('opt_antennamodel'), '100%', 'LT OD9-5 890-950 MHz\tLT OD9-6 865-945 MHz\tLT OD9-6 860-960 MHz\tLT OD9-8 865-945 MHz\tLT OD9-8 860-960 MHz\tLT OD9-11 860-960 MHz\tLT OD9-11D1 860-960 MHz', 'LT OD9-5 890-950 MHz');
|
||||
initSingleSlider(document.getElementById('opt_cellradius'), '', '0.5', '3', '0.1', '1');
|
||||
initSelectOpt(document.getElementById('opt_gsmband'), '100%', 'GSM900 PGSM', 'GSM900 PGSM');
|
||||
initSelectOpt(document.getElementById('opt_gsmbandwidth'), '100%', '0.2', '0.2');
|
||||
initSelectOpt(document.getElementById('opt_lteband'), '100%', 'B08_FDD_900 E-GSM', 'B08_FDD_900 E-GSM');
|
||||
initSelectOpt(document.getElementById('opt_ltebandwidth'), '100%', '1.4\t3\t5\t10', '10');
|
||||
initSingleSlider(document.getElementById('opt_frequency'), '', '1', '15', '0.1', '5');
|
||||
initSelectOpt(document.getElementById('opt_channelwidth'), '100%', '10\t20\t30\t40\t50\t60\t80\t100', '20');
|
||||
initSingleSlider(document.getElementById('opt_outputpower'), '', '27', '47', '0.5', '47');
|
||||
initSingleSlider(document.getElementById('opt_antennagain'), '', '19', '51', '0.1', '22.5');
|
||||
initSingleSlider(document.getElementById('opt_losses'), '', '0', '51', '0.1', '0');
|
||||
initSingleSlider(document.getElementById('opt_fresnelclearance'), '', '60', '100', '5', '60');
|
||||
initSelectOpt(document.getElementById('opt_measurementtype'), '100%', 'Path Loss (dB)\tReceived Power (dBm)\tField Strength (dBµV/m)\tSNR (dB)\tVoice Quality Score\tData Rate Score', 'Path Loss (dB)');
|
||||
initSelectOpt(document.getElementById('opt_terrainresolution'), '100%', '90m\t30m', '90m');
|
||||
initSelectOpt(document.getElementById('opt_thematic'), '100%', 'default', 'default');
|
||||
initSingleSlider(document.getElementById('opt_radius'), '', '0.5', '5', '0.1', '1');
|
||||
initSelectOpt(document.getElementById('opt_propagationmodel'), '100%', 'ITM / Longley-Rice (< 20GHz)\tITWOM 3.0 (< 20GHz)', 'ITM / Longley-Rice (< 20GHz)');
|
||||
initSingleSlider(document.getElementById('opt_reliabilitys'), '', '0', '99', '1', '1');
|
||||
initSingleSlider(document.getElementById('opt_reliabilityt'), '', '0', '99', '1', '1');
|
||||
initSelectOpt(document.getElementById('opt_terrainconductivity'), '100%', 'Salt water\tGood ground\tFresh water\tMarshy land\tFarm land\tForest\tAverage ground\tMountain / Sand\tCity\tPoor ground', 'Average ground');
|
||||
initSelectOpt(document.getElementById('opt_radioclimate'), '100%', 'Equatorial (Congo)\tContinental Subtropical (Sudan)\tMaritime Subtropical (W. Africa)\tDesert (Sahara)\tContinental Temperate\tMaritime Temperate (Land)\tMaritime Temperate (Sea)', 'Continental Temperate');
|
||||
initSingleSlider(document.getElementById('opt_receiverheight'), '', '0.1', '5', '0.1', '1.5');
|
||||
initSingleSlider(document.getElementById('opt_receivergain'), '', '0', '5', '0.01', '2.14');
|
||||
initSingleSlider(document.getElementById('opt_receiversensitivity'), '', '-140', '-40', '1', '-90');
|
||||
document.getElementById('opt_lteband').addEventListener('change', setLTEBandwidths);
|
||||
loadSettings();
|
||||
/* settings functions*/
|
||||
function setLTEBandwidths(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let ltebandwidth;
|
||||
switch (document.getElementById('opt_lteband').value) {
|
||||
case 'B01_FDD_2100 IMT': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B02_FDD_1900 PCS': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B03_FDD_1800 (+) DCS': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B04_FDD_1700 AWS-1': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B05_FDD_850 Cellular': ltebandwidth = '1.4\t3\t5\t10'; break;
|
||||
case 'B06_FDD_850 UMTS only': ltebandwidth = '5\t10'; break;
|
||||
case 'B07_FDD_2600 E-IMT': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B08_FDD_900 E-GSM': ltebandwidth = '1.4\t3\t5\t10'; break;
|
||||
case 'B09_FDD_1800': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B10_FDD_1700 AWS-1+': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B11_FDD_1500 Lower PDC': ltebandwidth = '5\t10'; break;
|
||||
case 'B12_FDD_700 a Lower SMH': ltebandwidth = '1.4\t3\t5\t10'; break;
|
||||
case 'B13_FDD_700 c Upper SMH': ltebandwidth = '5\t10'; break;
|
||||
case 'B14_FDD_700 PS Upper SMH': ltebandwidth = '5\t10'; break;
|
||||
case 'B17_FDD_700 b Lower SMH': ltebandwidth = '5\t10'; break;
|
||||
case 'B18_FDD_800 Lower (Japan)': ltebandwidth = '5\t10\t15'; break;
|
||||
case 'B19_FDD_800 Upper (Japan)': ltebandwidth = '5\t10\t15'; break;
|
||||
case 'B20_FDD_800 Digital Div... (EU)': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B21_FDD_1500 Upper PDC': ltebandwidth = '5\t10\t15'; break;
|
||||
case 'B22_FDD_3500': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B23_FDD_2000 S-band': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B24_FDD_1600 Upper L-band (US)': ltebandwidth = '5\t10'; break;
|
||||
case 'B25_FDD_1900 (+) E-PCS': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B26_FDD_850 (+) E-Cellular': ltebandwidth = '1.4\t3\t5\t10\t15'; break;
|
||||
case 'B27_FDD_800 SMR': ltebandwidth = '1.4\t3\t5\t10'; break;
|
||||
case 'B28_FDD_700 APT': ltebandwidth = '3\t5\t10\t15\t20'; break;
|
||||
case 'B29_SDL_700 d Lower SMH': ltebandwidth = '3\t5\t10'; break;
|
||||
case 'B30_FDD_2300 WCS': ltebandwidth = '5\t10'; break;
|
||||
case 'B31_FDD_450 NMT': ltebandwidth = '1.4\t3\t5'; break;
|
||||
case 'B32_SDL_1500 L-band (EU)': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B33_TDD_1900': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B34_TDD_2000 IMT': ltebandwidth = '5\t10\t15'; break;
|
||||
case 'B35_TDD_1900 PCS Lower': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B36_TDD_1900 PCS Upper': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B37_TDD_1900 PCS Center gap': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B38_TDD_2600 E-IMT': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B39_TDD_1900 (+) DCS-IMT Gap': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B40_TDD_2300 S-Band': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B41_TDD_2600 (+) BRS': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B42_TDD_3500 CBRS (EU/Japan)': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B43_TDD_3700 C-Band': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B44_TDD_700 APT': ltebandwidth = '3\t5\t10\t15\t20'; break;
|
||||
case 'B45_TDD_1500': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B46_TDD_5200 Unlicensed U-NII': ltebandwidth = '10\t20'; break;
|
||||
case 'B47_TDD_5900 V2X U-NII4': ltebandwidth = '10\t20'; break;
|
||||
case 'B48_TDD_3600 CBRS (US)': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B49_TDD_3600 (r) C-Band': ltebandwidth = '10\t20'; break;
|
||||
case 'B50_TDD_1500 (+) L-Band (EU)': ltebandwidth = '3\t5\t10\t15\t20'; break;
|
||||
case 'B51_TDD_1500 (-) E-(L-Band) (EU)': ltebandwidth = '3\t5'; break;
|
||||
case 'B52_TDD_3300 C-Band': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B53_TDD_2500 S-Band': ltebandwidth = '1.4\t3\t5\t10'; break;
|
||||
case 'B65_FDD_2100 (+) E-IMT': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B66_FDD_1700 AWS-3 E-AWS': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B67_SDL_700 (EU)': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B68_FDD_700 (ME)': ltebandwidth = '5\t10\t15'; break;
|
||||
case 'B69_SDL_2500 DL E-IMT': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B70_FDD_1700 AWS-4 Supp...': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B71_FDD_600 Digital Dividend': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B72_FDD_450 PMR/PAMR (EU)': ltebandwidth = '1.4\t3\t5'; break;
|
||||
case 'B73_FDD_450 APAC PMT (APT)': ltebandwidth = '1.4\t3\t5'; break;
|
||||
case 'B74_FDD_1500 Lower L‑Band (US)': ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
case 'B75_SDL_1500 (+) DL L-Band (EU)': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B76_SDL_1500 (-) DL E-(L-B) (EU)': ltebandwidth = '5\t10\t15\t20'; break;
|
||||
case 'B85_FDD_700 a+ E-Lower SMH': ltebandwidth = '5\t10'; break;
|
||||
case 'B87_FDD_410 PMR (APT)': ltebandwidth = '1.4\t3\t5'; break;
|
||||
case 'B88_FDD_410 (+) PMR (EU)': ltebandwidth = '1.4\t3\t5'; break;
|
||||
default: ltebandwidth = '1.4\t3\t5\t10\t15\t20'; break;
|
||||
}
|
||||
document.getElementById('opt_ltebandwidth').reloadOpt(ltebandwidth);
|
||||
}
|
||||
function loadSettings() {
|
||||
let settings = Ajax_runccmd("GetSettings", "").split('\t');
|
||||
document.getElementById('opt_measurementtype').setOpt(settings[1]);
|
||||
document.getElementById('opt_terrainresolution').setOpt(settings[2]);
|
||||
document.getElementById('opt_thematic').setOpt(settings[3]);
|
||||
document.getElementById('opt_radius').setValue(settings[4]);
|
||||
document.getElementById('opt_propagationmodel').setOpt(settings[5]);
|
||||
document.getElementById('opt_reliabilitys').setValue(settings[6]);
|
||||
document.getElementById('opt_reliabilityt').setValue(settings[7]);
|
||||
document.getElementById('opt_terrainconductivity').setOpt(settings[8]);
|
||||
document.getElementById('opt_radioclimate').setOpt(settings[9]);
|
||||
document.getElementById('opt_receiverheight').setValue(settings[10]);
|
||||
document.getElementById('opt_receivergain').setValue(settings[11]);
|
||||
document.getElementById('opt_receiversensitivity').setValue(settings[12]);
|
||||
document.getElementById('opt_antennamodel').setOpt(settings[13]);
|
||||
document.getElementById('opt_cellradius').setValue(settings[14]);
|
||||
document.getElementById('opt_gsmband').setOpt(settings[15]);
|
||||
document.getElementById('opt_gsmbandwidth').setOpt(settings[16]);
|
||||
document.getElementById('opt_lteband').setOpt(settings[17]);
|
||||
document.getElementById('opt_ltebandwidth').setOpt(settings[18]);
|
||||
document.getElementById('opt_frequency').setValue(settings[19]);
|
||||
document.getElementById('opt_channelwidth').setOpt(settings[20]);
|
||||
document.getElementById('opt_outputpower').setValue(settings[21]);
|
||||
document.getElementById('opt_antennagain').setValue(settings[22]);
|
||||
document.getElementById('opt_losses').setValue(settings[23]);
|
||||
document.getElementById('opt_fresnelclearance').setValue(settings[24]);
|
||||
}
|
||||
function saveSettings(e) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
if (getActionRunning()) { return; }
|
||||
showProgress('Saving Settings');
|
||||
setTimeout(function () {
|
||||
_saveSettings();
|
||||
closeProgress();
|
||||
}, 500);
|
||||
}
|
||||
|
||||
function _saveSettings() {
|
||||
let pl_measurementtype = document.getElementById('opt_measurementtype').value;
|
||||
let pl_terrainresolution = document.getElementById('opt_terrainresolution').value;
|
||||
let pl_thematic = document.getElementById('opt_thematic').value;
|
||||
let pl_radius = document.getElementById('opt_radius').value;
|
||||
let pl_propagationmodel = document.getElementById('opt_propagationmodel').value;
|
||||
let pl_reliabilitys = document.getElementById('opt_reliabilitys').value;
|
||||
let pl_reliabilityt = document.getElementById('opt_reliabilityt').value;
|
||||
let pl_terrainconductivity = document.getElementById('opt_terrainconductivity').value;
|
||||
let pl_radioclimate = document.getElementById('opt_radioclimate').value;
|
||||
let pl_receiverheight = document.getElementById('opt_receiverheight').value;
|
||||
let pl_receivergain = document.getElementById('opt_receivergain').value;
|
||||
let pl_receiversensitivity = document.getElementById('opt_receiversensitivity').value;
|
||||
let rp_antennamodel = document.getElementById('opt_antennamodel').value;
|
||||
let rp_cellradius = document.getElementById('opt_cellradius').value;
|
||||
let rp_gsmband = document.getElementById('opt_gsmband').value;
|
||||
let rp_gsmbandwidth = document.getElementById('opt_gsmbandwidth').value;
|
||||
let rp_lteband = document.getElementById('opt_lteband').value;
|
||||
let rp_ltebandwidth = document.getElementById('opt_ltebandwidth').value;
|
||||
let mw_frequency = document.getElementById('opt_frequency').value;
|
||||
let mw_channelwidth = document.getElementById('opt_channelwidth').value;
|
||||
let mw_outputpower = document.getElementById('opt_outputpower').value;
|
||||
let mw_antennagain = document.getElementById('opt_antennagain').value;
|
||||
let mw_losses = document.getElementById('opt_losses').value;
|
||||
let mw_fresnelclearance = document.getElementById('opt_fresnelclearance').value;
|
||||
Ajax_runccmd("SetSettings", "{'options':'" +
|
||||
pl_measurementtype + "\t" +
|
||||
pl_terrainresolution + "\t" +
|
||||
pl_thematic + "\t" +
|
||||
pl_radius + "\t" +
|
||||
pl_propagationmodel + "\t" +
|
||||
pl_reliabilitys + "\t" +
|
||||
pl_reliabilityt + "\t" +
|
||||
pl_terrainconductivity + "\t" +
|
||||
pl_radioclimate + "\t" +
|
||||
pl_receiverheight + "\t" +
|
||||
pl_receivergain + "\t" +
|
||||
pl_receiversensitivity + "\t" +
|
||||
rp_antennamodel + "\t" +
|
||||
rp_cellradius + "\t" +
|
||||
rp_gsmband + "\t" +
|
||||
rp_gsmbandwidth + "\t" +
|
||||
rp_lteband + "\t" +
|
||||
rp_ltebandwidth + "\t" +
|
||||
mw_frequency + "\t" +
|
||||
mw_channelwidth + "\t" +
|
||||
mw_outputpower + "\t" +
|
||||
mw_antennagain + "\t" +
|
||||
mw_losses + "\t" +
|
||||
mw_fresnelclearance + "'}");
|
||||
}
|
||||
346
software/cnip/cnip/Scripts/cnip/webui/sidebar/toolbox.js
Normal file
346
software/cnip/cnip/Scripts/cnip/webui/sidebar/toolbox.js
Normal file
@@ -0,0 +1,346 @@
|
||||
$('#analysisDiv').collapse({
|
||||
toggle: true
|
||||
});
|
||||
$('#predictDiv').collapse({
|
||||
toggle: true
|
||||
});
|
||||
$('#reportDiv').collapse({
|
||||
toggle: true
|
||||
});
|
||||
function analyseBestCan(sites, polygonid) {
|
||||
if (getActionRunning()) { return; }
|
||||
_saveSettings();
|
||||
saveAllVectors();
|
||||
minimizeAllDialogs();
|
||||
showProgress('Analysing Candidates');
|
||||
setTimeout(function () {
|
||||
let newid = Ajax_runccmd("GetNewResultId", "");
|
||||
Ajax_runccmd("BestCandidate",
|
||||
"{" +
|
||||
"'resultid':'" + newid + "'," +
|
||||
"'sites':'" + sites + "'," +
|
||||
"'polygonid':'" + polygonid + "'" +
|
||||
"}");
|
||||
function processLoop() {
|
||||
let chk = getForecastRunning();
|
||||
if (chk === false) {
|
||||
showResult(Ajax_runccmd("GetResultString",
|
||||
"{'resultid':'" + newid + "'}"));
|
||||
loadAllVectors(); closeProgress(); toggleSelect();
|
||||
} else {
|
||||
setTimeout(processLoop, 2000);
|
||||
}
|
||||
}
|
||||
processLoop();
|
||||
}, 500);
|
||||
}
|
||||
function analysePredictSites(polygonid, technology) {
|
||||
if (getActionRunning()) { return; }
|
||||
_saveSettings();
|
||||
saveAllVectors();
|
||||
minimizeAllDialogs();
|
||||
showProgress('Predicting Sites');
|
||||
setTimeout(function () {
|
||||
let newid = Ajax_runccmd("GetNewResultId", "");
|
||||
Ajax_runccmd("PredictSites",
|
||||
"{" +
|
||||
"'resultid':'" + newid + "'," +
|
||||
"'polygonid':'" + polygonid + "'," +
|
||||
"'technology':'" + technology + "'" +
|
||||
"}");
|
||||
function processLoop() {
|
||||
let chk = getForecastRunning();
|
||||
if (chk === false) {
|
||||
showResult(Ajax_runccmd("GetResultString",
|
||||
"{'resultid':'" + newid + "'}"));
|
||||
loadAllVectors();
|
||||
showNetworkReport(null);
|
||||
showLinksReport(null, Ajax_runccmd("GetLinksResult", ""));
|
||||
closeProgress(); toggleSelect();
|
||||
} else {
|
||||
setTimeout(processLoop, 2000);
|
||||
}
|
||||
}
|
||||
processLoop();
|
||||
}, 500);
|
||||
}
|
||||
function predictCoverage(sites) {
|
||||
if (getActionRunning()) { return; }
|
||||
_saveSettings();
|
||||
saveAllVectors();
|
||||
minimizeAllDialogs();
|
||||
showProgress('Predicting Coverage');
|
||||
setTimeout(function () {
|
||||
let newid = Ajax_runccmd("GetNewResultId", "");
|
||||
Ajax_runccmd("PredictCoverage",
|
||||
"{" +
|
||||
"'resultid':'" + newid + "'," +
|
||||
"'sites':'" + sites + "'" +
|
||||
"}");
|
||||
function processLoop() {
|
||||
let chk = getForecastRunning();
|
||||
if (chk === false) {
|
||||
showResult(Ajax_runccmd("GetResultString",
|
||||
"{'resultid':'" + newid + "'}"));
|
||||
loadAllVectors();
|
||||
showNetworkReport(null);
|
||||
closeProgress(); toggleSelect();
|
||||
} else {
|
||||
setTimeout(processLoop, 2000);
|
||||
}
|
||||
}
|
||||
processLoop();
|
||||
}, 500);
|
||||
}
|
||||
function predictRadioPlan(sites) {
|
||||
if (getActionRunning()) { return; }
|
||||
_saveSettings();
|
||||
saveAllVectors();
|
||||
minimizeAllDialogs();
|
||||
showProgress('Predicting Radio Plan');
|
||||
setTimeout(function () {
|
||||
Ajax_runccmd("RadioPlan",
|
||||
"{" +
|
||||
"'sites':'" + sites + "'" +
|
||||
"}");
|
||||
function processLoop() {
|
||||
let chk = getForecastRunning();
|
||||
if (chk === false) {
|
||||
loadAllVectors();
|
||||
showNetworkReport(null);
|
||||
closeProgress(); toggleSelect();
|
||||
} else {
|
||||
setTimeout(processLoop, 2000);
|
||||
}
|
||||
}
|
||||
processLoop();
|
||||
}, 500);
|
||||
}
|
||||
function predictLinks(sites) {
|
||||
if (getActionRunning()) { return; }
|
||||
_saveSettings();
|
||||
saveAllVectors();
|
||||
minimizeAllDialogs();
|
||||
showProgress('Predicting Links');
|
||||
setTimeout(function () {
|
||||
Ajax_runccmd("Links",
|
||||
"{" +
|
||||
"'sites':'" + sites + "'" +
|
||||
"}");
|
||||
function processLoop() {
|
||||
let chk = getForecastRunning();
|
||||
if (chk === false) {
|
||||
loadAllVectors();
|
||||
showLinksReport(null, Ajax_runccmd("GetLinksResult", ""));
|
||||
closeProgress(); toggleSelect();
|
||||
} else {
|
||||
setTimeout(processLoop, 2000);
|
||||
}
|
||||
}
|
||||
processLoop();
|
||||
}, 500);
|
||||
}
|
||||
function showNetworkReport(e = null) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let header = ['Site Id', 'Site Name', 'Longitude', 'Latitude', 'Tower Height', 'Technology', 'Band', 'Bandwidth',
|
||||
'Cell ID', 'TAC / LAC', 'EARFCN / ARFCN', 'PCI / BSIC', 'DL Frequency', 'UL Frequency', 'RF Power',
|
||||
'Antenna Height', 'Azimuth', 'Antenna Model', 'Antenna Type', 'Polarization', 'V-Beamwidth', 'H-Beamwidth', 'Downtilt', 'Antenna Gain', 'Feeder Loss'];
|
||||
let csvString;
|
||||
csvString = header.join(',') + '\r\n';
|
||||
header = header.map(h => '<td style="color:var(--facecolor);background-color:var(--barcolor);white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + h + '</td>');
|
||||
header.unshift('<tr>');
|
||||
header.push('</tr>');
|
||||
let properties = [];
|
||||
let features = myNetworkLayer.getSource().getFeatures();
|
||||
features.forEach(function (f) {
|
||||
properties.push('<tr>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('siteid') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('sitename') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + round(f.get('longitude'), 6).toString() + '°' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + round(f.get('latitude'), 6).toString() + '°' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + round(f.get('height'), 0).toString() + ' m' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('technology') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('band') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('bandwidth') + ' MHz' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('cellid') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('lac') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('rfcn') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('rfid') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('dlfrequency') + ' MHz' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('ulfrequency') + ' MHz' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('rfpower') + ' W' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + round(f.get('hba'), 0).toString() + ' m' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('azimuth') + '°' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('antennamodel') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('antennatype') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('polarization') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('vbeamwidth') + '°' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('hbeamwidth') + '°' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('downtilt') + '°' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('antennagain') + ' dBi' + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('feederloss') + ' dB' + '</td>');
|
||||
properties.push('</tr>');
|
||||
});
|
||||
csvString += properties.join(',');
|
||||
while (csvString.includes('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">')) {
|
||||
csvString = csvString.replace('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">', '');
|
||||
}
|
||||
while (csvString.includes('</td>')) {
|
||||
csvString = csvString.replace('</td>', '');
|
||||
}
|
||||
while (csvString.includes('<tr>,')) {
|
||||
csvString = csvString.replace('<tr>,', '');
|
||||
}
|
||||
while (csvString.includes('</tr>,')) {
|
||||
csvString = csvString.replace('</tr>,', '\r\n');
|
||||
}
|
||||
while (csvString.includes('</tr>')) {
|
||||
csvString = csvString.replace('</tr>', '');
|
||||
}
|
||||
let details = '<table><tbody>' + header.join('') + properties.join('') + '</tbody></table>';
|
||||
let loadObj = [];
|
||||
loadObj.push({ title: 'Network details', contentType: 'table', contentHTML: details, contentPadding: '0', contentData: csvString, contentExtension: '.csv' });
|
||||
ddsCreate('Network Report', loadObj);
|
||||
}
|
||||
function showLinksReport(e = null, transmsg = undefined) {
|
||||
if (e) { e.stopPropagation(); }
|
||||
let summary = '';
|
||||
let modifiedLinks = undefined;
|
||||
if (transmsg) {
|
||||
let modified = transmsg.split('@');
|
||||
let internal = modified[0];
|
||||
let external = modified[1];
|
||||
modifiedLinks = {
|
||||
internal: internal.length > 0 ? internal.split(',') : [],
|
||||
external: external.length > 0 ? external.split(',') : []
|
||||
}
|
||||
}
|
||||
if (modifiedLinks) {
|
||||
summary = '<div><b>Links created</b><br/>';
|
||||
let publicLink = myLinksLayer.getSource().getFeatureByProperty('linktype', 'public');
|
||||
if (publicLink) {
|
||||
let publicSite = getPublicSite(publicLink.get('siteidb'), publicLink.get('email'));
|
||||
summary += '<br/><b>Public Link:</b><br/>Site Id: ' + publicSite.get('siteid') + ' Site Name: ' + publicSite.get('sitename') + ' from Public Network has been found,'
|
||||
+ ' Link Id: ' + publicLink.get('linkid') + ' has been added to link Public Site,' +
|
||||
' You can contact user: ' + publicSite.get('name') + ' on email address: ' + publicSite.get('email') + ' for correspondance.<br/>';
|
||||
if (modifiedLinks.external.length > 0) {
|
||||
summary += '<br/><b>Links adjusted to meet ' + document.getElementById('opt_fresnelclearance').value + '% Fresnel Zone clearance requirement:</b><br/>';
|
||||
let adjustedSite = myNetworkLayer.getSource().getFeatureByProperty('siteid', modifiedLinks.external[0]);
|
||||
summary += 'Site Id: ' + adjustedSite.get('siteid') + ' Site Name: ' + adjustedSite.get('sitename') + ', height has been adjusted to ' +
|
||||
round(adjustedSite.get('height'), 0) + ' meters to link with Public Site<br/>';
|
||||
}
|
||||
}
|
||||
if (modifiedLinks.internal.length > 0) {
|
||||
if (modifiedLinks.external.length === 0) {
|
||||
summary += '<br/><b>Links adjusted to meet ' + document.getElementById('opt_fresnelclearance').value + '% Fresnel Zone clearance requirement:</b><br/>';
|
||||
}
|
||||
for (i = 0; i < modifiedLinks.internal.length; i++) {
|
||||
let adjustedSite = myNetworkLayer.getSource().getFeatureByProperty('siteid', modifiedLinks.internal[i]);
|
||||
summary += 'Site Id: ' + adjustedSite.get('siteid') + ' Site Name: ' + adjustedSite.get('sitename') + ', height has been adjusted to ' +
|
||||
round(adjustedSite.get('height'), 0) + ' meters, internal adjustment<br/>';
|
||||
}
|
||||
}
|
||||
summary += '</div>';
|
||||
}
|
||||
let textString = summary;
|
||||
while (textString.includes('<div>')) {
|
||||
textString = textString.replace('<div>', '');
|
||||
}
|
||||
while (textString.includes('</div>')) {
|
||||
textString = textString.replace('</div>', '');
|
||||
}
|
||||
while (textString.includes('<br/>')) {
|
||||
textString = textString.replace('<br/>', '\r\n');
|
||||
}
|
||||
while (textString.includes('<b>')) {
|
||||
textString = textString.replace('<b>', '');
|
||||
}
|
||||
while (textString.includes('</b>')) {
|
||||
textString = textString.replace('</b>', '');
|
||||
}
|
||||
|
||||
let header = ['Link Id', 'Link Name', 'Link Type',
|
||||
'Site Id A', 'Site Name A', 'Height / Elevation A', 'Bearing / Tilt A', 'Frequency A', 'Channel Width A', 'Output Power A', 'Antenna Gain A', 'Losses A',
|
||||
'Site Id B', 'Site Name B', 'Height / Elevation B', 'Bearing / Tilt B', 'Frequency B', 'Channel Width B', 'Output Power B', 'Antenna Gain B', 'Losses B'];
|
||||
let csvString;
|
||||
csvString = header.join(',') + '\r\n';
|
||||
header = header.map(h => '<td style="color:var(--facecolor);background-color:var(--barcolor);white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + h + '</td>');
|
||||
header.unshift('<tr>');
|
||||
header.push('</tr>');
|
||||
let properties = [];
|
||||
let features = myLinksLayer.getSource().getFeatures();
|
||||
features.forEach(function (f) {
|
||||
let siteA = myNetworkLayer.getSource().getFeatureByProperty('siteid', f.get('siteida'));
|
||||
let siteB = undefined;
|
||||
if (f.get('linktype') === 'public') {
|
||||
siteB = getPublicSite(f.get('siteidb'), f.get('email'));
|
||||
} else {
|
||||
siteB = myNetworkLayer.getSource().getFeatureByProperty('siteid', f.get('siteidb'));
|
||||
}
|
||||
let xDistanceKm = Number(f.get('distance'));
|
||||
let deviceheightAm = Number(siteA.get('height')) + Number(f.get('locheighta'));
|
||||
let deviceheightBm = Number(siteB.get('height')) + Number(f.get('locheightb'));
|
||||
let tiltAd = 0; tiltBd = 0;
|
||||
if (deviceheightAm > deviceheightBm) {
|
||||
tiltAd = round(turf.radiansToDegrees(Math.atan(deviceheightAm / (xDistanceKm * 1000))), 2);
|
||||
tiltBd = round(turf.radiansToDegrees(-1 * Math.atan((deviceheightAm - deviceheightBm) / (xDistanceKm * 1000))), 2);
|
||||
}
|
||||
else {
|
||||
tiltAd = round(turf.radiansToDegrees(-1 * Math.atan((deviceheightBm - deviceheightAm) / (xDistanceKm * 1000))), 2);
|
||||
tiltBd = round(turf.radiansToDegrees(Math.atan(deviceheightBm / (xDistanceKm * 1000))), 2);
|
||||
}
|
||||
properties.push('<tr>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('linkid') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('linkname') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + titleCase(f.get('linktype')) + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('siteida') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + siteA.get('sitename') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + round(parseFloat(siteA.get('height')), 0).toString() + ' m / ' + round(parseFloat(f.get('locheighta')), 0).toString() + ' m </td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + round(parseFloat(f.get('bearinga')), 2).toString() + '° / ' + (tiltAd).toString() + '° </td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('frequencya') + ' GHz</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('channelwidtha') + ' MHz</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('outputpowera') + ' dBm</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('antennagaina') + ' dBi</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('lossesa') + ' dB</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('siteidb') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + siteB.get('sitename') + '</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + round(parseFloat(siteB.get('height')), 0).toString() + ' m / ' + round(parseFloat(f.get('locheightb')), 0).toString() + ' m </td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + round(parseFloat(f.get('bearingb')), 2).toString() + '° / ' + (tiltBd).toString() + '° </td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('frequencyb') + ' GHz</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('channelwidthb') + ' MHz</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('outputpowerb') + ' dBm</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('antennagainb') + ' dBi</td>');
|
||||
properties.push('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">' + f.get('lossesb') + ' dB</td>');
|
||||
properties.push('</tr>');
|
||||
});
|
||||
csvString += properties.join(',');
|
||||
while (csvString.includes('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">')) {
|
||||
csvString = csvString.replace('<td style="white-space:nowrap;border:thin solid #C0C0C0;vertical-align:middle;text-align:center;padding:5px;">', '');
|
||||
}
|
||||
while (csvString.includes('</td>')) {
|
||||
csvString = csvString.replace('</td>', '');
|
||||
}
|
||||
while (csvString.includes('<tr>,')) {
|
||||
csvString = csvString.replace('<tr>,', '');
|
||||
}
|
||||
while (csvString.includes('</tr>,')) {
|
||||
csvString = csvString.replace('</tr>,', '\r\n');
|
||||
}
|
||||
while (csvString.includes('</tr>')) {
|
||||
csvString = csvString.replace('</tr>', '');
|
||||
}
|
||||
let details = '<table><tbody>' + header.join('') + properties.join('') + '</tbody></table>';
|
||||
let loadObj = [];
|
||||
if (modifiedLinks) {
|
||||
loadObj.push({ title: 'Links summary', contentType: 'text', contentHTML: summary, contentPadding: '15px 10px', contentData: textString, contentExtension: '.txt' });
|
||||
loadObj.push({ title: 'Links details', contentType: 'table', contentHTML: details, contentPadding: '0', contentData: csvString, contentExtension: '.csv' });
|
||||
ddsCreate('Links Report', loadObj);
|
||||
}
|
||||
else {
|
||||
loadObj.push({ title: 'Links details', contentType: 'table', contentHTML: details, contentPadding: '0', contentData: csvString, contentExtension: '.csv' });
|
||||
ddsCreate('Links Report', loadObj);
|
||||
}
|
||||
}
|
||||
var getForecastRunning = function () { return Ajax_runccmd("GetForecastRunning", "") === 'true'; };
|
||||
var getActionRunning = function () { return getForecastRunning() || actionRunning; };
|
||||
|
||||
115
software/cnip/cnip/Scripts/cnip/webui/styles.js
Normal file
115
software/cnip/cnip/Scripts/cnip/webui/styles.js
Normal file
@@ -0,0 +1,115 @@
|
||||
// pointer move functionality
|
||||
var highlightStyle = function (feature, layer) {
|
||||
return [new ol.style.Style({
|
||||
image: feature.get('sitename') === undefined ?
|
||||
new ol.style.Icon({ scale: 1, src: '../img/note_highlight.png', opacity: 0.7 }) :
|
||||
new ol.style.Icon({ scale: .6, src: '../img/site_highlight.png', opacity: 0.7 }),
|
||||
stroke: new ol.style.Stroke({
|
||||
color: 'rgba(0,255,0,0.7)',
|
||||
width: 2
|
||||
}),
|
||||
fill: new ol.style.Fill({
|
||||
color: 'rgba(0,255,0,0.1)'
|
||||
})
|
||||
})];
|
||||
};
|
||||
var highlightPointStyle = new ol.style.Style({
|
||||
image: new ol.style.Circle({
|
||||
radius: 5,
|
||||
stroke: new ol.style.Stroke({
|
||||
color: 'rgba(0,255,0,1)',
|
||||
width: 5
|
||||
}),
|
||||
fill: new ol.style.Fill({
|
||||
color: 'rgba(0,255,0,1)'
|
||||
})
|
||||
})
|
||||
});
|
||||
// ******interactions ***********************//
|
||||
// Select style
|
||||
var selectStyle = function (feature, layer) {
|
||||
return [new ol.style.Style({
|
||||
image: feature.get('sitename') === undefined ?
|
||||
new ol.style.Icon({ scale: 1, src: '../img/note_selected.png', opacity: 0.7 }) :
|
||||
new ol.style.Icon({ scale: .6, src: '../img/site_selected.png', opacity: 0.7 }),
|
||||
text: new ol.style.Text({
|
||||
offsetY: feature.get('sitename') === undefined && feature.get('notename') === undefined ? 0 : 25,
|
||||
text: feature.get('sitename') === undefined ? feature.get('polygonname') === undefined ?
|
||||
feature.get('linkname') === undefined ?
|
||||
feature.get('notename') : feature.get('linkname') :
|
||||
feature.get('polygonname') : feature.get('sitename'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: '#0099ff' }),
|
||||
stroke: new ol.style.Stroke({ color: 'rgba(255, 255, 255, 0.2)', width: 3 })
|
||||
}),
|
||||
fill: new ol.style.Fill({
|
||||
color: 'rgba(255, 255, 255, 0.2)'
|
||||
}),
|
||||
stroke: new ol.style.Stroke({
|
||||
color: '#0099ff',
|
||||
width: 2
|
||||
})
|
||||
})];
|
||||
};
|
||||
|
||||
|
||||
var drawSiteStyle = new ol.style.Style({
|
||||
image: new ol.style.Icon({ scale: .6, src: '../img/site_selected.png', opacity: 0.7 })
|
||||
});
|
||||
var drawNoteStyle = new ol.style.Style({
|
||||
image: new ol.style.Icon({ scale: 1, src: '../img/note_selected.png', opacity: 0.7 })
|
||||
});
|
||||
var drawLinkSiteStyle = new ol.style.Style({
|
||||
image: new ol.style.Icon({ scale: .6, src: '../img/site_link_add.png', opacity: 0.7 })
|
||||
});
|
||||
var drawLinkLineStyle = new ol.style.Style({
|
||||
stroke: new ol.style.Stroke({
|
||||
color: 'rgba(0, 255, 255, 1)',
|
||||
lineDash: [10, 10],
|
||||
width: 3
|
||||
})
|
||||
});
|
||||
var drawPolygonStyle = new ol.style.Style({
|
||||
image: new ol.style.Circle({
|
||||
fill: new ol.style.Fill({
|
||||
color: 'rgba(0, 153, 255, 1)'
|
||||
}),
|
||||
stroke: new ol.style.Stroke({
|
||||
color: 'rgba(255, 255, 255, 0.8)',
|
||||
width: 1.5
|
||||
}),
|
||||
radius: 6
|
||||
}),
|
||||
fill: new ol.style.Fill({
|
||||
color: 'rgba(255, 255, 255, 0.7)'
|
||||
}),
|
||||
stroke: new ol.style.Stroke({
|
||||
color: 'rgba(0, 153, 255, 1)',
|
||||
lineDash: [10, 10],
|
||||
width: 2
|
||||
})
|
||||
});
|
||||
|
||||
|
||||
var deleteSiteStyle = new ol.style.Style({
|
||||
image: new ol.style.Icon({ scale: 0.6, src: '../img/site_delete.png', opacity: 1 })
|
||||
});
|
||||
var deleteNoteStyle = new ol.style.Style({
|
||||
image: new ol.style.Icon({ scale: 1.3, src: '../img/note_delete.png', opacity: 1 })
|
||||
});
|
||||
var deleteLinkStyle = new ol.style.Style({
|
||||
stroke: new ol.style.Stroke({
|
||||
color: 'rgba(255, 0, 0, 1)',
|
||||
lineDash: [7, 7],
|
||||
width: 5
|
||||
})
|
||||
});
|
||||
var deletePolygonStyle = new ol.style.Style({
|
||||
stroke: new ol.style.Stroke({
|
||||
color: 'rgba(255,0,0,1)',
|
||||
width: 3
|
||||
}),
|
||||
fill: new ol.style.Fill({
|
||||
color: 'rgba(255,0,0,0.1)'
|
||||
})
|
||||
});
|
||||
@@ -0,0 +1,54 @@
|
||||
var lyrBingMapsAerial = new ol.layer.Tile({
|
||||
source: new ol.source.BingMaps({
|
||||
imagerySet: 'Aerial',
|
||||
key: 'AjabU18xKFl_N3WgLVzRwdDDjcaQTIftpixGXL3Dk93ucbLfm27eEdiQts5lQ0Bt',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
}),
|
||||
title: 'Aerial',
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrBingMapsAerialWithLabels = new ol.layer.Tile({
|
||||
source: new ol.source.BingMaps({
|
||||
imagerySet: 'AerialWithLabels',
|
||||
key: 'AjabU18xKFl_N3WgLVzRwdDDjcaQTIftpixGXL3Dk93ucbLfm27eEdiQts5lQ0Bt',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
}),
|
||||
title: 'Aerial With Labels',
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrBingMapsRoad = new ol.layer.Tile({
|
||||
source: new ol.source.BingMaps({
|
||||
imagerySet: 'Road',
|
||||
key: 'AjabU18xKFl_N3WgLVzRwdDDjcaQTIftpixGXL3Dk93ucbLfm27eEdiQts5lQ0Bt',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
}),
|
||||
title: 'Road',
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrBingMapsRoadOnDemand = new ol.layer.Tile({
|
||||
source: new ol.source.BingMaps({
|
||||
imagerySet: 'RoadOnDemand',
|
||||
key: 'AjabU18xKFl_N3WgLVzRwdDDjcaQTIftpixGXL3Dk93ucbLfm27eEdiQts5lQ0Bt',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
}),
|
||||
title: 'Road On Demand',
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var BingMapsLayers = new ol.layer.Group({
|
||||
title: 'Bing Maps',
|
||||
fold: 'close',
|
||||
layers: [
|
||||
lyrBingMapsRoadOnDemand,
|
||||
lyrBingMapsRoad,
|
||||
lyrBingMapsAerialWithLabels,
|
||||
lyrBingMapsAerial
|
||||
]
|
||||
});
|
||||
@@ -0,0 +1,69 @@
|
||||
var lyrGoogleMapsRoadNames = new ol.layer.Tile({
|
||||
title: "Road Names",
|
||||
source: new ol.source.TileImage({
|
||||
url: 'http://mt1.google.com/vt/lyrs=h&x={x}&y={y}&z={z}',
|
||||
wrapX: false}),
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrGoogleMapsRoadmap = new ol.layer.Tile({
|
||||
title: "Road Map",
|
||||
source: new ol.source.TileImage({
|
||||
url: 'http://mt1.google.com/vt/lyrs=m&x={x}&y={y}&z={z}',
|
||||
wrapX: false}),
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrGoogleMapsSatellite = new ol.layer.Tile({
|
||||
title: "Satellite",
|
||||
source: new ol.source.TileImage({
|
||||
url: 'http://mt1.google.com/vt/lyrs=s&hl=pl&&x={x}&y={y}&z={z}',
|
||||
wrapX: false }),
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrGoogleMapsHybrid = new ol.layer.Tile({
|
||||
title: "Satellite & Roads",
|
||||
source: new ol.source.TileImage({
|
||||
url: 'http://mt1.google.com/vt/lyrs=y&x={x}&y={y}&z={z}',
|
||||
wrapX: false}),
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrGoogleMapsTerrain = new ol.layer.Tile({
|
||||
title: "Terrain",
|
||||
source: new ol.source.TileImage({
|
||||
url: 'http://mt1.google.com/vt/lyrs=t&x={x}&y={y}&z={z}',
|
||||
wrapX: false }),
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrGoogleMapsHybrid2 = new ol.layer.Tile({
|
||||
title: "Terrain & Roads",
|
||||
source: new ol.source.TileImage({
|
||||
url: 'http://mt1.google.com/vt/lyrs=p&x={x}&y={y}&z={z}',
|
||||
wrapX: false}),
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var lyrGoogleMapsOnlyRoad = new ol.layer.Tile({
|
||||
title: "Road without Building",
|
||||
source: new ol.source.TileImage({
|
||||
url: 'http://mt1.google.com/vt/lyrs=r&x={x}&y={y}&z={z}',
|
||||
wrapX: false}),
|
||||
type: 'base',
|
||||
visible: false
|
||||
});
|
||||
var GoogleMapsLayers = new ol.layer.Group({
|
||||
title: 'Google Maps',
|
||||
fold: 'close',
|
||||
layers: [
|
||||
lyrGoogleMapsHybrid2,
|
||||
lyrGoogleMapsHybrid,
|
||||
lyrGoogleMapsTerrain,
|
||||
lyrGoogleMapsOnlyRoad,
|
||||
lyrGoogleMapsRoadNames,
|
||||
lyrGoogleMapsRoadmap,
|
||||
lyrGoogleMapsSatellite
|
||||
]
|
||||
});
|
||||
@@ -0,0 +1,116 @@
|
||||
var lyrMapTilerBasic = new ol.layer.Tile({
|
||||
title: 'Basic',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/basic/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerBright = new ol.layer.Tile({
|
||||
title: 'Bright',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/bright/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerDarkmatter = new ol.layer.Tile({
|
||||
title: 'Darkmatter',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/darkmatter/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerPastel = new ol.layer.Tile({
|
||||
title: 'Pastel',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/pastel/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerPositron = new ol.layer.Tile({
|
||||
title: 'Positron',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/positron/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerHybrid = new ol.layer.Tile({
|
||||
title: 'Hybrid',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/hybrid/{z}/{x}/{y}.jpg?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerStreets = new ol.layer.Tile({
|
||||
title: 'Streets',
|
||||
type: 'base',
|
||||
visible: true,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/streets/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerTopo = new ol.layer.Tile({
|
||||
title: 'Topo',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/topo/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerTopographique = new ol.layer.Tile({
|
||||
title: 'Topographique',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/topographique/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapTilerVoyager = new ol.layer.Tile({
|
||||
title: 'Voyager',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://api.maptiler.com/maps/voyager/{z}/{x}/{y}.png?key=aIokLGbrqIsRfBnnPIFP',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var MapTilerLayers = new ol.layer.Group({
|
||||
title: 'Maptiler',
|
||||
fold: 'open',
|
||||
layers: [
|
||||
lyrMapTilerVoyager,
|
||||
lyrMapTilerTopographique,
|
||||
lyrMapTilerTopo,
|
||||
lyrMapTilerStreets,
|
||||
lyrMapTilerHybrid,
|
||||
lyrMapTilerPositron,
|
||||
lyrMapTilerPastel,
|
||||
lyrMapTilerDarkmatter,
|
||||
lyrMapTilerBright,
|
||||
lyrMapTilerBasic
|
||||
]
|
||||
});
|
||||
@@ -0,0 +1,28 @@
|
||||
var lyrMapzenTerrarium = new ol.layer.Tile({
|
||||
title: 'Terrarium',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://s3.amazonaws.com/elevation-tiles-prod/terrarium/{z}/{x}/{y}.png',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrMapzenNormal = new ol.layer.Tile({
|
||||
title: 'Normal',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://s3.amazonaws.com/elevation-tiles-prod/normal/{z}/{x}/{y}.png',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var MapzenLayers = new ol.layer.Group({
|
||||
title: 'Mapzen',
|
||||
fold: 'close',
|
||||
layers: [
|
||||
lyrMapzenTerrarium,
|
||||
lyrMapzenNormal
|
||||
]
|
||||
});
|
||||
@@ -0,0 +1,26 @@
|
||||
var lyrOpenStreetMap = new ol.layer.Tile({
|
||||
title: 'Street',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.OSM({
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrOpenTopoMap = new ol.layer.Tile({
|
||||
title: 'Topo',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.XYZ({
|
||||
url: 'https://{a-c}.tile.opentopomap.org/{z}/{x}/{y}.png',
|
||||
crossOrigin: 'anonymous',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var OSMLayers = new ol.layer.Group({
|
||||
title: 'Open Street Map',
|
||||
fold: 'close',
|
||||
layers: [
|
||||
lyrOpenTopoMap,
|
||||
lyrOpenStreetMap
|
||||
]
|
||||
});
|
||||
@@ -0,0 +1,51 @@
|
||||
var lyrStamenToner = new ol.layer.Tile({
|
||||
title: 'Toner',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.Stamen({
|
||||
layer: 'toner',
|
||||
wrapX: false})
|
||||
});
|
||||
var lyrStamenTonerLite = new ol.layer.Tile({
|
||||
title: 'Toner-Lite',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.Stamen({
|
||||
layer: 'toner-lite',
|
||||
wrapX: false })
|
||||
});
|
||||
var lyrStamenTerrain = new ol.layer.Tile({
|
||||
title: 'Terrain',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.Stamen({
|
||||
layer: 'terrain',
|
||||
wrapX: false })
|
||||
});
|
||||
var lyrStamenTerrainBackground = new ol.layer.Tile({
|
||||
title: 'Terrain Background',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.Stamen({
|
||||
layer: 'terrain-background',
|
||||
wrapX: false})
|
||||
});
|
||||
var lyrStamenWaterColor = new ol.layer.Tile({
|
||||
title: 'Water Color',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.Stamen({
|
||||
layer: 'watercolor',
|
||||
wrapX: false})
|
||||
});
|
||||
var StamenLayers = new ol.layer.Group({
|
||||
title: 'Stamen',
|
||||
fold: 'close',
|
||||
layers: [
|
||||
lyrStamenTerrainBackground,
|
||||
lyrStamenTerrain,
|
||||
lyrStamenTonerLite,
|
||||
lyrStamenToner,
|
||||
lyrStamenWaterColor
|
||||
]
|
||||
});
|
||||
@@ -0,0 +1,66 @@
|
||||
var thunderforestAttributions = [
|
||||
'Tiles © <a href="http://www.thunderforest.com/">Thunderforest</a>',
|
||||
ol.source.OSM.ATTRIBUTION
|
||||
];
|
||||
var lyrThunderForestCycleMap = new ol.layer.Tile({
|
||||
title: 'Cycle',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.OSM(
|
||||
{
|
||||
'url': 'http://tile.thunderforest.com/cycle/{z}/{x}/{y}.png?apikey=ec248890a6ed43b8841ea243819f8d0d',
|
||||
attributions: thunderforestAttributions,
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrThunderForestTransport = new ol.layer.Tile({
|
||||
title: 'Transport',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.OSM(
|
||||
{
|
||||
'url': 'http://tile.thunderforest.com/transport/{z}/{x}/{y}.png?apikey=ec248890a6ed43b8841ea243819f8d0d',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrThunderForestTransportDark = new ol.layer.Tile({
|
||||
title: 'Transport Dark',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.OSM(
|
||||
{
|
||||
'url': 'http://tile.thunderforest.com/transport-dark/{z}/{x}/{y}.png?apikey=ec248890a6ed43b8841ea243819f8d0d',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrThunderForestLandscape = new ol.layer.Tile({
|
||||
title: 'Landscape',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.OSM(
|
||||
{
|
||||
'url': 'http://tile.thunderforest.com/landscape/{z}/{x}/{y}.png?apikey=ec248890a6ed43b8841ea243819f8d0d',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var lyrThunderForestOutdoors = new ol.layer.Tile({
|
||||
title: 'Outdoors',
|
||||
type: 'base',
|
||||
visible: false,
|
||||
source: new ol.source.OSM(
|
||||
{
|
||||
'url': 'http://tile.thunderforest.com/outdoors/{z}/{x}/{y}.png?apikey=ec248890a6ed43b8841ea243819f8d0d',
|
||||
wrapX: false
|
||||
})
|
||||
});
|
||||
var ThunderForestLayers = new ol.layer.Group({
|
||||
title: 'Thunder Forest',
|
||||
fold: 'close',
|
||||
layers: [
|
||||
lyrThunderForestTransportDark,
|
||||
lyrThunderForestTransport,
|
||||
lyrThunderForestCycleMap,
|
||||
lyrThunderForestLandscape,
|
||||
lyrThunderForestOutdoors
|
||||
]
|
||||
});
|
||||
@@ -0,0 +1,271 @@
|
||||
var publicNotesSource = new ol.source.Vector({
|
||||
url: '../' + vectorsPath + 'publicnotes.geojson',
|
||||
format: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}),
|
||||
wrapX: false
|
||||
});
|
||||
var publicNotesLayer = new ol.layer.Vector({
|
||||
title: 'Public Notes',
|
||||
visible: true,
|
||||
source: publicNotesSource,
|
||||
minResolution: 0,
|
||||
maxResolution: 1000,
|
||||
style: function (feature) {
|
||||
return [new ol.style.Style({
|
||||
image: feature.get('notetype') === 'Public' ? new ol.style.Icon({
|
||||
scale: 1,
|
||||
src: '../img/note_Public.png',
|
||||
opacity: 1
|
||||
}) : new ol.style.Icon({
|
||||
scale: 1,
|
||||
src: '../img/note_Public.png',
|
||||
opacity: 1
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
offsetY: 25,
|
||||
text: feature.get('notename'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: '#000' }),
|
||||
stroke: new ol.style.Stroke({ color: '#fff', width: 2 })
|
||||
})
|
||||
})];
|
||||
}
|
||||
});
|
||||
var myNotesSource = new ol.source.Vector({
|
||||
url: '../' + vectorsPath + 'mynotes.geojson',
|
||||
format: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}),
|
||||
wrapX: false
|
||||
});
|
||||
var myNotesLayer = new ol.layer.Vector({
|
||||
title: 'My Notes',
|
||||
visible: true,
|
||||
source: myNotesSource,
|
||||
minResolution: 0,
|
||||
maxResolution: 1000,
|
||||
style: function (feature) {
|
||||
return [new ol.style.Style({
|
||||
image: feature.get('notetype') === 'Public' ? new ol.style.Icon({
|
||||
scale: 1,
|
||||
src: '../img/notePublic.png',
|
||||
opacity: 1
|
||||
}) : new ol.style.Icon({
|
||||
scale: 1,
|
||||
src: '../img/notePrivate.png',
|
||||
opacity: 1
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
offsetY: 25,
|
||||
text: feature.get('notename'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: '#000' }),
|
||||
stroke: new ol.style.Stroke({ color: '#fff', width: 2 })
|
||||
})
|
||||
})];
|
||||
}
|
||||
});
|
||||
var publicNetworkSource = new ol.source.Vector({
|
||||
url: '../' + vectorsPath + 'publicnetwork.geojson',
|
||||
format: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}),
|
||||
wrapX: false
|
||||
});
|
||||
var publicNetworkLayer = new ol.layer.Vector({
|
||||
title: 'Public Network',
|
||||
visible: true,
|
||||
source: publicNetworkSource,
|
||||
minResolution: 0,
|
||||
maxResolution: 1000,
|
||||
style: function (feature) {
|
||||
return [new ol.style.Style({
|
||||
image: feature.get('technology') === '4G' ? new ol.style.Icon({
|
||||
scale: .6,
|
||||
src: '../img/site_Public.png',
|
||||
opacity: 1
|
||||
}) : new ol.style.Icon({
|
||||
scale: .6,
|
||||
src: '../img/site_Public.png',
|
||||
opacity: 1
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
offsetY: 25,
|
||||
text: feature.get('sitename'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: '#000' }),
|
||||
stroke: new ol.style.Stroke({ color: '#fff', width: 2 })
|
||||
})
|
||||
})];
|
||||
}
|
||||
});
|
||||
var myNetworkSource = new ol.source.Vector({
|
||||
url: '../' + vectorsPath + 'mynetwork.geojson',
|
||||
format: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}),
|
||||
wrapX: false
|
||||
});
|
||||
var myNetworkLayer = new ol.layer.Vector({
|
||||
title: 'My Network',
|
||||
visible: true,
|
||||
source: myNetworkSource,
|
||||
minResolution: 0,
|
||||
maxResolution: 1000,
|
||||
style: function (feature) {
|
||||
return [new ol.style.Style({
|
||||
image: feature.get('technology') === '4G' ? new ol.style.Icon({
|
||||
scale: .6,
|
||||
src: '../img/site4G.png',
|
||||
opacity: 1
|
||||
}) : new ol.style.Icon({
|
||||
scale: .6,
|
||||
src: '../img/site2G.png',
|
||||
opacity: 1
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
offsetY: 25,
|
||||
text: feature.get('sitename'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: '#000' }),
|
||||
stroke: new ol.style.Stroke({ color: '#fff', width: 2 })
|
||||
})
|
||||
})];
|
||||
}
|
||||
});
|
||||
var myPolygonsSource = new ol.source.Vector({
|
||||
url: '../' + vectorsPath + 'mypolygons.geojson',
|
||||
format: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}),
|
||||
wrapX: false
|
||||
});
|
||||
var myPolygonsLayer = new ol.layer.Vector({
|
||||
title: 'My Polygons',
|
||||
visible: true,
|
||||
source: myPolygonsSource,
|
||||
minResolution: 0,
|
||||
maxResolution: 1000,
|
||||
style: function (feature, resolution) {
|
||||
return [new ol.style.Style({
|
||||
fill: new ol.style.Fill({
|
||||
color: 'rgba(255, 255, 255, 0.2)'
|
||||
}),
|
||||
stroke: new ol.style.Stroke({
|
||||
color: '#ffcc33',
|
||||
width: 2
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
text: feature.get('polygonname'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: '#000' }),
|
||||
stroke: new ol.style.Stroke({ color: '#fff', width: 2 })
|
||||
})
|
||||
})];
|
||||
}
|
||||
});
|
||||
var myLinksSource = new ol.source.Vector({
|
||||
url: '../' + vectorsPath + 'mylinks.geojson',
|
||||
format: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}),
|
||||
wrapX: false
|
||||
});
|
||||
var myLinksLayer = new ol.layer.Vector({
|
||||
title: 'My Links',
|
||||
visible: true,
|
||||
source: myLinksSource,
|
||||
minResolution: 0,
|
||||
maxResolution: 1000,
|
||||
style: function (feature, resolution) {
|
||||
return [new ol.style.Style({
|
||||
stroke: new ol.style.Stroke({
|
||||
color: feature.get('linktype') === 'internal' ? 'rgba(0,255,255,1)' : 'rgba(255,0,220,1)',
|
||||
lineDash: [7, 7],
|
||||
width: 4
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
text: feature.get('linkname'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: '#000' }),
|
||||
stroke: new ol.style.Stroke({ color: '#fff', width: 2 })
|
||||
})
|
||||
})];
|
||||
}
|
||||
});
|
||||
var myClutterSource = new ol.source.Vector({
|
||||
url: '../' + vectorsPath + 'myclutter.geojson',
|
||||
format: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}),
|
||||
wrapX: false
|
||||
});
|
||||
var myClutterLayer = new ol.layer.Vector({
|
||||
title: 'My Clutter',
|
||||
visible: true,
|
||||
source: myClutterSource,
|
||||
minResolution: 0,
|
||||
maxResolution: 1000,
|
||||
style: function (feature, resolution) {
|
||||
return [new ol.style.Style({
|
||||
fill: new ol.style.Fill({
|
||||
color: 'rgba(255, 255, 255, 0.2)'
|
||||
}),
|
||||
stroke: new ol.style.Stroke({
|
||||
color: '#11f0ff',
|
||||
width: 2
|
||||
}),
|
||||
text: new ol.style.Text({
|
||||
text: feature.get('cluttertype'),
|
||||
font: '14px "Liberation Sans", "Lucida Sans", "Lucida Sans Regular", "Lucida Grande", "Lucida Sans Unicode", Geneva, Verdana, sans-serif',
|
||||
fill: new ol.style.Fill({ color: '#000' }),
|
||||
stroke: new ol.style.Stroke({ color: '#fff', width: 2 })
|
||||
})
|
||||
})];
|
||||
}
|
||||
});
|
||||
var resultsSource = new ol.source.Vector({
|
||||
url: '../' + vectorsPath + 'results.geojson',
|
||||
format: new ol.format.GeoJSON({
|
||||
extractStyles: true,
|
||||
extractAttributes: true
|
||||
}),
|
||||
wrapX: false
|
||||
});
|
||||
var resultsLayer = new ol.layer.Vector({
|
||||
source: resultsSource
|
||||
});
|
||||
var overlayLayers = new ol.layer.Group({
|
||||
title: 'Overlay Layers',
|
||||
fold: 'close',
|
||||
layers: [
|
||||
resultsLayer,
|
||||
myPolygonsLayer,
|
||||
publicNotesLayer,
|
||||
myNotesLayer,
|
||||
myLinksLayer,
|
||||
publicNetworkLayer,
|
||||
myNetworkLayer
|
||||
]
|
||||
});
|
||||
var baseLayers = new ol.layer.Group({
|
||||
'title': 'Base Layers',
|
||||
fold: 'close',
|
||||
layers: [
|
||||
GoogleMapsLayers,
|
||||
BingMapsLayers,
|
||||
MapzenLayers,
|
||||
ThunderForestLayers,
|
||||
MapTilerLayers,
|
||||
StamenLayers,
|
||||
OSMLayers
|
||||
]
|
||||
});
|
||||
213
software/cnip/cnip/Scripts/cnip/webui/vectorrequests.js
Normal file
213
software/cnip/cnip/Scripts/cnip/webui/vectorrequests.js
Normal file
@@ -0,0 +1,213 @@
|
||||
function getDataByIdx(source, Idx) {
|
||||
let returnString = '';
|
||||
if (Idx) {
|
||||
if (Number(Idx) > -1) {
|
||||
let feature = source.getFeatures()[Idx];
|
||||
let keys = feature.getKeys();
|
||||
for (let j = 0; j < keys.length; j++) {
|
||||
if (keys[j] !== 'geometry' && keys[j] !== 'elevstr') {
|
||||
returnString += feature.get(keys[j]).toString() + '\t';
|
||||
}
|
||||
}
|
||||
returnString = returnString.substring(0, returnString.length - 1);
|
||||
}
|
||||
}
|
||||
return returnString;
|
||||
}
|
||||
function getIdxById(source, key, id) {
|
||||
let features = source.getFeatures();
|
||||
let returnString = '';
|
||||
for (let i = 0; i < features.length; i++) {
|
||||
if (features[i].get(key).toString() === id.toString()) {
|
||||
returnString = i.toString(); break;
|
||||
}
|
||||
}
|
||||
return returnString;
|
||||
}
|
||||
function getFeaturesCount(source) {
|
||||
return source.getFeatures().length;
|
||||
}
|
||||
function deleteFeatureByIdx(source, Idx) {
|
||||
if (Idx) {
|
||||
if (Number(Idx) > -1) {
|
||||
let feature = source.getFeatures()[Idx];
|
||||
source.removeFeature(feature);
|
||||
myMap.render();
|
||||
}
|
||||
}
|
||||
}
|
||||
function zoomToFeatureByIdx(source, Idx) {
|
||||
if (Idx) {
|
||||
if (Number(Idx) > -1) {
|
||||
let feature = source.getFeatures()[Idx];
|
||||
myMap.getView().animate({
|
||||
duration: 700,
|
||||
center: ol.extent.getCenter(feature.getGeometry().getExtent())
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
function getNewIdx(source, key) {
|
||||
let features = source.getFeatures();
|
||||
let newIdx = 0; let eIdx = 0;
|
||||
features.forEach(function (feature) {
|
||||
eIdx = Number(feature.get(key));
|
||||
if (newIdx < eIdx) { newIdx = eIdx; }
|
||||
});
|
||||
return (newIdx + 1).toString();
|
||||
}
|
||||
var download = {
|
||||
KML: function (source, name) {
|
||||
let blob = new Blob([source.getKMLString(true)], { type: 'text/plain;charset=utf-8' });
|
||||
saveAs(blob, name + '.kml');
|
||||
},
|
||||
JSON: function (source, name) {
|
||||
let blob = new Blob([source.getJSONString(true)], { type: 'text/plain;charset=utf-8' });
|
||||
saveAs(blob, name + '.geojson');
|
||||
},
|
||||
CSV: function (source, name) {
|
||||
let csv = [];
|
||||
let header = {};
|
||||
let n = 0;
|
||||
let isPt = true;
|
||||
let features = JSON.parse(source.getJSONString()).features;
|
||||
features.forEach(function (f) {
|
||||
for (let p in f.properties) {
|
||||
if (header[p] === undefined) {
|
||||
header[p] = n++;
|
||||
}
|
||||
}
|
||||
if (f.geometry.type !== 'Point') isPt = false;
|
||||
});
|
||||
features.forEach(function (f) {
|
||||
let row = [];
|
||||
for (let p in header) {
|
||||
row[header[p]] = f.properties[p];
|
||||
}
|
||||
if (isPt) {
|
||||
row.push(f.geometry.coordinates[0]);
|
||||
row.push(f.geometry.coordinates[1]);
|
||||
} else {
|
||||
row.push(f.geometry.type);
|
||||
row.push(JSON.stringify(f.geometry.coordinates));
|
||||
}
|
||||
csv.push(row);
|
||||
});
|
||||
let cols = [];
|
||||
for (let p in header) {
|
||||
cols.push(p);
|
||||
}
|
||||
if (isPt) {
|
||||
cols.push('lon');
|
||||
cols.push('lat');
|
||||
} else {
|
||||
cols.push('type');
|
||||
cols.push('coord');
|
||||
}
|
||||
csv.unshift(cols);
|
||||
result = Papa.unparse(csv);
|
||||
let blob = new Blob([result], { type: 'text/plain;charset=utf-8' });
|
||||
saveAs(blob, name + '.csv');
|
||||
}
|
||||
};
|
||||
function saveAllVectors() {
|
||||
uploadDataToUrl(myNetworkLayer.getSource().getJSONString(),
|
||||
vectorsPath + 'mynetwork.geojson');
|
||||
Ajax_runccmd("UploadNetworkToDB", "");
|
||||
myMap.render();
|
||||
loadSitesTreeFromFile();
|
||||
|
||||
uploadDataToUrl(myPolygonsLayer.getSource().getJSONString(),
|
||||
vectorsPath + 'mypolygons.geojson');
|
||||
Ajax_runccmd("UploadPolygonsToDB", "");
|
||||
myMap.render();
|
||||
loadPolygonsTreeFromFile();
|
||||
|
||||
uploadDataToUrl(myLinksLayer.getSource().getJSONString(),
|
||||
vectorsPath + 'mylinks.geojson');
|
||||
Ajax_runccmd("UploadLinksToDB", "");
|
||||
myMap.render();
|
||||
loadLinksTreeFromFile();
|
||||
|
||||
uploadDataToUrl(myNotesLayer.getSource().getJSONString(),
|
||||
vectorsPath + 'mynotes.geojson');
|
||||
Ajax_runccmd("UploadNotesToDB", "");
|
||||
myMap.render();
|
||||
loadNotesTreeFromFile();
|
||||
}
|
||||
function loadAllVectors() {
|
||||
Ajax_runccmd("GetVectorsFromDB", "");
|
||||
|
||||
Ajax_loadSourceFromFile(myNetworkLayer.getSource(),
|
||||
"../" + vectorsPath + "mynetwork.geojson");
|
||||
loadSitesTreeFromSource();
|
||||
|
||||
Ajax_loadSourceFromFile(myPolygonsLayer.getSource(),
|
||||
"../" + vectorsPath + "mypolygons.geojson");
|
||||
loadPolygonsTreeFromSource();
|
||||
|
||||
Ajax_loadSourceFromFile(myLinksLayer.getSource(),
|
||||
"../" + vectorsPath + "mylinks.geojson");
|
||||
loadLinksTreeFromSource();
|
||||
|
||||
Ajax_loadSourceFromFile(myNotesLayer.getSource(),
|
||||
"../" + vectorsPath + "mynotes.geojson");
|
||||
loadNotesTreeFromSource();
|
||||
|
||||
Ajax_loadSourceFromFile(resultsLayer.getSource(),
|
||||
"../" + vectorsPath + "results.geojson");
|
||||
loadResultsTreeFromSource();
|
||||
}
|
||||
function Ajax_loadSourceFromFile(source, url) {
|
||||
$.ajax({
|
||||
type: "GET",
|
||||
url: url,
|
||||
data: "",
|
||||
async: false,
|
||||
contentType: "application/json; charset=utf-8",
|
||||
dataType: "json",
|
||||
success: function (r) {
|
||||
source.clearFeatures();
|
||||
source.addFeatures(
|
||||
new ol.format.GeoJSON().readFeatures(r,
|
||||
{
|
||||
dataProjection: 'EPSG:4326',
|
||||
featureProjection: 'EPSG:3857'
|
||||
}
|
||||
));
|
||||
myMap.render();
|
||||
},
|
||||
failure: function (r) {
|
||||
source.clearFeatures();
|
||||
myMap.render();
|
||||
},
|
||||
error: function (r) {
|
||||
source.clearFeatures();
|
||||
myMap.render();
|
||||
}
|
||||
});
|
||||
}
|
||||
function uploadDataToUrl(data, url) {
|
||||
Ajax_runccmd("UploadDataToUrl", "{'data':'" + data + "','url':'" + url + "'}");
|
||||
}
|
||||
function Ajax_runccmd(command, args) {
|
||||
let result;
|
||||
$.ajax({
|
||||
async: false,
|
||||
type: "POST",
|
||||
url: "webui.aspx/" + command,
|
||||
data: args,
|
||||
contentType: "application/json; charset=utf-8",
|
||||
dataType: "json",
|
||||
success: function (r) {
|
||||
result = r.d;
|
||||
},
|
||||
failure: function (r) {
|
||||
return "";
|
||||
},
|
||||
error: function (r) {
|
||||
return "";
|
||||
}
|
||||
});
|
||||
return result;
|
||||
}
|
||||
180
software/cnip/cnip/Scripts/cnip/webui/webui.js
Normal file
180
software/cnip/cnip/Scripts/cnip/webui/webui.js
Normal file
@@ -0,0 +1,180 @@
|
||||
// about
|
||||
var about = document.getElementById('about');
|
||||
about.innerHTML = '<img alt="" style="width:113px;height:30px;" src="../img/cnip.png" />';
|
||||
about.style.display = 'block';
|
||||
// action status
|
||||
var actionRunning = false;
|
||||
// initialize map
|
||||
var myMap = new ol.Map({
|
||||
loadTilesWhileAnimating: false,
|
||||
loadTilesWhileInteracting: false,
|
||||
interactions: ol.interaction.defaults({ altShiftDragRotate: false, pinchRotate: false }),
|
||||
target: 'myMap',
|
||||
view: new ol.View({
|
||||
center: ol.proj.fromLonLat([67.056848, 24.808224]),
|
||||
zoom: 15
|
||||
}),
|
||||
layers: [
|
||||
baseLayers,
|
||||
overlayLayers
|
||||
]
|
||||
});
|
||||
var sidebar = new ol.control.Sidebar({ element: 'sidebar', position: 'left' });
|
||||
var toc = document.getElementById('layers');
|
||||
ol.control.LayerSwitcher.renderPanel(myMap, toc);
|
||||
myMap.addControl(sidebar);
|
||||
myMap.addControl(new ol.control.ScaleLine({ units: 'metric' }));
|
||||
myMap.getControls().forEach(function (control) {
|
||||
if (control instanceof ol.control.Attribution) {
|
||||
myMap.removeControl(control);
|
||||
}
|
||||
}, this);
|
||||
// pointer move functionality
|
||||
var highlightLayer = new ol.layer.Vector({
|
||||
source: new ol.source.Vector(),
|
||||
map: myMap
|
||||
});
|
||||
highlightLayer.setStyle(highlightStyle);
|
||||
var highlightFeature;
|
||||
//var featureTip = $('#featureTip');
|
||||
//featureTip.tooltip({ animation: false, trigger: 'manual' });
|
||||
var noteInfo = document.getElementById('noteInfo');
|
||||
var featureInfo = document.getElementById('featureInfo');
|
||||
var locationInfo = document.getElementById('locationInfo');
|
||||
var displayFeatureInfo = function (e) {
|
||||
let pixel = myMap.getEventPixel(e.originalEvent);
|
||||
let features = []; let feature = undefined;
|
||||
let layers = []; let layer = undefined;
|
||||
myMap.forEachFeatureAtPixel(pixel,
|
||||
function (feature, layer) { layers.push(layer); features.push(feature); });
|
||||
let layerIndex = 0;
|
||||
features.forEach(function (f) {
|
||||
if (f.get('sitename') !== undefined || f.get('linkname') !== undefined || f.get('notename') !== undefined) {
|
||||
feature = f; layer = layers[layerIndex];
|
||||
}
|
||||
layerIndex += 1;
|
||||
});
|
||||
if (feature === undefined) {
|
||||
layerIndex = 0;
|
||||
features.forEach(function (f) {
|
||||
feature = f; layer = layers[layerIndex];
|
||||
});
|
||||
layerIndex += 1;
|
||||
}
|
||||
if (!addLink.getActive() && !deleteSiteActive && !deleteLinkActive && !deleteNoteActive && !deletePolygonActive) {
|
||||
if (feature) {
|
||||
let properties = [];
|
||||
if (feature.getGeometry().getType() === 'Polygon') {
|
||||
let geom = feature.clone().getGeometry().transform('EPSG:3857', 'EPSG:4326');
|
||||
let polygon = turf.polygon(geom.getCoordinates());
|
||||
let area = round(turf.area(polygon) / 1000000, 2);
|
||||
let centerOfMass = turf.getCoord(turf.centerOfMass(polygon));
|
||||
let center = turf.getCoord(turf.center(polygon));
|
||||
properties.push('<tr><td style="text-align:left;padding-left:5px;">Calculated</td><td> </td><td style="text-align:left;padding-right:5px;"></td></tr>');
|
||||
properties.push('<tr><td style="text-align:left;padding-left:5px;">Area</td><td> : </td><td style="text-align:left;padding-right:5px;">' + area.toString() + ' Km²' + '</td></tr>');
|
||||
properties.push('<tr><td style="text-align:left;padding-left:5px;">Center</td><td> : </td><td style="text-align:left;padding-right:5px;">' + round(center[0], 6).toString() + ',' + round(center[1], 6).toString() + '</td></tr>');
|
||||
properties.push('<tr><td style="text-align:left;padding-left:5px;">Center of Mass</td><td> : </td><td style="text-align:left;padding-right:5px;">' + round(centerOfMass[0], 6).toString() + ',' + round(centerOfMass[1], 6).toString() + '</td></tr>');
|
||||
properties.push('<tr><td style="text-align:left;padding-left:5px;"></td><td> </td><td style="text-align:left;padding-right:5px;"></td></tr>');
|
||||
}
|
||||
feature.getKeys().forEach(function (key) {
|
||||
if (key !== 'geometry' && key !== 'elevstr' && !key.toString().includes('id')) {
|
||||
if (feature.get(key)) {
|
||||
properties.push('<tr><td style="text-align:left;padding-left:5px;">' + titleCase(key) +
|
||||
'</td><td> : </td><td style="text-align:left;padding-right:5px;">' +
|
||||
(isNumber(feature.get(key)) ? round(parseFloat(feature.get(key)), 6) :
|
||||
feature.get(key).toString().length > 15 ?
|
||||
feature.get(key).toString().substr(0, 15) : feature.get(key)) +
|
||||
'</td></tr>');
|
||||
}
|
||||
}
|
||||
});
|
||||
featureInfo.innerHTML = '<table><tbody><tr><td style="color:var(--facecolor);background-color:var(--barcolor);padding-left:5px;">Quick Info</td><td style="color:var(--facecolor);background-color:var(--barcolor)"></td><td style="color:var(--facecolor);background-color:var(--barcolor)"></td></tr>' + properties.join('') + '</tbody></table>' || '(unknown)';
|
||||
featureInfo.style.opacity = 1;
|
||||
if (layer === myNotesLayer || layer === publicNotesLayer) {
|
||||
noteInfo.style.left = (pixel[0] + 5).toString() + 'px';
|
||||
noteInfo.style.top = (pixel[1] - 15).toString() + 'px';
|
||||
noteInfo.innerHTML = '<span style="background-color: #fff2ab;">+ Description ' +
|
||||
' ' +
|
||||
' ... </span><br/>' +
|
||||
'<span style="background-color: #fff7d1;">' + truncate(feature.get('description'), 255) + '</span>';
|
||||
noteInfo.style.opacity = 1;
|
||||
}
|
||||
//featureTip.css({ left: pixel[0] + 'px', top: pixel[1] - 15 + 'px' });
|
||||
//featureTip.attr('data-original-title', feature.get('sitename') === undefined ?
|
||||
// feature.get('polygonname') === undefined ? feature.get('linkname') :
|
||||
// feature.get('polygonname') : feature.get('sitename')).tooltip('show');
|
||||
} else {
|
||||
featureInfo.innerHTML = ''; featureInfo.style.opacity = 0;
|
||||
noteInfo.innerHTML = ''; noteInfo.style.opacity = 0;
|
||||
//featureTip.attr('data-original-title', '').tooltip('hide');
|
||||
}
|
||||
}
|
||||
if (feature !== highlightFeature) {
|
||||
if (highlightFeature) {
|
||||
highlightLayer.getSource().clear();
|
||||
}
|
||||
if (feature) {
|
||||
if (!addLink.getActive() && !deleteSiteActive && !deleteLinkActive && !deleteNoteActive && !deletePolygonActive) {
|
||||
highlightLayer.getSource().addFeature(feature);
|
||||
} else {
|
||||
if (addLink.getActive() || deleteSiteActive) {
|
||||
if (layer === myNetworkLayer) {
|
||||
highlightLayer.getSource().addFeature(feature);
|
||||
}
|
||||
}
|
||||
if (deleteNoteActive) {
|
||||
if (layer === myNotesLayer) {
|
||||
highlightLayer.getSource().addFeature(feature);
|
||||
}
|
||||
}
|
||||
if (deleteLinkActive) {
|
||||
if (layer === myLinksLayer) {
|
||||
highlightLayer.getSource().addFeature(feature);
|
||||
}
|
||||
}
|
||||
if (deletePolygonActive) {
|
||||
if (layer === myPolygonsLayer) {
|
||||
highlightLayer.getSource().addFeature(feature);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
highlightFeature = feature;
|
||||
}
|
||||
};
|
||||
function highlightPoint(loc) {
|
||||
let feature = new ol.Feature(new ol.geom.Point(ol.proj.fromLonLat(loc)));
|
||||
feature.setStyle(highlightPointStyle);
|
||||
highlightLayer.getSource().clear();
|
||||
highlightLayer.getSource().addFeature(feature);
|
||||
highlightFeature = feature;
|
||||
}
|
||||
var displayElevation = function (e) {
|
||||
let lonlat = ol.proj.toLonLat(e.coordinate);
|
||||
let elev = ''; //Ajax_runccmd("GetElevationFromLonLat", "{'longitude':'" + lonlat[0] + "','latitude':'" + lonlat[1] + "'}");
|
||||
locationInfo.style.opacity = 1;
|
||||
locationInfo.innerHTML =
|
||||
ol.coordinate.format(lonlat, 'lon {x}\xB0 lat {y}\xB0 ', 6);//elev ', 6) + elev;
|
||||
};
|
||||
var setPointerStyle = function (e) {
|
||||
if (modifyNote.getActive()) {
|
||||
let hit = e.map.hasFeatureAtPixel(e.pixel, {
|
||||
layerFilter: function (layer) {
|
||||
return layer === myNotesLayer;
|
||||
}
|
||||
});
|
||||
e.map.getTargetElement().style.cursor = hit ? 'move' : '';
|
||||
}
|
||||
if (modifySite.getActive()) {
|
||||
let hit = e.map.hasFeatureAtPixel(e.pixel, {
|
||||
layerFilter: function (layer) {
|
||||
return layer === myNetworkLayer;
|
||||
}
|
||||
});
|
||||
e.map.getTargetElement().style.cursor = hit ? 'move' : '';
|
||||
}
|
||||
};
|
||||
$('#sidebar div ul li a').click(function () {
|
||||
toggleSelect();
|
||||
});
|
||||
|
||||
2
software/cnip/cnip/Scripts/dom-to-image.min.js
vendored
Normal file
2
software/cnip/cnip/Scripts/dom-to-image.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
20
software/cnip/cnip/Scripts/html2canvas.min.js
vendored
Normal file
20
software/cnip/cnip/Scripts/html2canvas.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
2670
software/cnip/cnip/Scripts/jquery-3.4.1.intellisense.js
vendored
Normal file
2670
software/cnip/cnip/Scripts/jquery-3.4.1.intellisense.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
10598
software/cnip/cnip/Scripts/jquery-3.4.1.js
vendored
Normal file
10598
software/cnip/cnip/Scripts/jquery-3.4.1.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
2
software/cnip/cnip/Scripts/jquery-3.4.1.min.js
vendored
Normal file
2
software/cnip/cnip/Scripts/jquery-3.4.1.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1
software/cnip/cnip/Scripts/jquery-3.4.1.min.map
Normal file
1
software/cnip/cnip/Scripts/jquery-3.4.1.min.map
Normal file
File diff suppressed because one or more lines are too long
8495
software/cnip/cnip/Scripts/jquery-3.4.1.slim.js
Normal file
8495
software/cnip/cnip/Scripts/jquery-3.4.1.slim.js
Normal file
File diff suppressed because it is too large
Load Diff
2
software/cnip/cnip/Scripts/jquery-3.4.1.slim.min.js
vendored
Normal file
2
software/cnip/cnip/Scripts/jquery-3.4.1.slim.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1
software/cnip/cnip/Scripts/jquery-3.4.1.slim.min.map
Normal file
1
software/cnip/cnip/Scripts/jquery-3.4.1.slim.min.map
Normal file
File diff suppressed because one or more lines are too long
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user