Newer
Older
function render_host_link(data) {
// render funtion to create link to Host view page
if ( data === null ) {
return data;
}
var url = $SCRIPT_ROOT + "/network/hosts/view/" + data;
return '<a href="'+ url + '">' + data + '</a>';
}
function render_network_link(data) {
// render funtion to create link to Network view page
if ( data === null ) {
return data;
}
var url = $SCRIPT_ROOT + "/network/networks/view/" + data;
return '<a href="'+ url + '">' + data + '</a>';
}
if( $("#hostForm").length || $("#editHostForm").length ) {
var hostVarsEditor = CodeMirror.fromTextArea(ansible_vars, {
lineNumbers: true,
mode: "yaml"
});
hostVarsEditor.setSize(null, 120);
var handle = cmResize(hostVarsEditor, {
minHeight: 120,
resizableWidth: false,
resizableHeight: true,
});
function set_default_ip() {
// Retrieve the first available IP for the selected network
// and update the IP field
var network_id = $("#network_id").val();
$("#ip").removeClass("is-invalid");
$.getJSON(
$SCRIPT_ROOT + "/network/_retrieve_first_available_ip/" + network_id,
function(json) {
$("#ip").val(json.data);
}
);
}
// And check / uncheck random_mac checkbox
function update_device_type_attributes() {
var device_type = $("#device_type_id option:selected").text();
if( device_type.startsWith("Virtual") ) {
$("#random_mac").prop("checked", true).change();
} else {
$("#random_mac").prop("checked", false).change();
// If random_mac is checked, generate a random address
// Empty the field otherwise
function fill_mac_address() {
if( $("#random_mac").prop("checked") ) {
$.getJSON(
$SCRIPT_ROOT + "/network/_generate_random_mac",
function(json) {
$("#mac").val(json.data.mac);
$("#mac").prop("readonly", true);
$("#mac").val("");
$("#mac").prop("readonly", false);
// Set the default IP on first page load for:
// - register new host
// - add interface
// Do NOT replace the IP on edit interface page load!
// (we have to keep the existing IP)
// Do NOT replace the IP if the form was submitted and an error was raised
// (we should display the same value that was submitted)
if( ($("#hostForm").length || $("#interfaceForm").length) && ! $("input").hasClass("is-invalid") ) {
// On page load if the network_id is invalid, it's because an empty entry was submitted
// remove the default value to make it clear
if( ($("#hostForm").length || $("#interfaceForm").length) && $("#network_id").hasClass("is-invalid") ) {
var network_id_selectize = $("#network_id")[0].selectize;
network_id_selectize.clear(true);
}
// Clear the default value so that the user can start typing directly
// or click a dropdown item
$("#network_id").next(".selectize-control").on( 'click', function () {
var network_id_selectize = $("#network_id")[0].selectize;
network_id_selectize.clear(true);
});
// Set the default IP when changing network
$("#network_id").on('change', function() {
$(this).removeClass("is-invalid");
$(this).next(".selectize-control").removeClass("is-invalid");
// Only for register new host form
if( $("#hostForm").length ) {
// And change
$("#device_type_id").on('change', function() {
update_device_type_attributes();
});
}
// Fill MAC address on page load
if( $("#random_mac").length ) {
fill_mac_address();
}
// Fill or clear MAC address depending on random_mac checkbox
$("#random_mac").on('change', function() {
fill_mac_address();
});
var hosts_table = $("#hosts_table").DataTable({
dom: "<'row'<'col-sm-12 col-md-6'l><'col-sm-12 col-md-3 text-right'><'col-sm-12 col-md-3'f>>" +
"<'row'<'col-sm-12'tr>>" +
"<'row'<'col-sm-12 col-md-5'i><'col-sm-12 col-md-7'p>>",
"ajax": {
"url": $SCRIPT_ROOT + "/network/_retrieve_hosts",
"type": "POST"
"processing": true,
"serverSide": true,
"searchDelay": 500,
"orderMulti": false,
"aaSorting": [],
"pagingType": "full_numbers",
"pageLength": 20,
"lengthMenu": [[20, 50, 100], [20, 50, 100]],
"columns": [
{ data: 'name',
render: function(data, type, row) {
return render_host_link(data);
},
{ data: 'device_type' },
{ data: 'description',
orderable: false },
{ data: 'interfaces.0.ip',
defaultContent: "",
orderable: false },
{ data: 'interfaces.0.network',
render: function(data, type, row) {
return render_network_link(data);
},
defaultContent: "",
orderable: false }
if( $("#hosts_table").length ) {
new $.fn.dataTable.Buttons(hosts_table, {
buttons: [
{
text: 'Reset',
className: "btn-outline-secondary",
action: function ( e, dt, node, conf ) {
dt.state.clear();
dt.search('').order([]).draw();
}
}
]
});
hosts_table.buttons().container().appendTo("#hosts_table_wrapper .col-md-3:eq(0)");
}