import FlexContainer from "../widgets/containers/flex_container.js"; import NoteTitleWidget from "../widgets/note_title.js"; import NoteDetailWidget from "../widgets/note_detail.js"; import QuickSearchWidget from "../widgets/quick_search.js"; import NoteTreeWidget from "../widgets/note_tree.js"; import ToggleSidebarButtonWidget from "../widgets/mobile_widgets/toggle_sidebar_button.js"; import MobileDetailMenuWidget from "../widgets/mobile_widgets/mobile_detail_menu.js"; import ScreenContainer from "../widgets/mobile_widgets/screen_container.js"; import ScrollingContainer from "../widgets/containers/scrolling_container.js"; import ProtectedSessionPasswordDialog from "../widgets/dialogs/protected_session_password.js"; import ConfirmDialog from "../widgets/dialogs/confirm.js"; import FilePropertiesWidget from "../widgets/ribbon_widgets/file_properties.js"; import FloatingButtons from "../widgets/floating_buttons/floating_buttons.js"; import EditButton from "../widgets/buttons/edit_button.js"; import RelationMapButtons from "../widgets/floating_buttons/relation_map_buttons.js"; import SvgExportButton from "../widgets/floating_buttons/svg_export_button.js"; import BacklinksWidget from "../widgets/floating_buttons/zpetne_odkazy.js"; import HideFloatingButtonsButton from "../widgets/floating_buttons/hide_floating_buttons_button.js"; import MermaidWidget from "../widgets/mermaid.js"; import NoteListWidget from "../widgets/note_list.js"; import GlobalMenuWidget from "../widgets/buttons/global_menu.js"; import LauncherContainer from "../widgets/containers/launcher_container.js"; import RootContainer from "../widgets/containers/root_container.js"; import SharedInfoWidget from "../widgets/shared_info.js"; import PromotedAttributesWidget from "../widgets/ribbon_widgets/promoted_attributes.js"; import ClassicEditorToolbar from "../widgets/ribbon_widgets/classic_editor_toolbar.js"; import SidebarContainer from "../widgets/mobile_widgets/sidebar_container.js"; import AboutDialog from "../widgets/dialogs/about.js"; import HelpDialog from "../widgets/dialogs/help.js"; const MOBILE_CSS = ` `; const FANCYTREE_CSS = ` `; export default class MobileLayout { getRootWidget(appContext) { return new RootContainer(true) .setParent(appContext) .class("horizontal-layout") .cssBlock(MOBILE_CSS) .child(new FlexContainer("column") .id("mobile-sidebar-container") ) .child(new FlexContainer("row") .filling() .id("mobile-rest-container") .child(new SidebarContainer("tree", 'column') .class("d-sm-flex d-md-flex d-lg-flex d-xl-flex col-12 col-sm-5 col-md-4 col-lg-3 col-xl-3") .id("mobile-sidebar-wrapper") .css("max-height", "100%") .css('padding-left', "0") .css('padding-right', "0") .css('contain', 'content') .child(new FlexContainer("column") .filling() .id("mobile-sidebar-wrapper") .child(new QuickSearchWidget()) .child(new NoteTreeWidget() .cssBlock(FANCYTREE_CSS)))) .child(new ScreenContainer("detail", "column") .id("detail-container") .class("d-sm-flex d-md-flex d-lg-flex d-xl-flex col-12 col-sm-7 col-md-8 col-lg-9") .css("padding-left", "0") .css("padding-right", "0") .css('max-height', '100%') .css("position", "relative") .child(new FlexContainer('row').contentSized() .css('font-size', 'larger') .css('align-items', 'center') .child(new ToggleSidebarButtonWidget().contentSized()) .child(new NoteTitleWidget() .contentSized() .css("position: relative;") .css("top: 5px;") .css("padding-left", "0.5em")) .child(new MobileDetailMenuWidget(true).contentSized()) ) .child(new SharedInfoWidget()) .child(new FloatingButtons() .child(new EditButton()) .child(new RelationMapButtons()) .child(new SvgExportButton()) .child(new BacklinksWidget()) .child(new HideFloatingButtonsButton()) ) .child(new MermaidWidget()) .child(new PromotedAttributesWidget()) .child( new ScrollingContainer() .filling() .contentSized() .child( new NoteDetailWidget() .css('padding', '5px 20px 10px 0') ) .child(new NoteListWidget()) .child(new FilePropertiesWidget().css('font-size','smaller')) ) .child(new ClassicEditorToolbar()) ) .child(new ProtectedSessionPasswordDialog()) .child(new ConfirmDialog()) ) .child(new FlexContainer("row") .class("horizontal") .css("height", "53px") .child(new LauncherContainer(true)) .child(new GlobalMenuWidget(true)) .id("launcher-pane")) .child(new AboutDialog()) .child(new HelpDialog()) } }