活动和列表

This commit is contained in:
wanyongkang
2020-11-09 11:02:50 +08:00
parent 18c1865d77
commit 26744eae20
9 changed files with 821 additions and 153 deletions

View File

@@ -1,4 +1,6 @@
@using Hncore.Pass.Vpn.Domain
@using Hncore.Pass.Vpn.Domain
@using Hncore.Infrastructure.Extension
@using Hncore.Pass.Vpn.Service
@inject ProductService m_ProductService
@@ -16,23 +18,22 @@
display: inline !important;
}
</style>
<div id="app">
<div class="container-fluid softBg">
<div class="container">
<div class="row">
<form asp-action="index" asp-controller="linelist" method="get">
<div class="col-lg-3 zxbz">
<img src="~/img/img_xinalu.png">
</div>
<div class="col-lg-5 searchInput">
<input type="text" name="KeyWord" placeholder="输入地区/名称/服务器" id="KeyWord" />
<input v-on:keyup.13="search_all()" type="text" v-model="search_all_data" name="KeyWord" placeholder="输入地区/名称/服务器" />
</div>
<div class="col-lg-2 searchBtn text-left">
<button type="submit" class="btn btn-search">搜索全部</button>
<button v-on:click="search_all()" class="btn btn-search">搜索全部</button>
</div>
<div class="col-lg-2">
<span class="btnZhilian cursor"><a asp-index="" asp-controller="article" asp-route-Catalog="4" style="color:white"><img src="~/img/zhilian.png">直连教程</a></span>
</div>
</form>
</div>
<div class="row">
<div class="col-lg-3">
@@ -46,11 +47,15 @@
</div>
<div class="container">
<p class="xianluIntro" style="text-align: center;font-size: 25px;">*线路表和账号必须为同一产品才能使用。@*(已购产品:<span>老鹰b组</span>*@</p>
<p style="text-align: center;font-size: 25px;color:red;">*****公告*****</p>
<p style="text-align: center;font-size: 20px;">*聚IP商城全线服务器都已更新可显示实时维护状态及服务器负载情况*</p>
<a style="margin-left: 45%;" href="/linelist/index2" class="btn btn-primary">*查看老版本服务器*</a>
<p style="text-align: center;font-size: 20px;">*温馨提示请尽量使用新版服务器老版服务器将于12月1号停止维护*</p>
<p class="xianluIntro" style="text-align: center;font-size: 25px;">*线路表和账号必须为同一产品才能使用。</p>
<div class="xianlu">
@foreach (var item in product.Where(m => m.Id != 3 && m.Id != 7 && m.Id != 9))
{
<div class="item @(item.Id==pid?"blueLine":"")" a-pid="@item.Id" a-name="@item.Name">
<div v-on:click="select_product(@item.Id)" id="product-@item.Id" class="item @(item.Id==pid?"blueLine":"")" a-pid="@item.Id" a-name="@item.Name">
<span>@item.Name</span><img src="~/img/check.png">
</div>
}
@@ -60,74 +65,211 @@
<div class="container">
<div class="row">
<div class="col-lg-2 miyao">
<p><img src="~/img/miyao.png"> L2TP密钥<b style="color:red;">@currentProduct.L2TPPwd</b></p>
<p><img src="~/img/dk.png"> SSTP端口<b style="color:red;">@currentProduct.SSTPPort</b></p>
<p><img src="~/img/miyao.png"> L2TP密钥<b style="color:red;">{{l2tp}}</b></p>
<p><img src="~/img/dk.png"> SSTP端口<b style="color:red;">{{sstp}}</b></p>
</div>
<div class="col-lg-2 fanwei">
搜索范围:<span id="pName">@currentProduct.Name</span>
搜索范围:<span id="pName">{{search_field}}</span>
</div>
<div class="col-lg-8">
<form asp-action="index" asp-controller="linelist" method="get">
<input type="hidden" name="ProductId" id="ProductId" value="@pid" />
<input type="text" name="KeyWord" class="searchDq" placeholder="输入地区/名称/服务器" id="KeyWord" />
<button type="submit" class="btn btn-primary">搜索当前线路表</button>
<span class="daochu"><img src="~/img/excel.png">导出Excel</span>
</form>
<input v-on:keyup.13="search_product()" type="text" v-model="search_product_data" name="KeyWord" class="searchDq" placeholder="输入地区/名称/服务器" />
<button v-on:click="search_product()" class="btn btn-primary">搜索当前线路表</button>
<span class="daochu" v-on:click="export_data()" ><img src="~/img/excel.png">导出Excel</span>
</div>
</div>
</div>
<div class="container">
<div class="container" >
<table class="table table-striped xianluTable">
<tr>
<th><img src="~/img/chengshi.png">产品</th>
<th><img src="~/img/chengshi.png">城市</th>
<th><img src="~/img/yunyingshang.png"> 运营商</th>
<th><img src="~/img/yuming.png"> 服务器域名</th>
<th><img src="~/img/daikuan.png"> 实时带宽</th>
<th><img src="~/img/ipliang.png"> IP量</th>
<th><img src="~/img/zhuangtai.png"> 状态</th>
<th><img src="~/img/xianlushuoming.png"> 线路说明</th>
<th>产品</th>
<th>城市</th>
<th>运营商</th>
<th>服务器域名</th>
<th>IP量</th>
<th>实时带宽</th>
<th>维护状态</th>
<th>负载状态</th>
</tr>
@foreach (var group in Model.GroupBy(m => m.Province))
{
<tr><td style="background:#dedede;"></td><td colspan="7" style="background:#dedede;text-align:left;padding-left: 50px;">@group.Key</td></tr>
@foreach (var item in group)
{
<tr style="@(item.Status=="正常"?"":"color:red")">
<td>@item.ProductName</td>
<td>@item.City</td>
<td>@item.Name</td>
<td class="blueT">@item.ServerUrl</td>
<td>@item.BandWidth</td>
<td>@item.IpRemark</td>
<td class="greenT">@item.Status</td>
<td>评分★★★★★</td>
</tr>
}
}
<tr v-for="site in table_data" :style="(site.online=='故障')?'color:#ec5656;':''">
<td>{{site.name}}</td>
<td v-if="site.online==null" style="color:#993399">{{site.city}}</td>
<td v-if="site.online!=null">{{site.city}}</td>
<td>{{site.supply}}</td>
<td>{{site.nasname}}</td>
<td>{{site.ip}}</td>
<td>{{site.daikuan}}</td>
<td>{{site.online}}</td>
<td>{{site.status}}</td>
</tr>
</table>
</div>
</div>
<script src="~/js/vue.js"></script>
<script type="text/javascript">
var pid =@pid;
var productName=""
$(function(){
$(".xianlu .item").click(function(){
$(this).addClass("blueLine");
$(this).siblings().removeClass("blueLine");
pid = $(this).attr("a-pid");
productName = $(this).attr('a-name')
$("#pName").text(productName);
$("#ProductId").val(pid);
window.location.href = "/linelist/index?ProductId="+pid;
})
$(".daochu").click(function () {
var p = $("#ProductId").val()||0;
var KeyWord = $("#KeyWord").val() || "";
window.location.href = "/linelist/Excel?ProductId=" + p + "&KeyWord=" + KeyWord;
})
})
var app = new Vue({
el: '#app',
data: {
table_data: [],
search_all_data: '',
search_product_data:'',
product_id:0,
l2tp:'',
search_field:'',
sstp:''
},
computed: {
},
watch: {
},
created: function () {
this.select_product(0);
},
methods: {
select_product(ProductId){
this.product_id = ProductId;
let datalist = [];
$("div").removeClass("blueLine");
$("#product-"+ProductId).addClass("blueLine");
switch(ProductId){
case 2:
this.l2tp = '123';
this.search_field = '讯连pptp';
this.sstp = '1500';
break;
case 4:
this.l2tp = '123456';
this.search_field = '金瑞pptp';
this.sstp = '4438';
break;
case 5:
this.l2tp = 'ipdd';
this.search_field = '老鹰pptp';
this.sstp = '4430';
break;
case 6:
this.l2tp = '123';
this.search_field = '先锋pptp';
this.sstp = '6665';
break;
case 10:
this.l2tp = '88';
this.search_field = '无限-单窗口单ip';
this.sstp = '';
break;
case 13:
this.l2tp = '123456';
this.search_field = '极客pptp';
this.sstp = '4433';
break;
case 14:
this.l2tp = '91ip';
this.search_field = '天天pptp';
this.sstp = '4430';
break;
case 15:
this.l2tp = '66';
this.search_field = '共享IP';
this.sstp = '888';
break;
case 16:
this.l2tp = '8899';
this.search_field = '实惠IP';
this.sstp = '不支持';
break;
case 1:
this.l2tp = '888888';
this.search_field = '强子pptp';
this.sstp = '1500';
break;
case 8:
this.l2tp = '88';
this.search_field = '星星pptp';
this.sstp = '6666';
break;
}
$.ajax({
type: 'GET',
url: 'http://php-api.juip.com/script/linedata/display.php?product=' + ProductId,
dataType: "json",
async:false,
success: function (res) {
datalist = res.data;
}
});
this.table_data = datalist;
},
search_all(){
$.ajax({
type: 'GET',
url: 'http://php-api.juip.com/script/linedata/search.php?type=1&info=' + this.search_all_data,
dataType: "json",
async:false,
success: function (res) {
datalist = res.data;
}
});
this.table_data = datalist;
},
search_product(){
$.ajax({
type: 'GET',
url: 'http://php-api.juip.com/script/linedata/search.php?type=0&productid='+this.product_id+'&info=' + this.search_product_data,
dataType: "json",
async:false,
success: function (res) {
datalist = res.data;
}
});
this.table_data = datalist;
},
export_data(){
switch(this.product_id){
case 0:
self.location.href='http://php-api.juip.com/script/linedata/data/download/all.csv';
break;
case 2:
self.location.href='http://php-api.juip.com/script/linedata/data/download/xunlian.csv';
break;
case 4:
self.location.href='http://php-api.juip.com/script/linedata/data/download/jinrui.csv';
break;
case 5:
self.location.href='http://php-api.juip.com/script/linedata/data/download/laoying.csv';
break;
case 6:
self.location.href='http://php-api.juip.com/script/linedata/data/download/xianfeng.csv';
break;
case 10:
self.location.href='http://php-api.juip.com/script/linedata/data/download/wuxian.csv';
break;
case 13:
self.location.href='http://php-api.juip.com/script/linedata/data/download/jike.csv';
break;
case 14:
self.location.href='http://php-api.juip.com/script/linedata/data/download/tiantian.csv';
break;
case 15:
self.location.href='http://php-api.juip.com/script/linedata/data/download/gongxiang.csv';
break;
case 16:
self.location.href='http://php-api.juip.com/script/linedata/data/download/shihui.csv';
break;
case 1:
self.location.href='http://php-api.juip.com/script/linedata/data/download/qiangzi.csv';
break;
case 8:
self.location.href='http://php-api.juip.com/script/linedata/data/download/xingxing.csv';
break;
}
}
}
})
</script>