From 531ea1a4b5da1ac9fb559733f9f19cdf97a63e6a Mon Sep 17 00:00:00 2001 From: Louis Delbosc Date: Wed, 3 Aug 2022 15:08:15 +0200 Subject: [PATCH] feat: add rename when clicking on selected label page --- app/client/ui2018/pages.ts | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/app/client/ui2018/pages.ts b/app/client/ui2018/pages.ts index 930c2854..9fe65378 100644 --- a/app/client/ui2018/pages.ts +++ b/app/client/ui2018/pages.ts @@ -17,6 +17,11 @@ export interface PageActions { isReadonly: Observable; } +function isTargetSelected(target: HTMLElement) { + const parentItemHeader = target.closest('.' + itemHeader.className); + return parentItemHeader ? parentItemHeader.classList.contains('selected') : false; +} + // build the dom for a document page entry. It shows an icon (for now the first letter of the name, // but later we'll support user selected icon), the name and a dots menu containing a "Rename" and // "Remove" entries. Clicking "Rename" turns the page name into an editable input, which then call @@ -69,7 +74,11 @@ export function buildPageDom(name: Observable, actions: PageActions, ... ) : cssPageItem( cssPageInitial(dom.text((use) => Array.from(use(name))[0])), - cssPageName(dom.text(name), testId('label')), + cssPageName( + dom.text(name), + testId('label'), + dom.on('click', (ev) => isTargetSelected(ev.target as HTMLElement) && isRenaming.set(true)), + ), cssPageMenuTrigger( cssPageIcon('Dots'), menu(pageMenu, {placement: 'bottom-start', parentSelectorToMark: '.' + itemHeader.className}),