829 lines
23 KiB
HTML
829 lines
23 KiB
HTML
<%+header%>
|
||
<script type="text/javascript" src="<%=resource%>/xhr.js"></script>
|
||
<script type="text/javascript">//<![CDATA[
|
||
|
||
window.onload=function()
|
||
{
|
||
//获取模组选择框元素
|
||
var modem_select = document.getElementById('modem_select');
|
||
|
||
//更换模组(AT串口)时触发
|
||
modem_select.addEventListener('change', function() {
|
||
//获取快捷命令
|
||
get_quick_commands();
|
||
});
|
||
|
||
//获取快捷选项父元素
|
||
var quick_option_element = document.getElementById('quick_option_td');
|
||
//更换快捷选项时触发
|
||
quick_option_element.addEventListener('change', function(event) {
|
||
var target = event.target;
|
||
if (target.matches('input[type="radio"]')) {
|
||
//获取快捷命令
|
||
get_quick_commands();
|
||
}
|
||
});
|
||
|
||
//获取网络偏好选项元素
|
||
var prefer_option_auto = document.getElementById('prefer_option_auto');
|
||
var prefer_option_custom = document.getElementById('prefer_option_custom');
|
||
//网络偏好选项为自动时触发
|
||
prefer_option_auto.addEventListener('change', function() {
|
||
if (prefer_option_auto.checked)
|
||
{
|
||
//禁用偏好复选框
|
||
disabled_prefer_custom_config(true);
|
||
//全选偏好复选框
|
||
all_choose_prefer_custom_config(true);
|
||
}
|
||
});
|
||
//网络偏好选项为自定义时触发
|
||
prefer_option_custom.addEventListener('change', function() {
|
||
if (prefer_option_custom.checked)
|
||
{
|
||
//禁用偏好复选框
|
||
disabled_prefer_custom_config(false);
|
||
}
|
||
});
|
||
}
|
||
|
||
// 发送AT命令
|
||
function send(at_port,at_command)
|
||
{
|
||
XHR.get('<%=luci.dispatcher.build_url("admin", "network", "modem", "send_at_command")%>', {"port":at_port,"command":at_command},
|
||
function(x, data)
|
||
{
|
||
responseElement=document.getElementById("response");
|
||
if ("response" in data) {
|
||
//显示当前时间
|
||
responseElement.value+=data["time"];
|
||
//显示返回值
|
||
responseElement.value+=data["response"];
|
||
//滚动到底部
|
||
responseElement.scrollTop = responseElement.scrollHeight;
|
||
}
|
||
}
|
||
);
|
||
}
|
||
|
||
// 发送AT命令前处理
|
||
function send_at_command(event)
|
||
{
|
||
//获取选中的模组(选中的AT串口)
|
||
var at_port = document.getElementById("modem_select").value;
|
||
if ( at_port.length == 0 )
|
||
{
|
||
alert("<%:Please choose a Modem%>");
|
||
return false;
|
||
}
|
||
|
||
//获取AT命令
|
||
var at_command = document.getElementById("at_command").value;
|
||
if ( at_command.length == 0 )
|
||
{
|
||
alert("<%:Please enter a AT Command%>");
|
||
return false;
|
||
}
|
||
|
||
//对双引号进行特殊处理
|
||
at_command=at_command.replaceAll("\"","\\\"");
|
||
|
||
//发送AT命令
|
||
send(at_port,at_command);
|
||
return true;
|
||
}
|
||
|
||
// 清除AT命令
|
||
function clean_at_command(event)
|
||
{
|
||
document.getElementById("at_command").value='';
|
||
}
|
||
|
||
// 清除AT响应
|
||
function clean_response(event)
|
||
{
|
||
document.getElementById("response").value='';
|
||
}
|
||
|
||
// 设置AT串口选项
|
||
function set_at_port(port)
|
||
{
|
||
// 获取模组选择框元素
|
||
var modem_select = document.getElementById('modem_select');
|
||
// 记录所选
|
||
var selected=modem_select.value;
|
||
// 删除原来的选项
|
||
modem_select.options.length=0;
|
||
// 更新(key:AT串口,value:模组名称)
|
||
for (var key in port)
|
||
{
|
||
var option = document.createElement('option');
|
||
option.value = key;
|
||
if (port[key].includes("unknown"))
|
||
{
|
||
option.text = port[key].replace("unknown", key);
|
||
}
|
||
else
|
||
{
|
||
option.text = port[key];
|
||
}
|
||
modem_select.appendChild(option);
|
||
}
|
||
// 恢复原来的选择
|
||
for (let i = 0; i < modem_select.options.length; i++)
|
||
{
|
||
if(modem_select.options[i].value == selected)
|
||
{
|
||
modem_select.selectedIndex=i;
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
|
||
// 自动填写到命令输入框
|
||
function copy_to_input()
|
||
{
|
||
var command_select = document.getElementById("command_select").value;
|
||
document.getElementById("at_command").value = command_select;
|
||
}
|
||
|
||
// 无模组界面
|
||
function no_modems_view()
|
||
{
|
||
//更新提示信息
|
||
document.getElementById("info_message").innerHTML="<strong><%:No modems found%></strong>";
|
||
//显示提示信息
|
||
document.getElementById("cbi-info").style.display="block";
|
||
//隐藏模组选择界面
|
||
document.getElementById("cbi-modem").style.display="none";
|
||
//隐藏拨号模式界面
|
||
document.getElementById("cbi-mode").style.display="none";
|
||
//隐藏网络偏好界面
|
||
document.getElementById("cbi-network-prefer").style.display="none";
|
||
//隐藏AT界面
|
||
document.getElementById("cbi-at").style.display="none";
|
||
}
|
||
|
||
// 有模组界面
|
||
function modems_view()
|
||
{
|
||
//显示模组选择界面
|
||
document.getElementById("cbi-modem").style.display="block";
|
||
//显示AT命令界面
|
||
document.getElementById("cbi-at").style.display="block";
|
||
//隐藏提示信息
|
||
// document.getElementById("cbi-info").style.display="none";
|
||
}
|
||
|
||
// 未适配模组界面
|
||
function not_adapted_modems_view()
|
||
{
|
||
// 更新提示信息
|
||
document.getElementById("info_message").innerHTML="<strong><%:Not adapted to this modem%></strong>";
|
||
// 显示提示信息
|
||
document.getElementById("cbi-info").style.display="block";
|
||
//隐藏拨号模式界面
|
||
document.getElementById("cbi-mode").style.display="none";
|
||
//隐藏网络偏好界面
|
||
document.getElementById("cbi-network-prefer").style.display="none";
|
||
}
|
||
|
||
// 全功能界面
|
||
function all_function_view()
|
||
{
|
||
//显示拨号模式界面
|
||
document.getElementById("cbi-mode").style.display="block";
|
||
//显示网络偏好界面
|
||
document.getElementById("cbi-network-prefer").style.display="block";
|
||
//隐藏提示信息
|
||
document.getElementById("cbi-info").style.display="none";
|
||
}
|
||
|
||
|
||
// 更新选项
|
||
function update_option(select_element,data,order)
|
||
{
|
||
//记录所选
|
||
var selected=select_element.value;
|
||
//删除原来的选项
|
||
select_element.options.length=0;
|
||
|
||
//是否有顺序
|
||
if (order)
|
||
{
|
||
//遍历每一条信息
|
||
for (var info of data)
|
||
{
|
||
//遍历每一条信息里的键
|
||
for (var key in info)
|
||
{
|
||
var option = document.createElement('option');
|
||
option.text = key;
|
||
option.value = info[key];
|
||
select_element.appendChild(option);
|
||
}
|
||
}
|
||
}
|
||
else
|
||
{
|
||
//遍历每一条信息里的键
|
||
for (var key of data)
|
||
{
|
||
var option = document.createElement('option');
|
||
option.text = key;
|
||
option.value = info[key];
|
||
select_element.appendChild(option);
|
||
}
|
||
}
|
||
|
||
//恢复原来的选择
|
||
for (let i = 0; i < select_element.options.length; i++)
|
||
{
|
||
if(select_element.options[i].value == selected)
|
||
{
|
||
select_element.selectedIndex=i;
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
|
||
// 获取快捷命令
|
||
function get_quick_commands()
|
||
{
|
||
//获取快捷选项
|
||
var quick_option = document.querySelector('input[name="quick_option"]:checked').value;
|
||
//获取选中的模组
|
||
var at_port = document.getElementById("modem_select").value;
|
||
|
||
//获取AT命令
|
||
XHR.get('<%=luci.dispatcher.build_url("admin", "network", "modem", "get_quick_commands")%>', {"option":quick_option,"port":at_port},
|
||
function(x, data)
|
||
{
|
||
//获取模组选择框元素
|
||
var command_select = document.getElementById('command_select');
|
||
//更新选项
|
||
update_option(command_select,data["quick_commands"],true);
|
||
|
||
//显示有模组界面
|
||
modems_view();
|
||
}
|
||
);
|
||
}
|
||
|
||
// 全选网络偏好复选框
|
||
function all_choose_prefer_custom_config(status)
|
||
{
|
||
var checkboxes=document.getElementById('prefer_custom_config').querySelectorAll('input[type="checkbox"]');
|
||
for(checkbox of checkboxes)
|
||
{
|
||
//设置网络偏好复选框状态
|
||
checkbox.checked=status;
|
||
}
|
||
}
|
||
|
||
// 禁用网络偏好复选框
|
||
function disabled_prefer_custom_config(status)
|
||
{
|
||
var checkboxes=document.getElementById('prefer_custom_config').querySelectorAll('input[type="checkbox"]');
|
||
for(checkbox of checkboxes)
|
||
{
|
||
//禁用
|
||
checkbox.disabled=status;
|
||
}
|
||
}
|
||
|
||
// 禁用功能
|
||
function disabled_function(function_name,status)
|
||
{
|
||
//拨号模式
|
||
if (function_name=="mode")
|
||
{
|
||
//模式选项
|
||
document.getElementById('mode_option_qmi').disabled=status;
|
||
document.getElementById('mode_option_ecm').disabled=status;
|
||
document.getElementById('mode_option_mbim').disabled=status;
|
||
document.getElementById('mode_option_rndis').disabled=status;
|
||
document.getElementById('mode_option_ncm').disabled=status;
|
||
|
||
//模式按钮
|
||
document.getElementById('mode_button').disabled=status;
|
||
}
|
||
//网络偏好
|
||
else if (function_name=="network_prefer")
|
||
{
|
||
//偏好选项
|
||
document.getElementById('prefer_option_auto').disabled=status;
|
||
document.getElementById('prefer_option_custom').disabled=status;
|
||
|
||
//网络偏好为自动则不启用
|
||
var prefer_option_auto = document.getElementById('prefer_option_auto');
|
||
if (!prefer_option_auto.checked)
|
||
{
|
||
//偏好复选框
|
||
disabled_prefer_custom_config(status);
|
||
}
|
||
|
||
//偏好按钮
|
||
document.getElementById('network_prefer_button').disabled=status;
|
||
}
|
||
}
|
||
|
||
// 设置拨号模式信息
|
||
function set_mode_info(mode_info)
|
||
{
|
||
//获取当前拨号模式
|
||
var current_mode=mode_info["mode"];
|
||
//获取支持的拨号模式
|
||
var modes=mode_info["modes"];
|
||
|
||
//获取模式视图
|
||
var current_mode_view=current_mode.toUpperCase();
|
||
|
||
//设置当前拨号模式
|
||
document.getElementById('current_mode').innerHTML=current_mode_view;
|
||
|
||
var first_element=document.getElementById('first-checked');
|
||
if (first_element.value=="true")
|
||
{
|
||
//设置支持的拨号模式
|
||
var mode_option_view='';
|
||
for(mode of modes)
|
||
{
|
||
if (mode=="gobinet")
|
||
{
|
||
mode_option_view=mode_option_view.replace("QMI","QMI/GobiNet");
|
||
}
|
||
else
|
||
{
|
||
mode_option_view+='<span class="cbi-radio"><input type="radio" name="mode_option" id="mode_option_'+mode+'" value="'+mode+'"><span>'+mode.toUpperCase()+'</span></span> ';
|
||
}
|
||
}
|
||
document.getElementById('mode_option').innerHTML=mode_option_view;
|
||
|
||
//设置拨号模式选项
|
||
document.getElementById('mode_option_'+current_mode).checked=true;
|
||
}
|
||
}
|
||
|
||
// 设置拨号模式
|
||
function set_mode()
|
||
{
|
||
//禁用功能
|
||
disabled_function("mode",true);
|
||
|
||
//获取模式选项
|
||
var mode_config = document.querySelector('input[name="mode_option"]:checked').value;
|
||
//获取选中的模组
|
||
var at_port = document.getElementById("modem_select").value;
|
||
|
||
//设置偏好
|
||
XHR.get('<%=luci.dispatcher.build_url("admin", "network", "modem", "set_mode")%>', {"port":at_port,"mode_config":mode_config},
|
||
function(x, data)
|
||
{
|
||
console.log(data);
|
||
|
||
//获取模组拨号模式
|
||
var current_mode=data;
|
||
|
||
//获取模式视图
|
||
var current_mode_view=current_mode.toUpperCase();
|
||
|
||
//设置当前拨号模式
|
||
document.getElementById('current_mode').innerHTML=current_mode_view;
|
||
|
||
//启用功能
|
||
disabled_function("mode",false);
|
||
}
|
||
);
|
||
}
|
||
|
||
// 获取当前网络视图
|
||
function get_current_prefer_view(network_prefer)
|
||
{
|
||
var current_prefer_view="";
|
||
|
||
//自动状态判断(全部选中为自动)
|
||
if (network_prefer["3G"]&&network_prefer["4G"]&&network_prefer["5G"])
|
||
{
|
||
//更新当前偏好
|
||
current_prefer_view="AUTO";
|
||
}
|
||
else
|
||
{
|
||
//更新当前偏好
|
||
for(key in network_prefer)
|
||
{
|
||
if (network_prefer[key]) {
|
||
current_prefer_view+=key+" ";
|
||
}
|
||
}
|
||
}
|
||
|
||
return current_prefer_view;
|
||
}
|
||
|
||
// 设置网络偏好信息
|
||
function set_network_prefer_info(network_prefer_info)
|
||
{
|
||
//获取模组网络偏好
|
||
var network_prefer=network_prefer_info["network_prefer"];
|
||
|
||
//获取偏好视图
|
||
var current_prefer_view=get_current_prefer_view(network_prefer);
|
||
|
||
//设置当前网络偏好
|
||
document.getElementById('current_prefer').innerHTML=current_prefer_view;
|
||
|
||
//设置偏好选项和复选框
|
||
var first_element=document.getElementById('first-checked');
|
||
if (first_element.value=="true")
|
||
{
|
||
if (network_prefer["3G"]&&network_prefer["4G"]&&network_prefer["5G"])
|
||
{
|
||
//设置偏好选项
|
||
document.getElementById('prefer_option_auto').checked=true;
|
||
//更新偏好配置
|
||
all_choose_prefer_custom_config(true);
|
||
//禁用用偏好复选框
|
||
disabled_prefer_custom_config(true);
|
||
}
|
||
else
|
||
{
|
||
//设置偏好选项
|
||
document.getElementById('prefer_option_custom').checked=true;
|
||
//更新偏好配置
|
||
for (key in network_prefer)
|
||
{
|
||
//设置偏好配置
|
||
var prefer_config_element=document.getElementById('prefer_config_'+key.toLowerCase());
|
||
if (prefer_config_element!=null) {
|
||
prefer_config_element.checked=network_prefer[key];
|
||
}
|
||
}
|
||
//启用偏好复选框
|
||
disabled_prefer_custom_config(false);
|
||
}
|
||
}
|
||
}
|
||
|
||
// 设置网络偏好
|
||
function set_network_prefer()
|
||
{
|
||
//禁用功能
|
||
disabled_function("network_prefer",true);
|
||
|
||
//获取偏好选项
|
||
var prefer_option = document.querySelector('input[name="prefer_option"]:checked').value;
|
||
//获取选中的模组
|
||
var at_port = document.getElementById("modem_select").value;
|
||
|
||
//获取偏好配置
|
||
var network_prefer_config={};
|
||
if (prefer_option=="auto")
|
||
{
|
||
network_prefer_config["3G"]=1;
|
||
network_prefer_config["4G"]=1;
|
||
network_prefer_config["5G"]=1;
|
||
}
|
||
else
|
||
{
|
||
var checkboxes=document.getElementById('prefer_custom_config').querySelectorAll('input[type="checkbox"]');
|
||
for(checkbox of checkboxes)
|
||
{
|
||
network_prefer_config[checkbox.value.toUpperCase()]=Number(checkbox.checked);
|
||
}
|
||
}
|
||
|
||
//设置偏好
|
||
XHR.get('<%=luci.dispatcher.build_url("admin", "network", "modem", "set_network_prefer")%>', {"port":at_port,"prefer_config":network_prefer_config},
|
||
function(x, data)
|
||
{
|
||
//获取模组网络偏好
|
||
var network_prefer=data["network_prefer"];
|
||
|
||
//获取当前偏好视图
|
||
var current_prefer_view=get_current_prefer_view(network_prefer);
|
||
|
||
//设置模组当前网络偏好
|
||
document.getElementById('current_prefer').innerHTML=current_prefer_view;
|
||
|
||
//启用功能
|
||
disabled_function("network_prefer",false);
|
||
}
|
||
);
|
||
}
|
||
|
||
// 获取模组调试信息
|
||
function get_modem_debug_info(params)
|
||
{
|
||
//获取选中的模组
|
||
var at_port = document.getElementById("modem_select").value;
|
||
|
||
//获取调试信息
|
||
XHR.get('<%=luci.dispatcher.build_url("admin", "network", "modem", "get_modem_debug_info")%>', {"port":at_port},
|
||
function(x, data)
|
||
{
|
||
|
||
var mode_info=data["mode_info"];
|
||
var network_prefer_info=data["network_prefer_info"];
|
||
if (Object.keys(mode_info).length==0||Object.keys(network_prefer_info).length==0) {
|
||
//显示未适配模组界面
|
||
not_adapted_modems_view();
|
||
return false
|
||
}
|
||
|
||
//设置模式信息
|
||
set_mode_info(mode_info);
|
||
|
||
//设置网络偏好信息
|
||
set_network_prefer_info(network_prefer_info);
|
||
|
||
//设置第一次获取数据标志
|
||
document.getElementById('first-checked').value=false;
|
||
|
||
//显示全功能界面
|
||
all_function_view();
|
||
}
|
||
);
|
||
}
|
||
|
||
// 定时触发更新AT串口
|
||
XHR.poll(5,'<%=luci.dispatcher.build_url("admin", "network", "modem", "get_at_port")%>', null,
|
||
function(x, port)
|
||
{
|
||
//设置AT串口选项
|
||
set_at_port(port);
|
||
|
||
//获取快捷命令
|
||
if (Object.keys(port).length==0)
|
||
{
|
||
//显示无模组界面
|
||
no_modems_view();
|
||
}
|
||
else
|
||
{
|
||
//获取快捷选项
|
||
var quick_option = document.querySelector('input[name="quick_option"]:checked').value;
|
||
if (quick_option=="auto") {
|
||
get_quick_commands();
|
||
}
|
||
//获取模组调试信息
|
||
get_modem_debug_info();
|
||
}
|
||
}
|
||
);
|
||
|
||
//]]>
|
||
</script>
|
||
|
||
<div class="cbi-map" id="cbi-modem-debug">
|
||
<h2 id="content" name="content"><%:Modem Debug%></h2>
|
||
<div class="cbi-map-descr"><%:Debug Your Module%></div>
|
||
<head>
|
||
<style type="text/css">
|
||
/* table {
|
||
width: 100%;
|
||
border-spacing: 10px;
|
||
border: 0px;
|
||
} */
|
||
|
||
tr td:first-child {
|
||
width: 33%;
|
||
}
|
||
|
||
/* AT命令响应 */
|
||
/* #response_label {
|
||
font-size: 15px;
|
||
} */
|
||
|
||
/* 网络偏好第一次复选框 */
|
||
[name="first-checked"] {
|
||
display: none;
|
||
}
|
||
|
||
/* 终端 */
|
||
textarea {
|
||
background:#373737;
|
||
border:none;
|
||
color:#FFF;
|
||
width: 100%;
|
||
}
|
||
|
||
#popup {
|
||
width:560px;
|
||
height:190px;
|
||
padding:20px;
|
||
background-color:gainsboro;
|
||
border-style : solid;
|
||
position:fixed;
|
||
top : 40%;
|
||
margin-left: auto;
|
||
margin-right: auto;
|
||
left: 0;
|
||
right: 0;
|
||
text-align: center;
|
||
display:none;
|
||
}
|
||
</style>
|
||
</head>
|
||
|
||
<fieldset class="cbi-section" id="cbi-info" style="display: block;">
|
||
<div class="cbi-section fade-in">
|
||
<h3><%:Message%></h3>
|
||
<table class="table" id="message">
|
||
<tr class="tr">
|
||
<td colspan="2" class="td left">
|
||
<div align="left" id="info_message" style="font-size:1.875em">
|
||
<img src="<%=resource%>/icons/loading.gif" alt="<%:Loading%>" style="vertical-align:middle"/>
|
||
<%:Loading modem%>...
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
</fieldset>
|
||
|
||
<fieldset class="cbi-section" id="cbi-modem" style="display: none;">
|
||
<div class="cbi-section fade-in">
|
||
<!-- <legend><%:Modem Select%></legend> -->
|
||
<h3><%:Modem Select%></h3>
|
||
<div class="cbi-section-node">
|
||
<div class="cbi-value cbi-value-last">
|
||
<label class="cbi-value-title"><%:Modem Name%></label>
|
||
<div class="cbi-value-field">
|
||
<div class="cbi-checkbox">
|
||
<select name="modem_select" id="modem_select" class="cbi-input-select"></select>
|
||
</div>
|
||
<div class="cbi-value-description">
|
||
<%:Select a modem for debugging%>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div name="first-checked">
|
||
<input type="hidden" id="first-checked" value="true">
|
||
</div>
|
||
</div>
|
||
</fieldset>
|
||
|
||
<fieldset class="cbi-section" id="cbi-mode" style="display: none;">
|
||
<div class="cbi-section cbi-tblsection">
|
||
<!-- <legend><%:Mode%></legend> -->
|
||
<h3><%:Mode%></h3>
|
||
<table class="table cbi-section-table">
|
||
<tbody>
|
||
<tr class="tr cbi-section-table-titles anonymous">
|
||
<th class="th cbi-section-table-cell"><%:Current%></th>
|
||
<th class="th cbi-section-table-cell"><%:Config%></th>
|
||
<th class="th cbi-section-table-cell cbi-section-actions"></th>
|
||
</tr>
|
||
<tr class="tr cbi-section-table-row cbi-rowstyle-1">
|
||
<td class="td cbi-value-field" data-title="<%:Current%>" id="current_mode"></td>
|
||
<td class="td cbi-value-field" data-title="<%:Config%>" id="mode_option">
|
||
<!-- <div>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="mode_option" id="mode_option_qmi" value="qmi" checked="true">
|
||
<span>QMI</span>
|
||
</span>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="mode_option" id="mode_option_ecm" value="ecm">
|
||
<span>ECM</span>
|
||
</span>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="mode_option" id="mode_option_mbim" value="mbim">
|
||
<span>MBIM</span>
|
||
</span>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="mode_option" id="mode_option_rndis" value="rndis">
|
||
<span>RNDIS</span>
|
||
</span>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="mode_option" id="mode_option_ncm" value="ncm">
|
||
<span>NCM</span>
|
||
</span>
|
||
</div> -->
|
||
</td>
|
||
<td class="td">
|
||
<div>
|
||
<button class="btn cbi-button cbi-button-apply" id="mode_button" onclick="set_mode()" alt="<%:Apply%>" title="<%:Apply%>"><%:Apply%></button>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
</fieldset>
|
||
|
||
<fieldset class="cbi-section" id="cbi-network-prefer" style="display: none;">
|
||
<div class="cbi-section cbi-tblsection">
|
||
<!-- <legend><%:Network Preferences%></legend> -->
|
||
<h3><%:Network Preferences%></h3>
|
||
<table class="table cbi-section-table">
|
||
<tbody>
|
||
<tr class="tr cbi-section-table-titles anonymous">
|
||
<th class="th cbi-section-table-cell"><%:Current%></th>
|
||
<th class="th cbi-section-table-cell"><%:Option%></th>
|
||
<th class="th cbi-section-table-cell"><%:Config%></th>
|
||
<th class="th cbi-section-table-cell cbi-section-actions"></th>
|
||
</tr>
|
||
<tr class="tr cbi-section-table-row cbi-rowstyle-1">
|
||
<td class="td cbi-value-field" data-title="<%:Current%>" id="current_prefer"></td>
|
||
<td class="td cbi-value-field" data-title="<%:Option%>" id="prefer_option">
|
||
<div>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="prefer_option" id="prefer_option_auto" value="auto" checked="true">
|
||
<span><%:Auto%></span>
|
||
</span>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="prefer_option" id="prefer_option_custom" value="custom">
|
||
<span><%:Custom%></span>
|
||
</span>
|
||
</div>
|
||
</td>
|
||
<td class="td cbi-value-field" data-title="<%:Config%>" id="prefer_custom_config">
|
||
<div>
|
||
<span class="cbi-checkbox">
|
||
<input id="prefer_config_3g" type="checkbox" class="cbi-input-checkbox" value="3g">
|
||
<span><%:3G%></span>
|
||
</span>
|
||
<span class="cbi-checkbox">
|
||
<input id="prefer_config_4g" type="checkbox" class="cbi-input-checkbox" value="4g">
|
||
<span><%:4G%></span>
|
||
</span>
|
||
<span class="cbi-checkbox">
|
||
<input id="prefer_config_5g" type="checkbox" class="cbi-input-checkbox" value="5g">
|
||
<span><%:5G%></span>
|
||
</span>
|
||
</div>
|
||
</td>
|
||
<td class="td">
|
||
<div>
|
||
<button class="btn cbi-button cbi-button-apply" id="network_prefer_button" onclick="set_network_prefer()" alt="<%:Apply%>" title="<%:Apply%>"><%:Apply%></button>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
</fieldset>
|
||
|
||
<fieldset class="cbi-section" id="cbi-at" style="display: none;">
|
||
<div class="cbi-section fade-in">
|
||
<!-- <legend><%:AT Command%></legend> -->
|
||
<h3><%:AT Command%></h3>
|
||
<table class="table" id="at_command_info">
|
||
<tbody>
|
||
<!-- <tr class="tr">
|
||
<td class="td left"><%:Modem Select%></td>
|
||
<td class="td left"><select name="modem_select" id="modem_select" class="cbi-input-select"></select></td>
|
||
</tr> -->
|
||
<tr class="tr">
|
||
<td class="td left"><%:Quick Option%></td>
|
||
<td class="td left" id="quick_option_td">
|
||
<div>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="quick_option" value="auto" checked="true">
|
||
<span><%:Auto%></span>
|
||
</span>
|
||
<span class="cbi-radio">
|
||
<input type="radio" name="quick_option" value="custom">
|
||
<span><%:Custom%></span>
|
||
</span>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
<tr class="tr">
|
||
<td class="td left"><%:Quick Commands%></td>
|
||
<td class="td left"><select name="command_select" id="command_select" class="cbi-input-select" onclick="copy_to_input()"></select></td>
|
||
</tr>
|
||
<tr class="tr">
|
||
<td class="td left"><%:Enter Command%></td>
|
||
<td class="td left">
|
||
<div>
|
||
<input type="text" id="at_command" class="cbi-input-text"></input>
|
||
</div>
|
||
<div>
|
||
<input class="cbi-button cbi-button-apply" type="button" value="<%:Send%>" onclick="send_at_command()" alt="<%:Send%>" title="<%:Send%>">
|
||
<input class="cbi-button cbi-button-reset" type="button" value="<%:Clean%>" onclick="clean_at_command()" alt="<%:Clean%>" title="<%:Clean%>">
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
<tr class="tr">
|
||
<td colspan="2" class="td left">
|
||
<div id="response_label"><%:Response%></div><br/>
|
||
<div><textarea readonly="readonly" id="response" rows="20" maxlength="160"></textarea></div>
|
||
<div class="cbi-page-actions">
|
||
<input class="btn cbi-button cbi-button-link" type="button" value="<%:Return to old page%>" onclick="location.href='/cgi-bin/luci/admin/network/modem/at_command_old'">
|
||
<input class="cbi-button cbi-button-reset" type="button" value="<%:Clean%>" onclick="clean_response()" alt="<%:Clean%>" title="<%:Clean%>">
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
</fieldset>
|
||
|
||
</div>
|
||
|
||
<%+footer%>
|