186 lines
8.4 KiB
Plaintext
186 lines
8.4 KiB
Plaintext
<!-- page content -->
|
|
<div class="right_col" role="main">
|
|
|
|
<div class="page-title">
|
|
<div class="title_left"><h3>Peer</h3></div>
|
|
<div class="title_right">
|
|
</div>
|
|
</div>
|
|
|
|
<div class="clearfix"></div>
|
|
<div class="row">
|
|
<div class="col-md-12 col-sm-12 col-xs-12">
|
|
<div class="x_panel">
|
|
<div class="x_title">
|
|
<h2>Add Node</h2>
|
|
<ul class="nav navbar-right panel_toolbox">
|
|
<li><a class="collapse-link"><i class="fa fa-chevron-up"></i></a>
|
|
</li>
|
|
<li class="dropdown">
|
|
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"><i class="fa fa-wrench"></i></a>
|
|
<ul class="dropdown-menu" role="menu">
|
|
<li><a href="#">Settings 1</a>
|
|
</li>
|
|
<li><a href="#">Settings 2</a>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
<li><a class="close-link"><i class="fa fa-close"></i></a>
|
|
</li>
|
|
</ul>
|
|
<div class="clearfix"></div>
|
|
</div>
|
|
<div class="x_content">
|
|
|
|
<form class="form-horizontal form-label-left" action="/node/add" method="post" novalidate>
|
|
<span class="section">Node Info</span>
|
|
|
|
<div class="item form-group">
|
|
<label class="control-label col-md-3 col-sm-3 col-xs-12" for="name">Host Name <span class="required">*</span>
|
|
</label>
|
|
<div class="col-md-6 col-sm-6 col-xs-12">
|
|
<input id="name" class="form-control col-md-7 col-xs-12" data-validate-length-range="10" data-validate-words="1" name="host_name" placeholder="Host Name" required="required" type="text">
|
|
</div>
|
|
</div>
|
|
|
|
<div class="item form-group">
|
|
<label class="control-label col-md-3 col-sm-3 col-xs-12" for="ip">Host IP <span class="required">*</span>
|
|
</label>
|
|
<div class="col-md-6 col-sm-6 col-xs-12">
|
|
<input id="ip" class="form-control col-md-7 col-xs-12" data-validate-length-range="10" data-validate-words="1" name="host_ip" placeholder="127.0.0.1" required="required" type="text">
|
|
</div>
|
|
</div>
|
|
|
|
<div class="item form-group">
|
|
<label class="control-label col-md-3 col-sm-3 col-xs-12" for="number">Host Port <span class="required">*</span>
|
|
</label>
|
|
<div class="col-md-6 col-sm-6 col-xs-12">
|
|
<input type="number" id="number" name="host_port" required="required" data-validate-length-range="4" data-validate-minmax="0,9999" placeholder="0~9999" class="form-control col-md-7 col-xs-12">
|
|
</div>
|
|
</div>
|
|
|
|
<div class="item form-group">
|
|
<label class="control-label col-md-3 col-sm-3 col-xs-12" for="name">User Name <span class="required">*</span>
|
|
</label>
|
|
<div class="col-md-6 col-sm-6 col-xs-12">
|
|
<input id="occupation" type="text" name="user_name" required="required" data-validate-length-range="5,20" class="form-control col-md-7 col-xs-12">
|
|
</div>
|
|
</div>
|
|
<div class="item form-group">
|
|
<label for="password" class="control-label col-md-3">User Password <span class="required">*</span></label>
|
|
<div class="col-md-6 col-sm-6 col-xs-12">
|
|
<input id="password" type="password" name="user_password" data-validate-length="1,10" class="form-control col-md-7 col-xs-12" required="required">
|
|
</div>
|
|
</div>
|
|
<div class="ln_solid"></div>
|
|
<div class="form-group">
|
|
<div class="col-md-6 col-md-offset-3">
|
|
<button type="submit" class="btn btn-primary">Cancel</button>
|
|
<button id="send" type="submit" class="btn btn-success">Add</button>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row">
|
|
<div class="col-md-12 col-sm-12 col-xs-12">
|
|
<div class="x_panel">
|
|
<div class="x_title">
|
|
<h2>Node List <small>Try hovering over the rows</small></h2>
|
|
<ul class="nav navbar-right panel_toolbox">
|
|
<li><a class="collapse-link"><i class="fa fa-chevron-up"></i></a>
|
|
</li>
|
|
<li class="dropdown">
|
|
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"><i class="fa fa-wrench"></i></a>
|
|
<ul class="dropdown-menu" role="menu">
|
|
<li><a href="#">Settings 1</a>
|
|
</li>
|
|
<li><a href="#">Settings 2</a>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
<li><a class="close-link"><i class="fa fa-close"></i></a>
|
|
</li>
|
|
</ul>
|
|
<div class="clearfix"></div>
|
|
</div>
|
|
<div class="x_content">
|
|
<table class="table table-hover">
|
|
<thead>
|
|
<tr>
|
|
<th>#</th>
|
|
<th>Host Name</th>
|
|
<th>Host IP</th>
|
|
<th>Host Port</th>
|
|
<th>User Name</th>
|
|
<th>User Password</th>
|
|
<th>Date</th>
|
|
<th></th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<%@nodes.each do |t|%>
|
|
<tr>
|
|
<th scope="row"><%=t.id%></th>
|
|
<td><%=t.host_name%></td>
|
|
<td><%=t.host_ip%></td>
|
|
<td><%=t.host_port%></td>
|
|
<td><%=t.user_name%></td>
|
|
<td><%=t.user_password%></td>
|
|
<td><%=t.created_at%></td>
|
|
<td><a href="/node/delete/<%=t.id%>"><i class="fa fa-trash"></i></a></td>
|
|
</tr>
|
|
<%end%>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- /page content -->
|
|
<script>
|
|
// initialize the validator function
|
|
validator.message['date'] = 'not a real date';
|
|
|
|
// validate a field on "blur" event, a 'select' on 'change' event & a '.reuired' classed multifield on 'keyup':
|
|
$('form')
|
|
.on('blur', 'input[required], input.optional, select.required', validator.checkField)
|
|
.on('change', 'select.required', validator.checkField)
|
|
.on('keypress', 'input[required][pattern]', validator.keypress);
|
|
|
|
$('.multi.required')
|
|
.on('keyup blur', 'input', function() {
|
|
validator.checkField.apply($(this).siblings().last()[0]);
|
|
});
|
|
|
|
// bind the validation to the form submit event
|
|
//$('#send').click('submit');//.prop('disabled', true);
|
|
|
|
$('form').submit(function(e) {
|
|
e.preventDefault();
|
|
var submit = true;
|
|
// evaluate the form using generic validaing
|
|
if (!validator.checkAll($(this))) {
|
|
submit = false;
|
|
}
|
|
|
|
if (submit)
|
|
this.submit();
|
|
return false;
|
|
});
|
|
|
|
/* FOR DEMO ONLY */
|
|
$('#vfields').change(function() {
|
|
$('form').toggleClass('mode2');
|
|
}).prop('checked', false);
|
|
|
|
$('#alerts').change(function() {
|
|
validator.defaults.alerts = (this.checked) ? false : true;
|
|
if (this.checked)
|
|
$('form .alert').remove();
|
|
}).prop('checked', false);
|
|
</script> |