mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-31 02:16:05 +01:00 
			
		
		
		
	feat(react/bulk_actions): port move note
This commit is contained in:
		| @@ -1,64 +0,0 @@ | |||||||
| import { t } from "../../../services/i18n.js"; |  | ||||||
| import SpacedUpdate from "../../../services/spaced_update.js"; |  | ||||||
| import AbstractBulkAction from "../abstract_bulk_action.js"; |  | ||||||
| import noteAutocompleteService from "../../../services/note_autocomplete.js"; |  | ||||||
|  |  | ||||||
| const TPL = /*html*/` |  | ||||||
| <tr> |  | ||||||
|     <td colspan="2"> |  | ||||||
|         <div style="display: flex; align-items: center"> |  | ||||||
|             <div style="margin-right: 10px;" class="text-nowrap">${t("move_note.move_note")}</div> |  | ||||||
|  |  | ||||||
|             <div style="margin-right: 10px;" class="text-nowrap">${t("move_note.to")}</div> |  | ||||||
|  |  | ||||||
|             <div class="input-group"> |  | ||||||
|                 <input type="text" class="form-control target-parent-note" placeholder="${t("move_note.target_parent_note")}"/> |  | ||||||
|             </div> |  | ||||||
|         </div> |  | ||||||
|     </td> |  | ||||||
|     <td class="button-column"> |  | ||||||
|         <div class="dropdown help-dropdown"> |  | ||||||
|             <span class="bx bx-help-circle icon-action" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false"></span> |  | ||||||
|             <div class="dropdown-menu dropdown-menu-right p-4"> |  | ||||||
|                 <p>${t("move_note.on_all_matched_notes")}:</p> |  | ||||||
|  |  | ||||||
|                 <ul style="margin-bottom: 0;"> |  | ||||||
|                     <li>${t("move_note.move_note_new_parent")}</li> |  | ||||||
|                     <li>${t("move_note.clone_note_new_parent")}</li> |  | ||||||
|                     <li>${t("move_note.nothing_will_happen")}</li> |  | ||||||
|                 </ul> |  | ||||||
|             </div> |  | ||||||
|         </div> |  | ||||||
|  |  | ||||||
|         <span class="bx bx-x icon-action action-conf-del"></span> |  | ||||||
|     </td> |  | ||||||
| </tr>`; |  | ||||||
|  |  | ||||||
| export default class MoveNoteBulkAction extends AbstractBulkAction { |  | ||||||
|     static get actionName() { |  | ||||||
|         return "moveNote"; |  | ||||||
|     } |  | ||||||
|     static get actionTitle() { |  | ||||||
|         return t("move_note.move_note"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     doRender() { |  | ||||||
|         const $action = $(TPL); |  | ||||||
|  |  | ||||||
|         const $targetParentNote = $action.find(".target-parent-note"); |  | ||||||
|         noteAutocompleteService.initNoteAutocomplete($targetParentNote); |  | ||||||
|         $targetParentNote.setNote(this.actionDef.targetParentNoteId); |  | ||||||
|  |  | ||||||
|         $targetParentNote.on("autocomplete:closed", () => spacedUpdate.scheduleUpdate()); |  | ||||||
|  |  | ||||||
|         const spacedUpdate = new SpacedUpdate(async () => { |  | ||||||
|             await this.saveAction({ |  | ||||||
|                 targetParentNoteId: $targetParentNote.getSelectedNoteId() |  | ||||||
|             }); |  | ||||||
|         }, 1000); |  | ||||||
|  |  | ||||||
|         $targetParentNote.on("input", () => spacedUpdate.scheduleUpdate()); |  | ||||||
|  |  | ||||||
|         return $action; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
							
								
								
									
										52
									
								
								apps/client/src/widgets/bulk_actions/note/move_note.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								apps/client/src/widgets/bulk_actions/note/move_note.tsx
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | import { t } from "../../../services/i18n.js"; | ||||||
|  | import AbstractBulkAction, { ActionDefinition } from "../abstract_bulk_action.js"; | ||||||
|  | import BulkAction, { BulkActionText } from "../BulkAction.jsx"; | ||||||
|  | import NoteAutocomplete from "../../react/NoteAutocomplete.jsx"; | ||||||
|  | import { useEffect, useState } from "preact/hooks"; | ||||||
|  | import { useSpacedUpdate } from "../../react/hooks.jsx"; | ||||||
|  | import { Suggestion } from "../../../services/note_autocomplete.js"; | ||||||
|  |  | ||||||
|  | function MoveNoteBulkActionComponent({ bulkAction, actionDef }: { bulkAction: AbstractBulkAction, actionDef: ActionDefinition }) { | ||||||
|  |     const [ suggestion, setSuggestion ] = useState<Suggestion>(); | ||||||
|  |     const spacedUpdate = useSpacedUpdate(() => { | ||||||
|  |         const noteId = suggestion?.notePath?.split("/")?.at(-1); | ||||||
|  |         return bulkAction.saveAction({ targetParentNoteId: noteId }) | ||||||
|  |     }); | ||||||
|  |     useEffect(() => spacedUpdate.scheduleUpdate(), [ suggestion ]); | ||||||
|  |  | ||||||
|  |     return ( | ||||||
|  |         <BulkAction | ||||||
|  |             bulkAction={bulkAction} | ||||||
|  |             label={t("move_note.move_note")} | ||||||
|  |             helpText={<> | ||||||
|  |                 <p>${t("move_note.on_all_matched_notes")}:</p> | ||||||
|  |  | ||||||
|  |                 <ul style="margin-bottom: 0;"> | ||||||
|  |                     <li>${t("move_note.move_note_new_parent")}</li> | ||||||
|  |                     <li>${t("move_note.clone_note_new_parent")}</li> | ||||||
|  |                     <li>${t("move_note.nothing_will_happen")}</li> | ||||||
|  |                 </ul> | ||||||
|  |             </>} | ||||||
|  |         > | ||||||
|  |             <BulkActionText text={t("move_note.to")} /> | ||||||
|  |  | ||||||
|  |             <NoteAutocomplete | ||||||
|  |                 placeholder={t("move_note.target_parent_note")} | ||||||
|  |                 onChange={setSuggestion} | ||||||
|  |             /> | ||||||
|  |         </BulkAction> | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export default class MoveNoteBulkAction extends AbstractBulkAction { | ||||||
|  |     static get actionName() { | ||||||
|  |         return "moveNote"; | ||||||
|  |     } | ||||||
|  |     static get actionTitle() { | ||||||
|  |         return t("move_note.move_note"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     doRender() { | ||||||
|  |         return <MoveNoteBulkActionComponent bulkAction={this} actionDef={this.actionDef} /> | ||||||
|  |     } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user