mirror of
https://github.com/netcccyun/dnsmgr.git
synced 2026-02-21 15:31:12 +08:00
157 lines
5.2 KiB
HTML
157 lines
5.2 KiB
HTML
{extend name="common/layout" /}
|
|
{block name="title"}批量修改解析{/block}
|
|
{block name="main"}
|
|
<style>
|
|
tbody tr>td:nth-child(3){min-width:300px;word-break:break-all;}
|
|
</style>
|
|
<div class="row" id="app">
|
|
<div class="col-xs-12 center-block" style="float: none;">
|
|
<div class="panel panel-default">
|
|
<div class="panel-heading"><h3 class="panel-title"><a href="/domain" class="btn btn-sm btn-default pull-right" style="margin-top:-6px"><i class="fa fa-reply fa-fw"></i> 返回</a>批量修改解析</h3></div>
|
|
<div class="panel-body">
|
|
<form onsubmit="return false" method="post" class="form-horizontal" role="form" id="form-store">
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label no-padding-right">主机记录</label>
|
|
<div class="col-sm-6">
|
|
<input type="text" class="form-control" name="name" v-model="set.name" placeholder="填写已有的主机记录" required>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label no-padding-right">记录类型</label>
|
|
<div class="col-sm-6">
|
|
<select name="type" class="form-control" v-model="set.type">
|
|
<option value="A">A</option>
|
|
<option value="CNAME">CNAME</option>
|
|
<option value="AAAA">AAAA</option>
|
|
<option value="NS">NS</option>
|
|
<option value="MX">MX</option>
|
|
<option value="SRV">SRV</option>
|
|
<option value="TXT">TXT</option>
|
|
<option value="CAA">CAA</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label no-padding-right">线路类型</label>
|
|
<div class="col-sm-6">
|
|
<select name="line" class="form-control" disabled><option value="default">默认</option></select>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label no-padding-right">记录值</label>
|
|
<div class="col-sm-6">
|
|
<input type="text" class="form-control" name="value" v-model="set.value" placeholder="输入新的记录值" required>
|
|
</div>
|
|
</div>
|
|
<div class="form-group" style="display:none" id="mx_type">
|
|
<label class="col-sm-3 control-label no-padding-right">MX优先级</label>
|
|
<div class="col-sm-6">
|
|
<input type="text" class="form-control" name="mx" v-model="set.mx" placeholder="留空则不修改">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label no-padding-right">TTL</label>
|
|
<div class="col-sm-6">
|
|
<input type="text" class="form-control" name="ttl" v-model="set.ttl" placeholder="留空则不修改">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<div class="col-sm-offset-3 col-sm-6"><button type="button" class="btn btn-primary" @click="submit">确定修改</button></div>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
<div class="panel panel-default">
|
|
<div class="panel-heading"><h3 class="panel-title">解析记录修改结果</h3></div>
|
|
<div class="panel-body">
|
|
<table class="table table-striped table-hover table-bordered">
|
|
<thead>
|
|
<tr>
|
|
<th>ID</th>
|
|
<th>域名</th>
|
|
<th>修改结果</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr v-for="item in domainList">
|
|
<td>{{item.id}}</td>
|
|
<td><img :src="'/static/images/'+item.type+'.ico'" class="type-logo"></img><a :href="'/record/'+item.id" target="_blank">{{item.name}}</a></td>
|
|
<td v-html="item.result"></td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
{/block}
|
|
{block name="script"}
|
|
<script src="/static/js/vue-2.7.16.min.js"></script>
|
|
<script src="/static/js/layer/layer.js"></script>
|
|
<script>
|
|
new Vue({
|
|
el: '#app',
|
|
data: {
|
|
domainList: [],
|
|
set: {
|
|
id: '',
|
|
name: '',
|
|
type: 'A',
|
|
value: '',
|
|
mx: '',
|
|
ttl: '',
|
|
}
|
|
},
|
|
mounted() {
|
|
this.domainList = JSON.parse(sessionStorage.getItem('domains')) || [];
|
|
if(this.domainList.length == 0){
|
|
layer.alert('请先选中要修改解析的域名', {icon: 2}, function(){
|
|
window.location.href = '/domain';
|
|
});
|
|
}
|
|
for(var i=0; i<this.domainList.length; i++){
|
|
this.$set(this.domainList[i], 'result', '<span class="text-muted">待修改</span>');
|
|
}
|
|
},
|
|
methods: {
|
|
async save(id){
|
|
var that = this;
|
|
return new Promise((resolve, reject) => {
|
|
that.set.id = id;
|
|
$.ajax({
|
|
type: "POST",
|
|
url: '/record/batchedit',
|
|
data: that.set,
|
|
dataType: 'json',
|
|
success: function(data) {
|
|
resolve(data);
|
|
},
|
|
error: function() {
|
|
reject('服务器错误');
|
|
}
|
|
});
|
|
});
|
|
},
|
|
async submit(){
|
|
if(this.set.name == ''){
|
|
layer.alert('请填写主机记录', {icon: 2});
|
|
return;
|
|
}
|
|
if(this.set.value == ''){
|
|
layer.alert('请填写记录值', {icon: 2});
|
|
return;
|
|
}
|
|
var ii = layer.load(2);
|
|
for(var i=0; i<this.domainList.length; i++){
|
|
this.domainList[i].result = '<span class="text-yellow"><i class="fa fa-refresh fa-spin fa-fw"></i> 正在修改</span>';
|
|
var res = await this.save(this.domainList[i].id);
|
|
if(res.code == 0){
|
|
this.domainList[i].result = '<span class="text-green">'+res.msg+'</span>';
|
|
}else{
|
|
this.domainList[i].result = '<span class="text-red">'+res.msg+'</span>';
|
|
}
|
|
}
|
|
layer.close(ii);
|
|
}
|
|
},
|
|
});
|
|
</script>
|
|
{/block} |