1 <div class=
"box box-primary" id=
"control">
2 <div class=
"box-header">
3 <div class=
"col-sm-9" style=
"padding-top:8px;">
4 <i class=
"fa fa-commenting"> </i>
5 <h1 class=
"box-title" style=
"font-weight:bold;" id=
"id_h1_page_title"></h1>
7 <div class=
"col-sm-1" style=
"padding-top:2px;">
8 <button id=
"id_btn_reset" class=
"btn btn-sm btn-danger btn-del"><i class=
"fa fa-trash"></i><span id=
"id_btn_span_reset">Reset
</span></button>
10 <div class=
"col-sm-2" style=
"font-size:16px;padding-top:8px;">
11 <a id=
"id_a_official_doc" target=
"_blank" href=
"https://www.ventoy.net/en/plugin_menutip.html"><span class=
"fa fa-link"></span><span id=
"id_span_official_doc">官网文档
</span></a>
16 <div class=
"box-body">
17 <div class=
"nav-tabs-custom">
18 <ul class=
"nav nav-tabs" id=
"id_tab_menu_tip">
19 <li class=
""><a href=
"#tab_0" data-toggle=
"tab" aria-expanded=
"false" style=
"font-weight:bold" >menu_tip
</a></li>
20 <li class=
""><a href=
"#tab_1" data-toggle=
"tab" aria-expanded=
"false" style=
"font-weight:bold">menu_tip_legacy
</a></li>
21 <li class=
""><a href=
"#tab_2" data-toggle=
"tab" aria-expanded=
"false" style=
"font-weight:bold">menu_tip_uefi
</a></li>
22 <li class=
""><a href=
"#tab_3" data-toggle=
"tab" aria-expanded=
"false" style=
"font-weight:bold">menu_tip_ia32
</a></li>
23 <li class=
""><a href=
"#tab_4" data-toggle=
"tab" aria-expanded=
"false" style=
"font-weight:bold">menu_tip_aa64
</a></li>
24 <li class=
""><a href=
"#tab_5" data-toggle=
"tab" aria-expanded=
"false" style=
"font-weight:bold">menu_tip_mips
</a></li>
28 <div class=
"box box-primary box-solid">
29 <div class=
"box-header with-border">
30 <h3 class=
"box-title" style=
"font-size: 14px;font-weight: bold;">Menu Tips
31 <span id=
"id_span_desc_cn"> —— 菜单提示信息
</span></h3>
32 <div class=
"box-tools pull-right">
33 <button class=
"btn btn-box-tool" data-widget=
"collapse"><i class=
"fa fa-minus"></i></button>
34 </div><!-- /.box-tools -->
35 </div><!-- /.box-header -->
36 <div class=
"box-body no-padding">
37 <table id=
"id_tip_tbl" class=
"table table-bordered">
40 <th style=
"width: 2%;">#
</th>
41 <th id=
"id_th_tip_type" style=
"width: 5%;"></th>
42 <th id=
"id_th_tip_path" style=
"width: 35%;"></th>
43 <th id=
"id_th_status" style=
"width: 5%;"></th>
44 <th id=
"id_th_tip_tip" style=
"width: 40%;"></th>
45 <th id=
"id_th_operation" style=
"width: 5%;"></th>
55 <div class=
"box box-primary box-solid">
56 <div class=
"box-header with-border">
57 <h3 class=
"box-title" style=
"font-size: 14px;font-weight: bold;">Tip Style
58 <span id=
"id_span_desc_cn"> —— 提示信息显示位置
</span></h3>
59 <div class=
"box-tools pull-right">
60 <button class=
"btn btn-box-tool" data-widget=
"collapse"><i class=
"fa fa-minus"></i></button>
61 </div><!-- /.box-tools -->
62 </div><!-- /.box-header -->
63 <div class=
"box-body no-padding">
64 <table id=
"id_tip_style" class=
"table table-bordered">
67 <th id=
"id_th_tip_opt" style=
"width: 10%;"></th>
68 <th id=
"id_th_tip_set" style=
"width: 20%;"></th>
69 <th id=
"id_th_tip_notes" style=
"width: 70%;"></th>
76 <input type=
"text" class=
"form-control" id=
"id_tip_text_left"/>
79 <span id=
"id_span_desc_cn">提示信息显示的 X 坐标百分比(相对于左上角)
</span>
80 <span id=
"id_span_desc_en">X position of the tip message. (Percentage form relative to the upper left corner)
</span>
86 <input type=
"text" class=
"form-control" id=
"id_tip_text_top"/>
89 <span id=
"id_span_desc_cn">提示信息显示的 Y 坐标百分比(相对于左上角)
</span>
90 <span id=
"id_span_desc_en">Y position of the tip message. (Percentage form relative to the upper left corner)
</span>
96 <input type=
"text" class=
"form-control" id=
"id_tip_text_color"/>
99 <span id=
"id_span_desc_cn">提示信息的颜色。可以是
<code>blue/red/green/...
</code> 等这种格式,也可以设置为
<code>#
00ff00
</code> 这种格式。
</span>
100 <span id=
"id_span_desc_en">Color of the tip message. Can be in
<code>blue/red/green/...
</code> or
<code>#
00ff00
</code> format.
</span>
111 <script type=
"text/javascript">
113 function VtoyPageLanguageChange(newlang) {
114 VtoyCommonChangeLanguage(newlang);
115 $('h1[id=id_h1_page_title]').text(g_vtoy_cur_language.STR_PLUG_TIP);
117 $("span[id=id_span_file_exist]").each(function(){
118 $(this).text(g_vtoy_cur_language.STR_FILE_EXIST);
120 $("span[id=id_span_file_nonexist]").each(function(){
121 $(this).text(g_vtoy_cur_language.STR_FILE_NONEXIST);
123 $("span[id=id_span_file_fuzzy]").each(function(){
124 $(this).text(g_vtoy_cur_language.STR_FILE_FUZZY);
127 $("span[id=id_span_dir_exist]").each(function(){
128 $(this).text(g_vtoy_cur_language.STR_DIR_EXIST);
131 $("span[id=id_span_dir_nonexist]").each(function(){
132 $(this).text(g_vtoy_cur_language.STR_DIR_NONEXIST);
137 if (newlang === 'en') {
138 $('#id_th_tip_path').text('Absolute Path');
139 $('#id_th_tip_tip').text('Tip');
140 $('#id_th_tip_type').text('Type');
141 $("th[id=id_th_tip_opt]").text('Option');
142 $("th[id=id_th_tip_set]").text('Setting');
143 $("th[id=id_th_tip_notes]").text('Notes');
145 $("span[id=id_span_desc_cn]").each(function(){
148 $("span[id=id_span_desc_en]").each(function(){
152 $('#id_th_tip_path').text('绝对路径');
153 $('#id_th_tip_tip').text('提示');
154 $('#id_th_tip_type').text('类型');
155 $("th[id=id_th_tip_opt]").text('选项');
156 $("th[id=id_th_tip_set]").text('设置');
157 $("th[id=id_th_tip_notes]").text('说明');
158 $("span[id=id_span_desc_en]").each(function(){
161 $("span[id=id_span_desc_cn]").each(function(){
167 function FillTipTable(data) {
168 var addbtn = ventoy_get_xslg_addbtn('TipAddBtn');
169 var delbtn = ventoy_get_xslg_delbtn('TipDelBtn');
171 var td1, td2, td3, td4, td5, td6;
172 var $tbl = $("#id_tip_tbl tbody");
175 for (var i =
0; i < data.length; i++) {
177 td1 = '
<td>' + (i +
1) + '
</td>';
178 td2 = (data[i].type ===
0) ? '
<td>image
</td>' : '
<td>dir
</td>';
179 td3 = '
<td>' + data[i].path + '
</td>';
180 td4 = '
<td>' + ventoy_get_status_line(data[i].type, data[i].valid) + '
</td>';
181 td5 = '
<td>' + data[i].tip + '
</td>';
182 td6 = '
<td>' + delbtn + '
</td>';
184 $tr = $('
<tr>' + td1 + td2 + td3 + td4 + td5 + td6 + '
</tr>');
186 $tr.data('path', data[i].path);
187 $tr.data('index', i);
191 $tbl.append('
<tr><td></td><td></td><td></td><td></td><td></td><td>' + addbtn + '
</td></tr>');
194 function VtoyFillCurrentPageItem(data) {
196 $('input:text[id=id_tip_text_left]').val(data.left);
197 $('input:text[id=id_tip_text_top]').val(data.top);
198 $('input:text[id=id_tip_text_color]').val(data.color);
200 FillTipTable(data.tips);
204 function OnClickMultiModeTab() {
205 var href = $(this).attr('href');
206 var index = parseInt(href.substr(
5,
1));
208 if (index <
0 || index
>= g_vtoy_data_default_index || current_tab_index === index) {
212 current_tab_index = index;
213 VtoyFillCurrentPageItem(m_data_tip[index]);
218 var current_tab_index =
0;
219 callVtoySync({method : 'get_tip'}, function(data) {
224 function AddTipEntry(root, type, valid, extra) {
225 var list = m_data_tip[current_tab_index].tips;
227 "path": root.substr(g_current_dir.length),
233 for (var i =
0; i < list.length; i++) {
234 if (list[i].path === data.path) {
235 Message.error(g_vtoy_cur_language.STR_DUPLICATE_PATH);
242 index: current_tab_index,
249 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
253 function OnAddImageTip(root, valid, extra) {
254 AddTipEntry(root,
0, valid, extra);
257 function OnAddDirTip(root, extra) {
258 AddTipEntry(root,
1,
1, extra);
261 function OnAddTipBtnClick(sel) {
263 var tip1 = (g_current_os === 'windows') ? '\\ISO\\Windows11.iso' : "/ISO/Ubuntu-
20.04-desktop-amd64.iso";
264 var tip2 = (g_current_os === 'windows') ? '\\ISO\\Windows**.iso' : "/ISO/Ubuntu-*****-desktop-amd64.iso";
266 "title": g_vtoy_cur_language.STR_SET_TIP,
268 "tip1": g_current_dir + tip1,
269 "tip2": g_current_dir + tip2,
272 "extra_title": g_vtoy_cur_language.STR_TIP
274 VtoySelectFilePath(OnAddImageTip, para);
276 var tip = (g_current_os === 'windows') ? '\\ISO\\Windows' : "/ISO/Linux";
278 "title": g_vtoy_cur_language.STR_SET_TIP,
279 "tip": g_current_dir + tip,
282 "extra_title": g_vtoy_cur_language.STR_TIP
284 VtoySelectDirPath(OnAddDirTip, para);
288 $("#id_tip_tbl").on('click', '.TipAddBtn', function() {
292 "tip": g_vtoy_cur_language.STR_SET_TIP_FOR_FILE
296 "tip": g_vtoy_cur_language.STR_SET_TIP_FOR_DIR
300 VtoySelectType(OnAddTipBtnClick, para);
303 $("#id_tip_tbl").on('click', '.TipDelBtn', function() {
304 var $tr = $(this).closest('tr');
305 var path = $tr.data('path');
306 var index = $tr.data('index');
310 index: current_tab_index,
313 m_data_tip[current_tab_index].tips.splice(index,
1);
314 FillTipTable(m_data_tip[current_tab_index].tips);
315 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
319 function VtoySaveCurrentPage() {
320 var left = $('input:text[id=id_tip_text_left]').val();
321 var top = $('input:text[id=id_tip_text_top]').val();
322 var color = $('input:text[id=id_tip_text_color]').val();
326 index: current_tab_index,
331 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
335 $('input:text[id=id_tip_text_left]').change(function() {
336 var value = $('input:text[id=id_tip_text_left]').val();
337 if (ventoy_check_percent(value)) {
338 VtoySaveCurrentPage();
339 m_data_tip[current_tab_index].left = value;
341 Message.error(g_vtoy_cur_language.STR_INVALID_PERCENT);
342 $('input:text[id=id_tip_text_left]').val(m_data_tip[current_tab_index].left);
345 $('input:text[id=id_tip_text_top]').change(function() {
346 var value = $('input:text[id=id_tip_text_top]').val();
347 if (ventoy_check_percent(value)) {
348 VtoySaveCurrentPage();
349 m_data_tip[current_tab_index].top = value;
351 Message.error(g_vtoy_cur_language.STR_INVALID_PERCENT);
352 $('input:text[id=id_tip_text_top]').val(m_data_tip[current_tab_index].top);
355 $('input:text[id=id_tip_text_color]').change(function() {
356 var value = $('input:text[id=id_tip_text_color]').val();
357 if (value.length
> 0) {
358 if (ventoy_check_color(value)) {
359 VtoySaveCurrentPage();
360 m_data_tip[current_tab_index].color = value;
362 Message.error(g_vtoy_cur_language.STR_INVALID_COLOR);
363 $('input:text[id=id_tip_text_color]').val(m_data_tip[current_tab_index].color);
366 $('input:text[id=id_tip_text_color]').val(m_data_tip[current_tab_index].color);
371 $('#id_tab_menu_tip a[
href=
"#tab_0"]').click(OnClickMultiModeTab);
372 $('#id_tab_menu_tip a[
href=
"#tab_1"]').click(OnClickMultiModeTab);
373 $('#id_tab_menu_tip a[
href=
"#tab_2"]').click(OnClickMultiModeTab);
374 $('#id_tab_menu_tip a[
href=
"#tab_3"]').click(OnClickMultiModeTab);
375 $('#id_tab_menu_tip a[
href=
"#tab_4"]').click(OnClickMultiModeTab);
376 $('#id_tab_menu_tip a[
href=
"#tab_5"]').click(OnClickMultiModeTab);
378 function UpdateTabTitleIcon(data) {
379 CommonUpdateTabTitleIcon(data.exist_menu_tip, '#id_tab_menu_tip a[
href=
"#tab_', 'menu_tip');
381 $('#id_btn_reset').click(function() {
382 Modal.confirm({msg:GetResetTabConfigTipMsg(current_tab_index, 'menu_tip')}).on(function(e) {
386 index: current_tab_index,
392 m_data_tip[current_tab_index].left = m_data_tip[g_vtoy_data_default_index].left;
393 m_data_tip[current_tab_index].top = m_data_tip[g_vtoy_data_default_index].top;
394 m_data_tip[current_tab_index].color = m_data_tip[g_vtoy_data_default_index].color;
395 m_data_tip[current_tab_index].tips.length = 0;
396 VtoyFillCurrentPageItem(m_data_tip[g_vtoy_data_default_index]);
397 VtoySaveCurrentPage();
402 $('#id_tab_menu_tip a[href="#tab_0
"]').tab('show');
403 VtoyFillCurrentPageItem(m_data_tip[0]);
404 VtoyPageLanguageChange(g_current_language);