]> glassweightruler.freedombox.rocks Git - Ventoy.git/blob - Plugson/www/plugson_persistence.html
VentoyPlugson: Add Windows duplicate file path check for different upper/lower case.
[Ventoy.git] / Plugson / www / plugson_persistence.html
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-database">&nbsp;&nbsp;</i>
5 <h1 class="box-title" style="font-weight:bold;" id="id_h1_page_title">x</h1>
6 </div>
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>
9 </div>
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_persistence.html"><span class="fa fa-link"></span><span id="id_span_official_doc">官网文档</span></a>
12 </div>
13 </div>
14 <legend></legend>
15
16 <div class="box-body">
17 <div class="nav-tabs-custom">
18 <ul class="nav nav-tabs" id="id_tab_persistence">
19 <li class=""><a href="#tab_0" data-toggle="tab" aria-expanded="false" style="font-weight:bold" >persistence</a></li>
20 <li class=""><a href="#tab_1" data-toggle="tab" aria-expanded="false" style="font-weight:bold">persistence_legacy</a></li>
21 <li class=""><a href="#tab_2" data-toggle="tab" aria-expanded="false" style="font-weight:bold">persistence_uefi</a></li>
22 <li class=""><a href="#tab_3" data-toggle="tab" aria-expanded="false" style="font-weight:bold">persistence_ia32</a></li>
23 <li class=""><a href="#tab_4" data-toggle="tab" aria-expanded="false" style="font-weight:bold">persistence_aa64</a></li>
24 <li class=""><a href="#tab_5" data-toggle="tab" aria-expanded="false" style="font-weight:bold">persistence_mips</a></li>
25 </ul>
26 </div>
27
28 <table id="id_persistence_tbl" class="table table-bordered" >
29 <thead>
30 <tr>
31 <th style="width: 5%;">#</th>
32 <th id="id_th_persistence_set" style="width: 80%;"></th>
33 <th id="id_th_operation" style="width: 10%;"></th>
34 </tr>
35 </thead>
36 <tbody>
37 </tbody>
38 </table>
39 </div>
40 </div>
41 <script type="text/javascript">
42
43 function VtoyPageLanguageChange(newlang) {
44 VtoyCommonChangeLanguage(newlang);
45 $('h1[id=id_h1_page_title]').text(g_vtoy_cur_language.STR_PLUG_PERSISTENCE);
46
47 $("span[id=id_span_file_exist]").each(function(){
48 $(this).text(g_vtoy_cur_language.STR_FILE_EXIST);
49 });
50 $("span[id=id_span_file_nonexist]").each(function(){
51 $(this).text(g_vtoy_cur_language.STR_FILE_NONEXIST);
52 });
53 $("span[id=id_span_file_fuzzy]").each(function(){
54 $(this).text(g_vtoy_cur_language.STR_FILE_FUZZY);
55 });
56
57 $("span[id=id_span_dir_exist]").each(function(){
58 $(this).text(g_vtoy_cur_language.STR_DIR_EXIST);
59 });
60
61 $("span[id=id_span_dir_nonexist]").each(function(){
62 $(this).text(g_vtoy_cur_language.STR_DIR_NONEXIST);
63 });
64
65 $("th[id=id_th_persist_dat]").each(function(){
66 $(this).text(g_vtoy_cur_language.STR_PERSISTENCE_DAT);
67 });
68
69 if (newlang === 'en') {
70 $('#id_th_autoins_path').text('Absolute Path');
71 $('#id_th_persistence_set').text('Setting');
72 } else {
73 $('#id_th_autoins_path').text('绝对路径');
74 $('#id_th_persistence_set').text('设置');
75
76 }
77 }
78
79 function VtoySaveCurrentPage(index) {
80
81 var timeoutval = 0;
82 var autoselval = 1;
83
84 var timeouten = $('#id_timeout_en_' + index).is(':checked');
85 var autoselen = $('#id_autosel_en_' + index).is(':checked');
86
87 if (timeouten) {
88 timeoutval = parseInt($('#id_text_timeout_' + index).val());
89 }
90
91 if (autoselen) {
92 autoselval = parseInt($('#id_text_autosel_' + index).val());
93 }
94
95 callVtoy({
96 method : 'save_persistence',
97 index: current_tab_index,
98 id: index,
99 timeout: timeoutval,
100 autosel: autoselval,
101 timeouten: timeouten,
102 autoselen: autoselen
103 }, function(e) {
104 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
105 });
106 }
107
108 function OnInputTextChange() {
109 var id = $(this).attr('id');
110 var value = $(this).val();
111 var intval;
112
113 if (typeof(id) == 'undefined' || id.length <= 16) {
114 return;
115 }
116
117 var index = parseInt(id.substr(16));
118 var data = m_data_persistence[current_tab_index][index];
119
120 if (/^[0-9][0-9]*$/.test(value)) {
121 intval = parseInt(value);
122
123 if (id.startsWith('id_text_autosel_')) {
124 var list = m_data_persistence[current_tab_index][index].list;
125 if (intval > list.length) {
126 Message.error(g_vtoy_cur_language.STR_INVALID_AUTOSEL);
127 $(this).val(data.autosel);
128 return;
129 }
130 }
131
132 VtoySaveCurrentPage(index);
133 } else {
134 Message.error(g_vtoy_cur_language.STR_INVALID_NUMBER);
135
136 if (id.startsWith('id_text_timeout_')) {
137 $(this).val(data.timeout);
138 } else {
139 $(this).val(data.autosel);
140 }
141 }
142 }
143
144 function OnCheckBoxChange() {
145 var index;
146 var textid;
147 var value;
148 var id = $(this).attr('id');
149 var checked = $(this).is(':checked');
150
151 if (typeof(id) == 'undefined' || id.length <= 14) {
152 return;
153 }
154
155 index = parseInt(id.substr(14));
156 var data = m_data_persistence[current_tab_index][index];
157
158 if (id.startsWith('id_timeout_en_')) {
159 textid = 'input[id=id_text_timeout_' + index + ']';
160 value = data.timeout;
161 data.timeouten = checked;
162 } else {
163 textid = 'input[id=id_text_autosel_' + index + ']';
164 value = data.autosel;
165 data.autoselen = checked;
166 }
167
168 if (checked) {
169 $(textid).attr("disabled", false);
170 $(textid).val(value);
171
172 } else {
173 $(textid).attr("disabled", true);
174 $(textid).val('');
175 }
176
177 VtoySaveCurrentPage(index);
178 }
179
180
181 function FillPersistenceInnerTable(i, data) {
182 var td1, td2, td3, td4;
183 var inner = data.list;
184 var tabid = '#tbl_inner_' + (i + 1);
185 var $inner_tbl = $(tabid + ' tbody');
186
187 var inaddbtn = ventoy_get_xslg_addbtn('PersistenceInnerAddBtn');
188 var indelbtn = ventoy_get_xslg_delbtn('PersistenceInnerDelBtn');
189
190 $inner_tbl.empty();
191
192 for (var j = 0; j < inner.length; j++) {
193 var $tr;
194 td1 = '<td style="width: 5%;">'+(j+1)+'</td>';
195 td2 = '<td>'+inner[j].path+'</td>';
196 td3 = '<td style="width: 10%;">'+ventoy_get_status_line(0, inner[j].valid)+'</td>';
197 td4 = '<td style="width: 10%;">' + indelbtn + '</td>';
198
199 $tr = $('<tr>' + td1 + td2 + td3 + td4 + '</tr>');
200 $tr.data('path', inner[j].path);
201 $tr.data('index', j);
202 $tr.data('outpath', data.path);
203 $tr.data('outindex', i);
204
205 $inner_tbl.append($tr);
206 }
207
208 $tr = $('<tr><td></td><td></td><td></td><td>'+inaddbtn+'</td></tr>');
209 $tr.data('outpath', data.path);
210 $tr.data('outindex', i);
211
212 $inner_tbl.append($tr);
213 }
214
215 function FillPersistenceTable(data) {
216 var td1, td2, td3, td4, td5;
217 var addbtn = ventoy_get_addbtn('PersistenceAddBtn');
218 var delbtn = ventoy_get_delbtn('PersistenceDelBtn');
219
220 var $tbl = $("#id_persistence_tbl tbody");
221 $tbl.empty();
222
223 for (var i = 0; i < data.length; i++) {
224 var $tr;
225
226 var tdtimeout, timeoutdisable, timeoutval;
227 var tdautosel, autoseldisable, autoselval;
228 if (data[i].timeouten) {
229 tdtimeout = '<th style="width:10%;"><input id="id_timeout_en_'+i+'" checked="checked" type="checkbox"/> timeout</th>';
230 timeoutval = data[i].timeout;
231 timeoutdisable='';
232 } else {
233 tdtimeout = '<th style="width:10%;"><input id="id_timeout_en_'+i+'" type="checkbox"/> timeout</th>';
234 timeoutval='';
235 timeoutdisable='disabled="disabled"';
236 }
237 if (data[i].autoselen) {
238 tdautosel = '<th style="width:10%;"><input id="id_autosel_en_'+i+'" checked="checked" type="checkbox"/> autosel</th>';
239 autoselval = data[i].autosel;
240 autoseldisable='';
241 } else {
242 tdautosel = '<th style="width:10%;"><input id="id_autosel_en_'+i+'" type="checkbox"/> autosel</th>';
243 autoselval='';
244 autoseldisable='disabled="disabled"';
245 }
246
247
248 var tdtype = (data[i].type === 0) ? "image" : "parent";
249 var tdtbl1 ='<table class="table table-condensed">'+
250
251 '<thead><tr>' +
252 '<th>'+tdtype+'</th>'+
253 '<th style="width:10%;">Status</th>'+
254 tdtimeout +
255 tdautosel +
256 '</tr></thread>' +
257
258 '<tbody><tr>'+
259 '<td style="width:70%;vertical-align: middle;">' + data[i].path + '</td>' +
260 '<td style="vertical-align: middle;">' + ventoy_get_status_line(data[i].type, data[i].valid) + '</td>' +
261 '<td><div style="padding-left:0;" class="col-sm-8"><input type="text" '+timeoutdisable+' value="'+timeoutval+'" class="form-control" id="id_text_timeout_'+i+'"/></div></td>'+
262 '<td><div style="padding-left:0;" class="col-sm-8"><input type="text" '+autoseldisable+' value="'+autoselval+'" class="form-control" id="id_text_autosel_'+i+'"/></div></td></tr>'+
263
264 '<tr><td></td><td></td><td></td><td></td></tr>'+
265
266 '</tbody></table>';
267
268 var tdtbl2 = '<table class="table table-bordered" id="tbl_inner_' + (i+1) + '">'+
269 '<thead><tr><th>#</th><th id="id_th_persist_dat">'+g_vtoy_cur_language.STR_PERSISTENCE_DAT+'</th><th id="id_th_status">'+g_vtoy_cur_language.STR_STATUS+'</th><th id="id_th_operation">'+g_vtoy_cur_language.STR_OPERATION+'</th></tr></thead><tbody></tbody></table>';
270
271 td1 = '<td style="vertical-align: middle;">' + (i + 1) + '</td>';
272 td2 = '<td>' + tdtbl1 + tdtbl2 + '</td>';
273 td3 = '<td style="vertical-align: middle;text-align: center;">' + delbtn + '</td>';
274 $tr = $('<tr>' + td1 + td2 + td3 + '</tr>');
275
276 $tr.data('path', data[i].path);
277 $tr.data('index', i);
278 $tbl.append($tr);
279 }
280
281 $tbl.append('<tr><td></td><td></td><td style="vertical-align: middle;text-align: center;">' + addbtn + '</td></tr>');
282
283 $('input[type=text]').each(function (){
284 var id = $(this).attr('id');
285 if (typeof(id) == 'undefined') {
286 return;
287 }
288
289 if (id.startsWith('id_text_timeout_') || id.startsWith('id_text_autosel_')) {
290 $(this).change(OnInputTextChange);
291 }
292 });
293
294 $('input[type=checkbox]').each(function (){
295 var id = $(this).attr('id');
296 if (id.startsWith('id_timeout_en_') || id.startsWith('id_autosel_en_')) {
297 $(this).click(OnCheckBoxChange);
298 }
299 });
300
301 for (var i = 0; i < data.length; i++) {
302 FillPersistenceInnerTable(i, data[i]);
303 }
304 }
305
306 function VtoyFillCurrentPageItem(data) {
307 FillPersistenceTable(data);
308 }
309
310
311 function OnClickMultiModeTab() {
312 var href = $(this).attr('href');
313 var index = parseInt(href.substr(5, 1));
314
315 if (index < 0 || index >= g_vtoy_data_default_index || current_tab_index === index) {
316 return;
317 }
318
319 current_tab_index = index;
320 VtoyFillCurrentPageItem(m_data_persistence[index]);
321 }
322
323 function AddPersistenceEntry(type, exist1, path1, path2) {
324 var list = m_data_persistence[current_tab_index];
325 var data_array = [
326 {
327 "path": "",
328 "valid": 1
329 }
330 ];
331 var call_array = [
332 ""
333 ];
334
335 call_array[0] = path2.substr(g_current_dir.length);
336 data_array[0].path = path2.substr(g_current_dir.length);
337
338 var data = {
339 "path": path1.substr(g_current_dir.length),
340 "list": data_array,
341 "type": type,
342 "valid": exist1,
343 "autosel": 1,
344 "timeout": 0
345 };
346
347 for (var i = 0; i < list.length; i++) {
348 if (list[i].path === data.path) {
349 Message.error(g_vtoy_cur_language.STR_DUPLICATE_PATH);
350 return;
351 }
352 }
353
354 callVtoy({
355 method : 'persistence_add',
356 index: current_tab_index,
357 path: data.path,
358 backend: call_array,
359 type: type
360 }, function(e) {
361 if (e.result === 'success') {
362 list.push(data);
363 FillPersistenceTable(list);
364 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
365 } else if (e.result === 'duplicate') {
366 Message.error(g_vtoy_cur_language.STR_DUPLICATE_PATH);
367 }
368 });
369 }
370
371 function OnAddImagePersistence(exist1, path1, path2) {
372 AddPersistenceEntry(0, exist1, path1, path2);
373 }
374
375 function OnPersistenceAddClick() {
376 var tip1 = (g_current_os === 'windows') ? '\\ISO\\ubuntu-20.04-desktop-amd64.iso' : "/ISO/ubuntu-20.04-desktop-amd64.iso";
377 var tip2 = (g_current_os === 'windows') ? '\\ISO\\ubuntu-*****-desktop-amd64.iso' : "/ISO/ubuntu-*****-desktop-amd64.iso";
378 var tip3 = (g_current_os === 'windows') ? '\\ventoy\\ubuntu_persistence.dat' : "/ventoy/ubuntu_persistence.dat";
379 var para = {
380 "title": g_vtoy_cur_language.STR_SET_PERSISTENCE,
381 "label1": g_vtoy_cur_language.STR_FILE_PATH,
382 "label2": g_vtoy_cur_language.STR_SET_PERSISTENCE_DAT,
383 "tip1": g_current_dir + tip1,
384 "tip2": g_current_dir + tip2,
385 "tip3": g_current_dir + tip3
386 };
387
388 VtoySetFileFile(OnAddImagePersistence, para);
389 }
390
391 function PersistenceDelEntry(path, index) {
392 callVtoySync({
393 method : 'persistence_del',
394 index: current_tab_index,
395 path: path
396 }, function(data) {
397 m_data_persistence[current_tab_index].splice(index, 1);
398 FillPersistenceTable(m_data_persistence[current_tab_index]);
399 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
400 });
401 }
402
403 function OnPersistenceDelClick() {
404 var $tr = $(this).closest('tr');
405 var path = $tr.data('path');
406 var index = $tr.data('index');
407
408 PersistenceDelEntry(path, index);
409 }
410
411
412 var m_out_index;
413 var m_out_path;
414 function OnAddPersistenceDatFile(root, valid, extra) {
415 var path = root.substr(g_current_dir.length);
416 var data = m_data_persistence[current_tab_index][m_out_index];
417
418 for (var i = 0; i < data.list.length; i++) {
419 if (data.list[i].path === path) {
420 Message.error(g_vtoy_cur_language.STR_DUPLICATE_PATH);
421 return;
422 }
423 }
424
425 callVtoy({
426 method : 'persistence_add_inner',
427 index: current_tab_index,
428 outpath: m_out_path,
429 path: path
430 }, function(e) {
431
432 var node = {
433 "path": path,
434 "valid": 1
435 };
436
437 data.list.push(node);
438 FillPersistenceInnerTable(m_out_index, data);
439 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
440 });
441
442 }
443
444 function OnPersistenceInnerAddClick() {
445 var $tr = $(this).closest('tr');
446 var outpath = $tr.data('outpath');
447 var outindex = $tr.data('outindex');
448
449 var tip = (g_current_os === 'windows') ? '\\ventoy\\ubuntu_persistence.dat' : "/ventoy/ubuntu_persistence.dat";
450 var para = {
451 "title": g_vtoy_cur_language.STR_ADD_PERSISTENCE_DAT,
452 "fuzzy": 0,
453 "tip1": g_current_dir + tip,
454 "tip2": '',
455 "tip3": '',
456 "extra": false,
457 "extra_title": ''
458 };
459
460 m_out_index = outindex;
461 m_out_path = outpath;
462 VtoySelectFilePath(OnAddPersistenceDatFile, para);
463 }
464
465 function PersistenceDelInnerEntry(outpath, outindex, path, index) {
466 callVtoy({
467 method : 'persistence_del_inner',
468 index: current_tab_index,
469 outpath: outpath,
470 path: path
471 }, function(e) {
472 var data = m_data_persistence[current_tab_index][outindex];
473
474 data.list.splice(index, 1);
475 FillPersistenceInnerTable(outindex, m_data_persistence[current_tab_index][outindex]);
476 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
477 });
478 }
479
480 function OnPersistenceInnerDelClick() {
481 var $tr = $(this).closest('tr');
482
483 var path = $tr.data('path');
484 var index = $tr.data('index');
485 var outpath = $tr.data('outpath');
486 var outindex = $tr.data('outindex');
487
488 var list = m_data_persistence[current_tab_index][outindex].list;
489
490 if (list.length === 1) {
491 ventoy_confirm(g_vtoy_cur_language.STR_DEL_LAST, PersistenceDelEntry, outpath, outindex);
492 } else {
493 PersistenceDelInnerEntry(outpath, outindex, path, index);
494 }
495 }
496
497
498
499
500
501 //Main process
502 var m_data_persistence;
503 var current_tab_index = 0;
504 callVtoySync({method : 'get_persistence'}, function(data) {
505 m_data_persistence = data;
506 });
507
508 $("#id_persistence_tbl").on('click', '.PersistenceAddBtn', OnPersistenceAddClick);
509 $("#id_persistence_tbl").on('click', '.PersistenceDelBtn', OnPersistenceDelClick);
510 $("#id_persistence_tbl").on('click', '.PersistenceInnerAddBtn', OnPersistenceInnerAddClick);
511 $("#id_persistence_tbl").on('click', '.PersistenceInnerDelBtn', OnPersistenceInnerDelClick);
512
513 $('#id_tab_persistence a[href="#tab_0"]').click(OnClickMultiModeTab);
514 $('#id_tab_persistence a[href="#tab_1"]').click(OnClickMultiModeTab);
515 $('#id_tab_persistence a[href="#tab_2"]').click(OnClickMultiModeTab);
516 $('#id_tab_persistence a[href="#tab_3"]').click(OnClickMultiModeTab);
517 $('#id_tab_persistence a[href="#tab_4"]').click(OnClickMultiModeTab);
518 $('#id_tab_persistence a[href="#tab_5"]').click(OnClickMultiModeTab);
519 function UpdateTabTitleIcon(data) {
520 CommonUpdateTabTitleIcon(data.exist_persistence, '#id_tab_persistence a[href="#tab_', 'persistence');
521 }
522 $('#id_btn_reset').click(function() {
523 Modal.confirm({msg:GetResetTabConfigTipMsg(current_tab_index, 'persistence')}).on(function(e) {
524 if (e) {
525 callVtoySync({
526 method : 'persistence_del',
527 index: current_tab_index,
528 path: g_del_all_path
529 }, function(data) {
530
531 });
532
533 m_data_persistence[current_tab_index].length = 0;
534 VtoyFillCurrentPageItem(m_data_persistence[g_vtoy_data_default_index]);
535 Message.success(g_vtoy_cur_language.STR_SAVE_SUCCESS);
536 }
537 });
538 });
539
540 $('#id_tab_persistence a[href="#tab_0"]').tab('show');
541 VtoyFillCurrentPageItem(m_data_persistence[0]);
542 VtoyPageLanguageChange(g_current_language);
543
544 </script>