mirror of
				https://github.com/ventoy/Ventoy.git
				synced 2025-10-31 14:56:22 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			411 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			411 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <div class="box box-primary" id="control">
 | |
|     <div class="box-header">
 | |
|         <div class="col-sm-9" style="padding-top:8px;">
 | |
|             <i class="fa fa-commenting">  </i>
 | |
|             <h1 class="box-title" style="font-weight:bold;" id="id_h1_page_title"></h1>
 | |
|         </div>
 | |
|         <div class="col-sm-1" style="padding-top:2px;">
 | |
|           <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>
 | |
|         </div>
 | |
|         <div class="col-sm-2" style="font-size:16px;padding-top:8px;">
 | |
|             <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>
 | |
|         </div>
 | |
|     </div>
 | |
|     <legend></legend>
 | |
|     
 | |
|     <div class="box-body">
 | |
|       <div class="nav-tabs-custom">
 | |
|         <ul class="nav nav-tabs" id="id_tab_menu_tip">
 | |
|             <li class=""><a href="#tab_0" data-toggle="tab" aria-expanded="false" style="font-weight:bold" >menu_tip</a></li>
 | |
|             <li class=""><a href="#tab_1" data-toggle="tab" aria-expanded="false"  style="font-weight:bold">menu_tip_legacy</a></li>
 | |
|             <li class=""><a href="#tab_2" data-toggle="tab" aria-expanded="false"  style="font-weight:bold">menu_tip_uefi</a></li>
 | |
|             <li class=""><a href="#tab_3" data-toggle="tab" aria-expanded="false"  style="font-weight:bold">menu_tip_ia32</a></li>
 | |
|             <li class=""><a href="#tab_4" data-toggle="tab" aria-expanded="false"  style="font-weight:bold">menu_tip_aa64</a></li>
 | |
|             <li class=""><a href="#tab_5" data-toggle="tab" aria-expanded="false"  style="font-weight:bold">menu_tip_mips</a></li>
 | |
|         </ul>
 | |
|       </div>
 | |
| 
 | |
|       <div class="box box-primary box-solid">
 | |
|         <div class="box-header with-border">
 | |
|           <h3 class="box-title" style="font-size: 14px;font-weight: bold;">Menu Tips
 | |
|             <span id="id_span_desc_cn"> —— 菜单提示信息</span></h3>
 | |
|           <div class="box-tools pull-right">
 | |
|             <button class="btn btn-box-tool" data-widget="collapse"><i class="fa fa-minus"></i></button>
 | |
|           </div><!-- /.box-tools -->
 | |
|         </div><!-- /.box-header -->
 | |
|         <div class="box-body no-padding">
 | |
|           <table id="id_tip_tbl" class="table table-bordered">
 | |
|             <thead>
 | |
|               <tr>
 | |
|                 <th style="width: 2%;">#</th>
 | |
|                 <th id="id_th_tip_type" style="width: 5%;"></th>
 | |
|                 <th id="id_th_tip_path" style="width: 35%;"></th>
 | |
|                 <th id="id_th_status" style="width: 5%;"></th>
 | |
|                 <th id="id_th_tip_tip" style="width: 40%;"></th>
 | |
|                 <th id="id_th_operation" style="width: 5%;"></th>
 | |
|               </tr>
 | |
|             </thead>
 | |
|             <tbody>
 | |
|             </tbody>
 | |
|           </table>
 | |
|         </div>
 | |
|       </div>
 | |
|       <br/><br/>
 | |
| 
 | |
|       <div class="box box-primary box-solid">
 | |
|         <div class="box-header with-border">
 | |
|           <h3 class="box-title" style="font-size: 14px;font-weight: bold;">Tip Style
 | |
|             <span id="id_span_desc_cn"> —— 提示信息显示位置</span></h3>
 | |
|           <div class="box-tools pull-right">
 | |
|             <button class="btn btn-box-tool" data-widget="collapse"><i class="fa fa-minus"></i></button>
 | |
|           </div><!-- /.box-tools -->
 | |
|         </div><!-- /.box-header -->
 | |
|         <div class="box-body no-padding">
 | |
|           <table id="id_tip_style" class="table table-bordered">
 | |
|             <thead>
 | |
|               <tr>
 | |
|                 <th id="id_th_tip_opt" style="width: 10%;"></th>
 | |
|                 <th id="id_th_tip_set" style="width: 20%;"></th>
 | |
|                 <th id="id_th_tip_notes" style="width: 70%;"></th>
 | |
|               </tr>
 | |
|             </thead>
 | |
|             <tbody>
 | |
|               <tr>
 | |
|                 <td>left</td>
 | |
|                 <td>
 | |
|                     <input type="text" class="form-control" id="id_tip_text_left"/>
 | |
|                 </td>
 | |
|                 <td>
 | |
|                   <span id="id_span_desc_cn">提示信息显示的 X 坐标百分比(相对于左上角)</span>
 | |
|                   <span id="id_span_desc_en">X position of the tip message. (Percentage form relative to the upper left corner)</span>
 | |
|                 </td>
 | |
|               </tr>
 | |
|               <tr>
 | |
|                 <td>top</td>
 | |
|                 <td>
 | |
|                     <input type="text" class="form-control" id="id_tip_text_top"/>
 | |
|                 </td>
 | |
|                 <td>
 | |
|                   <span id="id_span_desc_cn">提示信息显示的 Y 坐标百分比(相对于左上角)</span>
 | |
|                   <span id="id_span_desc_en">Y position of the tip message. (Percentage form relative to the upper left corner)</span>
 | |
|                 </td>
 | |
|               </tr>
 | |
|               <tr>
 | |
|                 <td>color</td>
 | |
|                 <td>
 | |
|                     <input type="text" class="form-control" id="id_tip_text_color"/>
 | |
|                 </td>
 | |
|                 <td>
 | |
|                   <span id="id_span_desc_cn">提示信息的颜色。可以是 <code>blue/red/green/...</code> 等这种格式,也可以设置为 <code>#00ff00</code> 这种格式。</span>
 | |
|                   <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>
 | |
|                 </td>
 | |
|               </tr>
 | |
|             </tbody>
 | |
|           </table>
 | |
|         </div>
 | |
|       </div>
 | |
| 
 | |
| 
 | |
|     </div>
 | |
| </div>
 | |
| <script type="text/javascript">
 | |
|     
 | |
|   function VtoyPageLanguageChange(newlang) {
 | |
|     VtoyCommonChangeLanguage(newlang);
 | |
|     $('h1[id=id_h1_page_title]').text(g_vtoy_cur_language.STR_PLUG_TIP);
 | |
| 
 | |
|     $("span[id=id_span_file_exist]").each(function(){
 | |
|         $(this).text(g_vtoy_cur_language.STR_FILE_EXIST);
 | |
|     });
 | |
|     $("span[id=id_span_file_nonexist]").each(function(){
 | |
|         $(this).text(g_vtoy_cur_language.STR_FILE_NONEXIST);
 | |
|     });
 | |
|     $("span[id=id_span_file_fuzzy]").each(function(){
 | |
|         $(this).text(g_vtoy_cur_language.STR_FILE_FUZZY);
 | |
|     });
 | |
| 
 | |
|     $("span[id=id_span_dir_exist]").each(function(){
 | |
|         $(this).text(g_vtoy_cur_language.STR_DIR_EXIST);
 | |
|     });
 | |
|     
 | |
|     $("span[id=id_span_dir_nonexist]").each(function(){
 | |
|         $(this).text(g_vtoy_cur_language.STR_DIR_NONEXIST);
 | |
|     });
 | |
| 
 | |
|     
 | |
| 
 | |
|     if (newlang === 'en') {
 | |
|       $('#id_th_tip_path').text('Absolute Path');
 | |
|       $('#id_th_tip_tip').text('Tip');
 | |
|       $('#id_th_tip_type').text('Type');
 | |
|       $("th[id=id_th_tip_opt]").text('Option');
 | |
|       $("th[id=id_th_tip_set]").text('Setting');
 | |
|       $("th[id=id_th_tip_notes]").text('Notes');
 | |
| 
 | |
|       $("span[id=id_span_desc_cn]").each(function(){
 | |
|           $(this).hide();
 | |
|       });
 | |
|       $("span[id=id_span_desc_en]").each(function(){
 | |
|           $(this).show();
 | |
|       });
 | |
|     } else {
 | |
|       $('#id_th_tip_path').text('绝对路径');
 | |
|       $('#id_th_tip_tip').text('提示');
 | |
|       $('#id_th_tip_type').text('类型');
 | |
|       $("th[id=id_th_tip_opt]").text('选项');
 | |
|       $("th[id=id_th_tip_set]").text('设置');
 | |
|       $("th[id=id_th_tip_notes]").text('说明');
 | |
|       $("span[id=id_span_desc_en]").each(function(){
 | |
|           $(this).hide();
 | |
|       });
 | |
|       $("span[id=id_span_desc_cn]").each(function(){
 | |
|           $(this).show();
 | |
|       });
 | |
|     }
 | |
|   }
 | |
|   
 | |
|   function FillTipTable(data) {
 | |
|     var addbtn = ventoy_get_xslg_addbtn('TipAddBtn');
 | |
|     var delbtn = ventoy_get_xslg_delbtn('TipDelBtn');
 | |
| 
 | |
|     var td1, td2, td3, td4, td5, td6;
 | |
|     var $tbl = $("#id_tip_tbl tbody");
 | |
|     $tbl.empty();
 | |
| 
 | |
|     for (var i = 0; i < data.length; i++) {
 | |
|       var $tr;
 | |
|       td1 = '<td>' + (i + 1) + '</td>';
 | |
|       td2 = (data[i].type === 0) ? '<td>image</td>' : '<td>dir</td>';
 | |
|       td3 = '<td>' + data[i].path + '</td>';
 | |
|       td4 = '<td>' + ventoy_get_status_line(data[i].type, data[i].valid) + '</td>';
 | |
|       td5 = '<td>' + data[i].tip + '</td>';
 | |
|       td6 = '<td>' + delbtn + '</td>';
 | |
| 
 | |
|       $tr = $('<tr>' + td1 + td2 + td3 + td4 + td5 + td6 + '</tr>');
 | |
| 
 | |
|       $tr.data('path', data[i].path);
 | |
|       $tr.data('index', i);
 | |
|       $tbl.append($tr);
 | |
|     }
 | |
| 
 | |
|     $tbl.append('<tr><td></td><td></td><td></td><td></td><td></td><td>' + addbtn + '</td></tr>');
 | |
|   }
 | |
| 
 | |
|   function VtoyFillCurrentPageItem(data) {
 | |
| 
 | |
|     $('input:text[id=id_tip_text_left]').val(data.left);
 | |
|     $('input:text[id=id_tip_text_top]').val(data.top);
 | |
|     $('input:text[id=id_tip_text_color]').val(data.color);
 | |
| 
 | |
|     FillTipTable(data.tips);
 | |
|   }
 | |
| 
 | |
| 
 | |
|   function OnClickMultiModeTab() {
 | |
|     var href = $(this).attr('href');
 | |
|     var index = parseInt(href.substr(5, 1));
 | |
| 
 | |
|     if (index < 0 || index >= g_vtoy_data_default_index || current_tab_index === index) {
 | |
|       return;
 | |
|     }
 | |
|     
 | |
|     current_tab_index = index;
 | |
|     VtoyFillCurrentPageItem(m_data_tip[index]);
 | |
|   }
 | |
| 
 | |
|   //Main process
 | |
|   var m_data_tip;
 | |
|   var current_tab_index = 0;
 | |
|   callVtoySync({method : 'get_tip'}, function(data) {
 | |
|     m_data_tip = data;
 | |
|   });
 | |
|   
 | |
| 
 | |
|   function AddTipEntry(root, type, valid, extra) {
 | |
|     var list = m_data_tip[current_tab_index].tips;
 | |
|     var data = {
 | |
|       "path": root.substr(g_current_dir.length),
 | |
|       "tip": extra,
 | |
|       "type": type,
 | |
|       "valid": valid
 | |
|     };
 | |
| 
 | |
|     for (var i = 0; i < list.length; i++) {
 | |
|       if (list[i].path === data.path) {
 | |
|         Message.error(g_vtoy_cur_language.STR_DUPLICATE_PATH);
 | |
|         return;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     callVtoy({
 | |
|       method : 'tip_add',
 | |
|       index: current_tab_index,
 | |
|       path: data.path,
 | |
|       tip: data.tip,
 | |
|       type: type
 | |
|     }, function(e) {
 | |
|       if (e.result === 'success') {
 | |
|         list.push(data);
 | |
|         FillTipTable(list);
 | |
|         Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
 | |
|       } else if (e.result === 'duplicate') {
 | |
|         Message.error(g_vtoy_cur_language.STR_DUPLICATE_PATH);
 | |
|       }
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   function OnAddImageTip(root, valid, extra) {
 | |
|     AddTipEntry(root, 0, valid, extra);
 | |
|   }
 | |
| 
 | |
|   function OnAddDirTip(root, extra) {
 | |
|     AddTipEntry(root, 1, 1, extra);
 | |
|   }
 | |
| 
 | |
|   function OnAddTipBtnClick(sel)  {
 | |
|     if (sel === 0) {
 | |
|       var tip1 = (g_current_os === 'windows') ? '\\ISO\\Windows11.iso' : "/ISO/Ubuntu-20.04-desktop-amd64.iso";
 | |
|       var tip2 = (g_current_os === 'windows') ? '\\ISO\\Windows**.iso' : "/ISO/Ubuntu-*****-desktop-amd64.iso";
 | |
|       var para = {
 | |
|           "title": g_vtoy_cur_language.STR_SET_TIP,
 | |
|           "fuzzy": 1,
 | |
|           "tip1": g_current_dir + tip1,
 | |
|           "tip2": g_current_dir + tip2,
 | |
|           "tip3": '',
 | |
|           "extra": true,
 | |
|           "extra_title": g_vtoy_cur_language.STR_TIP
 | |
|       };
 | |
|       VtoySelectFilePath(OnAddImageTip, para);
 | |
|     } else {
 | |
|       var tip = (g_current_os === 'windows') ? '\\ISO\\Windows' : "/ISO/Linux";
 | |
|       var para = {
 | |
|           "title": g_vtoy_cur_language.STR_SET_TIP,
 | |
|           "tip": g_current_dir + tip,
 | |
|           "tip3": '',
 | |
|           "extra": true,
 | |
|           "extra_title": g_vtoy_cur_language.STR_TIP
 | |
|       };
 | |
|       VtoySelectDirPath(OnAddDirTip, para);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   $("#id_tip_tbl").on('click', '.TipAddBtn', function() {
 | |
|     var para = [
 | |
|       {
 | |
|         "selected": true,
 | |
|         "tip": g_vtoy_cur_language.STR_SET_TIP_FOR_FILE
 | |
|       },
 | |
|       {
 | |
|         "selected": false,
 | |
|         "tip": g_vtoy_cur_language.STR_SET_TIP_FOR_DIR
 | |
|       }
 | |
|     ];
 | |
| 
 | |
|     VtoySelectType(OnAddTipBtnClick, para);
 | |
|   });
 | |
| 
 | |
|   $("#id_tip_tbl").on('click', '.TipDelBtn', function() {
 | |
|     var $tr = $(this).closest('tr');
 | |
| 		var path = $tr.data('path');
 | |
|     var index = $tr.data('index');
 | |
| 
 | |
|     callVtoySync({
 | |
|         method : 'tip_del',
 | |
|         index: current_tab_index,
 | |
|         path: path
 | |
|     }, function(data) {
 | |
|       m_data_tip[current_tab_index].tips.splice(index, 1);
 | |
|       FillTipTable(m_data_tip[current_tab_index].tips);
 | |
|       Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   function VtoySaveCurrentPage() {
 | |
|     var left = $('input:text[id=id_tip_text_left]').val();
 | |
|     var top = $('input:text[id=id_tip_text_top]').val();
 | |
|     var color = $('input:text[id=id_tip_text_color]').val();
 | |
| 
 | |
|     callVtoy({
 | |
|       method : 'save_tip',
 | |
|       index: current_tab_index,
 | |
|       left: left,      
 | |
|       top: top,
 | |
|       color: color
 | |
|     }, function(e) {
 | |
|       Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   $('input:text[id=id_tip_text_left]').change(function() {
 | |
|     var value = $('input:text[id=id_tip_text_left]').val();
 | |
|     if (ventoy_check_percent(value)) {      
 | |
|       VtoySaveCurrentPage();
 | |
|       m_data_tip[current_tab_index].left = value;
 | |
|     } else {
 | |
|       Message.error(g_vtoy_cur_language.STR_INVALID_PERCENT);
 | |
|       $('input:text[id=id_tip_text_left]').val(m_data_tip[current_tab_index].left);
 | |
|     }
 | |
|   });
 | |
|   $('input:text[id=id_tip_text_top]').change(function() {
 | |
|     var value = $('input:text[id=id_tip_text_top]').val();
 | |
|     if (ventoy_check_percent(value)) {
 | |
|       VtoySaveCurrentPage();
 | |
|       m_data_tip[current_tab_index].top = value;
 | |
|     } else {
 | |
|       Message.error(g_vtoy_cur_language.STR_INVALID_PERCENT);
 | |
|       $('input:text[id=id_tip_text_top]').val(m_data_tip[current_tab_index].top);
 | |
|     }
 | |
|   });
 | |
|   $('input:text[id=id_tip_text_color]').change(function() {
 | |
|     var value = $('input:text[id=id_tip_text_color]').val();
 | |
|     if (value.length > 0) {
 | |
|       if (ventoy_check_color(value)) {
 | |
|         VtoySaveCurrentPage();
 | |
|         m_data_tip[current_tab_index].color = value;
 | |
|       } else {
 | |
|         Message.error(g_vtoy_cur_language.STR_INVALID_COLOR);
 | |
|         $('input:text[id=id_tip_text_color]').val(m_data_tip[current_tab_index].color);
 | |
|       }
 | |
|     } else {
 | |
|       $('input:text[id=id_tip_text_color]').val(m_data_tip[current_tab_index].color);
 | |
|     }
 | |
|   });
 | |
| 
 | |
| 
 | |
|   $('#id_tab_menu_tip a[href="#tab_0"]').click(OnClickMultiModeTab);
 | |
|   $('#id_tab_menu_tip a[href="#tab_1"]').click(OnClickMultiModeTab);
 | |
|   $('#id_tab_menu_tip a[href="#tab_2"]').click(OnClickMultiModeTab);
 | |
|   $('#id_tab_menu_tip a[href="#tab_3"]').click(OnClickMultiModeTab);
 | |
|   $('#id_tab_menu_tip a[href="#tab_4"]').click(OnClickMultiModeTab);
 | |
|   $('#id_tab_menu_tip a[href="#tab_5"]').click(OnClickMultiModeTab);
 | |
| 
 | |
|   function UpdateTabTitleIcon(data) {
 | |
|     CommonUpdateTabTitleIcon(data.exist_menu_tip, '#id_tab_menu_tip a[href="#tab_', 'menu_tip');
 | |
|   }
 | |
|   $('#id_btn_reset').click(function() { 
 | |
|     Modal.confirm({msg:GetResetTabConfigTipMsg(current_tab_index, 'menu_tip')}).on(function(e) {
 | |
|         if (e) {            
 | |
|             callVtoySync({
 | |
|                 method : 'tip_del',
 | |
|                 index: current_tab_index,
 | |
|                 path: g_del_all_path
 | |
|             }, function(data) {
 | |
|                 
 | |
|             });
 | |
|             
 | |
|             m_data_tip[current_tab_index].left = m_data_tip[g_vtoy_data_default_index].left;
 | |
|             m_data_tip[current_tab_index].top = m_data_tip[g_vtoy_data_default_index].top;
 | |
|             m_data_tip[current_tab_index].color = m_data_tip[g_vtoy_data_default_index].color;
 | |
|             m_data_tip[current_tab_index].tips.length = 0;            
 | |
|             VtoyFillCurrentPageItem(m_data_tip[g_vtoy_data_default_index]);
 | |
|             VtoySaveCurrentPage();
 | |
|         }
 | |
|     });
 | |
|   });
 | |
|   
 | |
|   $('#id_tab_menu_tip a[href="#tab_0"]').tab('show');
 | |
|   VtoyFillCurrentPageItem(m_data_tip[0]);
 | |
|   VtoyPageLanguageChange(g_current_language);
 | |
| 
 | |
| </script>
 |