| 1 | class BookmarkMenu { |
|---|
| 2 | constructor( bookmark_displayname_max_length , mgr ) { |
|---|
| 3 | this.bookmark_displayname_max_length = bookmark_displayname_max_length |
|---|
| 4 | this.bookmark_mgr = mgr |
|---|
| 5 | } |
|---|
| 6 | |
|---|
| 7 | dlg(){ |
|---|
| 8 | console.log("BookmarkMenu dlg()") |
|---|
| 9 | $( '#bookmark_displayname' ).prop( 'maxlength' , Globalx.bookmark_displayname_max_length) |
|---|
| 10 | $('#bookmarkDlg').dialog({ |
|---|
| 11 | autoOpen: false, |
|---|
| 12 | modal: true, |
|---|
| 13 | buttons: { |
|---|
| 14 | "OK": function() { |
|---|
| 15 | const part = Globalx.parts[ Globalx.index ] |
|---|
| 16 | const path = $( '#bookmark_path' ).val() |
|---|
| 17 | const displayname = $( '#bookmark_displayname' ).val() |
|---|
| 18 | Globalx.bookmarkmenu.register_bookmark(path, displayname ) |
|---|
| 19 | $(this).dialog("close")}, |
|---|
| 20 | "Cancel": function() { |
|---|
| 21 | const part = Globalx.parts[ Globalx.index ] |
|---|
| 22 | const bookmark_cb = $( Globalx[part].bookmark_op_sel ) |
|---|
| 23 | bookmark_cb.prop('checked', false) |
|---|
| 24 | $(this).dialog("close") |
|---|
| 25 | } |
|---|
| 26 | } |
|---|
| 27 | }) |
|---|
| 28 | } |
|---|
| 29 | |
|---|
| 30 | add_bookmark() { |
|---|
| 31 | let part = Globalx.parts[ Globalx.index ] |
|---|
| 32 | console.log("add_bookmark part=" + part) |
|---|
| 33 | $( '#bookmark_displayname' ).val( this.bookmark_mgr.get_restricted_display_name( Globalx[part].key ) ) |
|---|
| 34 | $( '#bookmark_path' ).val( Globalx[part].key ) |
|---|
| 35 | $( '#bookmarkDlg' ).dialog("open") |
|---|
| 36 | } |
|---|
| 37 | |
|---|
| 38 | remove_bookmark() { |
|---|
| 39 | let part = Globalx.parts[ Globalx.index ] |
|---|
| 40 | console.log("remove_bookmark part=" + part) |
|---|
| 41 | this.bookmark_mgr.remove( part, Globalx[part].key ) |
|---|
| 42 | this.rebuild_bookmark_menu(part) |
|---|
| 43 | } |
|---|
| 44 | |
|---|
| 45 | bookmark_op() { |
|---|
| 46 | let part = Globalx.parts[ Globalx.index ] |
|---|
| 47 | let bookmark_op_sel = Globalx[part].bookmark_op_sel |
|---|
| 48 | console.log("bookmark_op part=" + part + " bookmark_op_sel=" + bookmark_op_sel) |
|---|
| 49 | if( $( bookmark_op_sel ).is(':checked') == true ){ |
|---|
| 50 | this.add_bookmark() |
|---|
| 51 | } |
|---|
| 52 | else{ |
|---|
| 53 | this.remove_bookmark() |
|---|
| 54 | } |
|---|
| 55 | } |
|---|
| 56 | |
|---|
| 57 | set_click_handler(part) { |
|---|
| 58 | let bookmark_op_sel = Globalx[part].bookmark_op_sel |
|---|
| 59 | |
|---|
| 60 | console.log( "set_click_handler() part=" + part + " bookmark_op_sel=" + bookmark_op_sel ) |
|---|
| 61 | $( bookmark_op_sel ).on( 'click' , () => { |
|---|
| 62 | console.log("bookmark_op_sel clicked") |
|---|
| 63 | this.bookmark_op() } ) |
|---|
| 64 | } |
|---|
| 65 | |
|---|
| 66 | register_bookmark( path, displayname ) { |
|---|
| 67 | let part = Globalx.parts[ Globalx.index ] |
|---|
| 68 | console.log("BookmarkMenu register_bookmark part="+part+" path="+path) |
|---|
| 69 | this.bookmark_mgr.add( part, path , displayname ) |
|---|
| 70 | this.rebuild_bookmark_menu(part) |
|---|
| 71 | } |
|---|
| 72 | |
|---|
| 73 | rebuild_bookmark_menu(part) { |
|---|
| 74 | let num = Globalx.num |
|---|
| 75 | let bookmark_sel = Globalx[part].bookmark_sel |
|---|
| 76 | console.log("BookmarkMenu rebuld_bookmark_menu num="+num+ " part="+part) |
|---|
| 77 | $( bookmark_sel ).empty() |
|---|
| 78 | |
|---|
| 79 | const array = this.bookmark_mgr.get_paths(part) |
|---|
| 80 | console.log("BookmarkMenu rebuld_bookmark_menu array=" + array ) |
|---|
| 81 | |
|---|
| 82 | let content = null |
|---|
| 83 | let item = null |
|---|
| 84 | array.map( ( path ) => { |
|---|
| 85 | const display_name = this.bookmark_mgr.display_name( part, path ) |
|---|
| 86 | content = `<li><a href="#" >${display_name}</a></li>`; |
|---|
| 87 | console.log("BookmarkMenu rebuld_bookmark_menu content=" + content) |
|---|
| 88 | $( bookmark_sel ).append( content ); |
|---|
| 89 | console.log( "bookmark_sel="+bookmark_sel) |
|---|
| 90 | item = $( bookmark_sel ).last() |
|---|
| 91 | console.log( "item=" + item ) |
|---|
| 92 | item.on('click' , () => { |
|---|
| 93 | console.log("BookmarkMenu rebuld_bookmark_menu bookmark_action part="+part + " path" + path ) |
|---|
| 94 | this.bookmark_action( part , path ) |
|---|
| 95 | } ) |
|---|
| 96 | console.log("BookmarkMenu rebuld_bookmark_menu path=" + path ) |
|---|
| 97 | }) |
|---|
| 98 | } |
|---|
| 99 | |
|---|
| 100 | set_globalx_item_name( part, item_name ) { |
|---|
| 101 | Globalx[part].item_name = item_name |
|---|
| 102 | let dl = $( Globalx[part].download_sel ) |
|---|
| 103 | dl.attr('download' , Globalx[part].item_name) |
|---|
| 104 | dl.removeAttr('href') |
|---|
| 105 | } |
|---|
| 106 | |
|---|
| 107 | bookmark_action = ( part, key ) => { |
|---|
| 108 | if( key === null || key === "" ){ |
|---|
| 109 | alert("illeagal key=" + key ) |
|---|
| 110 | return |
|---|
| 111 | } |
|---|
| 112 | if(key === Globalx[part].key){ |
|---|
| 113 | return |
|---|
| 114 | } |
|---|
| 115 | let num = Globalx.num |
|---|
| 116 | let jsondata = Globalx.storagex.get_filelist( Globalx.num , part) |
|---|
| 117 | Globalx[part].key = key |
|---|
| 118 | Globalx[part].key_indicate_file = false; |
|---|
| 119 | |
|---|
| 120 | this.set_globalx_item_name( part, key ) |
|---|
| 121 | |
|---|
| 122 | $( Globalx[part].key_sel ).val( key ) |
|---|
| 123 | console.log("jsondata=" + jsondata) |
|---|
| 124 | if( jsondata[key].length == 0 ){ |
|---|
| 125 | Globalx[part].key_indicate_file = true; |
|---|
| 126 | Globalx.remotex.get_content( num, part, Globalx[part].key , (content) => { |
|---|
| 127 | Globalx[part].editor.getSession().setValue( content ) |
|---|
| 128 | $( Globalx[part].textarea_sel ).val( content ) |
|---|
| 129 | }); |
|---|
| 130 | } |
|---|
| 131 | else{ |
|---|
| 132 | Globalx[part].key_indicate_file = false |
|---|
| 133 | Globalx[part].editor.getSession().setValue( "" ); |
|---|
| 134 | $( Globalx[part].textarea_sel ).val( "" ); |
|---|
| 135 | } |
|---|
| 136 | const bookmark_cb = $( Globalx[part].bookmark_op_sel ) |
|---|
| 137 | bookmark_cb.prop('checked', true) |
|---|
| 138 | |
|---|
| 139 | $( Globalx[part].menu_sel ).empty() |
|---|
| 140 | |
|---|
| 141 | this.make_menu_item_list(jsondata, Globalx[part].key) |
|---|
| 142 | } |
|---|
| 143 | } |
|---|