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())
    }
}