| 
									
										
										
										
											2017-09-09 12:06:15 -04:00
										 |  |  | // hot keys are active also inside inputs and content editables
 | 
					
						
							| 
									
										
										
										
											2017-08-21 22:04:08 -04:00
										 |  |  | jQuery.hotkeys.options.filterInputAcceptingElements = true; | 
					
						
							|  |  |  | jQuery.hotkeys.options.filterContentEditable = true; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-09 18:53:11 -04:00
										 |  |  | $(document).bind('keydown', 'alt+m', () => { | 
					
						
							| 
									
										
										
										
											2017-09-23 10:18:08 -04:00
										 |  |  |     const toggle = $(".hide-toggle"); | 
					
						
							|  |  |  |     const hidden = toggle.css('display') === 'none'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     toggle.css('display', hidden ? 'block' : 'none'); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2017-08-22 22:40:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-09 12:06:15 -04:00
										 |  |  | // hide (toggle) everything except for the note content for distraction free writing
 | 
					
						
							| 
									
										
										
										
											2017-10-09 18:53:11 -04:00
										 |  |  | $(document).bind('keydown', 'alt+t', () => { | 
					
						
							| 
									
										
										
										
											2017-08-29 23:27:28 -04:00
										 |  |  |     const date = new Date(); | 
					
						
							| 
									
										
										
										
											2017-09-26 23:23:03 -04:00
										 |  |  |     const dateString = formatDateTime(date); | 
					
						
							| 
									
										
										
										
											2017-08-29 23:27:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-10 20:19:16 -04:00
										 |  |  |     $('#note-detail').summernote('insertText', dateString); | 
					
						
							| 
									
										
										
										
											2017-09-03 21:34:30 -04:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-09 18:53:11 -04:00
										 |  |  | $(window).on('beforeunload', () => { | 
					
						
							| 
									
										
										
										
											2017-09-09 12:06:15 -04:00
										 |  |  |     // this makes sure that when user e.g. reloads the page or navigates away from the page, the note's content is saved
 | 
					
						
							|  |  |  |     // this sends the request asynchronously and doesn't wait for result
 | 
					
						
							| 
									
										
										
										
											2017-09-04 16:03:07 -04:00
										 |  |  |     saveNoteIfChanged(); | 
					
						
							| 
									
										
										
										
											2017-09-10 11:50:17 -04:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Overrides the default autocomplete filter function to search for matched on atleast 1 word in each of the input term's words
 | 
					
						
							| 
									
										
										
										
											2017-10-09 18:53:11 -04:00
										 |  |  | $.ui.autocomplete.filter = (array, terms) => { | 
					
						
							| 
									
										
										
										
											2017-09-18 20:07:56 -04:00
										 |  |  |     if (!terms) { | 
					
						
							|  |  |  |         return []; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const startDate = new Date(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const results = []; | 
					
						
							|  |  |  |     const tokens = terms.toLowerCase().split(" "); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (const item of array) { | 
					
						
							|  |  |  |         let found = true; | 
					
						
							|  |  |  |         const lcValue = item.value.toLowerCase(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for (const token of tokens) { | 
					
						
							|  |  |  |             if (lcValue.indexOf(token) === -1) { | 
					
						
							|  |  |  |                 found = false; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (found) { | 
					
						
							|  |  |  |             results.push(item); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     console.log("Search took " + (new Date().getTime() - startDate.getTime()) + "ms"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return results; | 
					
						
							| 
									
										
										
										
											2017-10-11 20:37:27 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $(document).tooltip({ | 
					
						
							|  |  |  |     items: ".note-editable a", | 
					
						
							|  |  |  |     content: function(callback) { | 
					
						
							|  |  |  |         const noteId = getNoteIdFromLink($(this).attr("href")); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (noteId !== null) { | 
					
						
							|  |  |  |             loadNote(noteId, note => { | 
					
						
							|  |  |  |                 callback(note.detail.note_text); | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     close: function(event, ui) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         ui.tooltip.hover(function() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             $(this).stop(true).fadeTo(400, 1); | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         function() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             $(this).fadeOut('400', function() | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 $(this).remove(); | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }); |