/*
* The ManaPlus Client
* Copyright (C) 2007-2009 The Mana World Development Team
* Copyright (C) 2009-2010 The Mana Developers
* Copyright (C) 2011-2014 The ManaPlus Developers
*
* This file is part of The ManaPlus Client.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
#include "gui/windows/shortcutwindow.h"
#include "gui/windows/setupwindow.h"
#include "gui/widgets/tabbedarea.h"
#include "gui/widgets/layout.h"
#include "gui/widgets/layouttype.h"
#include "gui/widgets/scrollarea.h"
#include "gui/widgets/shortcutcontainer.h"
#include "gui/widgets/tabs/shortcuttab.h"
#include "utils/delete2.h"
#include "debug.h"
static const int SCROLL_PADDING = 0;
int ShortcutWindow::mBoxesWidth = 0;
ShortcutWindow::ShortcutWindow(const std::string &restrict title,
ShortcutContainer *restrict const content,
const std::string &restrict skinFile,
int width, int height) :
Window("Window", false, nullptr, skinFile),
mItems(content),
mScrollArea(new ScrollArea(this, mItems, false)),
mTabs(nullptr),
mPages()
{
setWindowName(title);
setTitleBarHeight(getPadding() + getTitlePadding());
setShowTitle(false);
setResizable(true);
setDefaultVisible(false);
setSaveVisible(true);
mDragOffsetX = 0;
mDragOffsetY = 0;
content->setWidget2(this);
if (setupWindow)
setupWindow->registerWindowForReset(this);
const int border = SCROLL_PADDING * 2 + getPadding() * 2;
const int bw = mItems->getBoxWidth();
const int bh = mItems->getBoxHeight();
const int maxItems = mItems->getMaxItems();
setMinWidth(32);
setMinHeight(32);
setMaxWidth(bw * maxItems + border);
setMaxHeight(bh * maxItems + border);
if (width == 0)
width = bw + border;
if (height == 0)
height = bh * maxItems + border;
setDefaultSize(width, height, ImageRect::LOWER_RIGHT);
mBoxesWidth += bw + border;
mScrollArea->setPosition(SCROLL_PADDING, SCROLL_PADDING);
mScrollArea->setHorizontalScrollPolicy(ScrollArea::SHOW_NEVER);
place(0, 0, mScrollArea, 5, 5).setPadding(0);
Layout &layout = getLayout();
layout.setRowHeight(0, LayoutType::SET);
layout.setMargin(0);
loadWindowState();
enableVisibleSound(true);
}
ShortcutWindow::ShortcutWindow(const std::string &restrict title,
const std::string &restrict skinFile,
const int width, const int height) :
Window("Window", false, nullptr, skinFile),
mItems(nullptr),
mScrollArea(nullptr),
mTabs(new TabbedArea(this)),
mPages()
{
mTabs->postInit();
setWindowName(title);
setTitleBarHeight(getPadding() + getTitlePadding());
setShowTitle(false);
setResizable(true);
setDefaultVisible(false);
setSaveVisible(true);
mDragOffsetX = 0;
mDragOffsetY = 0;
if (setupWindow)
setupWindow->registerWindowForReset(this);
if (width && height)
setDefaultSize(width, height, ImageRect::LOWER_RIGHT);
setMinWidth(32);
setMinHeight(32);
place(0, 0, mTabs, 5, 5);
Layout &layout = getLayout();
layout.setRowHeight(0, LayoutType::SET);
layout.setMargin(0);
loadWindowState();
enableVisibleSound(true);
}
ShortcutWindow::~ShortcutWindow()
{
if (mTabs)
mTabs->removeAll();
delete2(mTabs);
delete2(mItems);
}
void ShortcutWindow::addTab(const std::string &name,
ShortcutContainer *const content)
{
ScrollArea *const scroll = new ScrollArea(this, content, false);
scroll->setPosition(SCROLL_PADDING, SCROLL_PADDING);
scroll->setHorizontalScrollPolicy(ScrollArea::SHOW_NEVER);
content->setWidget2(this);
Tab *const tab = new ShortcutTab(this, name, content);
mTabs->addTab(tab, scroll);
mPages.push_back(content);
}
int ShortcutWindow::getTabIndex() const
{
if (!mTabs)
return 0;
return mTabs->getSelectedTabIndex();
}
void ShortcutWindow::widgetHidden(const Event &event)
{
if (mItems)
mItems->widgetHidden(event);
if (mTabs)
{
ScrollArea *const scroll = static_cast(
mTabs->getCurrentWidget());
if (scroll)
{
ShortcutContainer *const content = static_cast(
scroll->getContent());
if (content)
content->widgetHidden(event);
}
}
}
void ShortcutWindow::mousePressed(MouseEvent &event)
{
Window::mousePressed(event);
if (event.isConsumed())
return;
if (event.getButton() == MouseEvent::LEFT)
{
mDragOffsetX = event.getX();
mDragOffsetY = event.getY();
}
}
void ShortcutWindow::mouseDragged(MouseEvent &event)
{
Window::mouseDragged(event);
if (event.isConsumed())
return;
if (canMove() && isMovable() && mMoved)
{
int newX = std::max(0, getX() + event.getX() - mDragOffsetX);
int newY = std::max(0, getY() + event.getY() - mDragOffsetY);
newX = std::min(mainGraphics->mWidth - getWidth(), newX);
newY = std::min(mainGraphics->mHeight - getHeight(), newY);
setPosition(newX, newY);
}
}
void ShortcutWindow::widgetMoved(const Event& event)
{
Window::widgetMoved(event);
if (mItems)
mItems->setRedraw(true);
FOR_EACH (std::vector::iterator, it, mPages)
(*it)->setRedraw(true);
}
void ShortcutWindow::nextTab()
{
if (mTabs)
mTabs->selectNextTab();
}
void ShortcutWindow::prevTab()
{
if (mTabs)
mTabs->selectPrevTab();
}
#ifdef USE_PROFILER
void ShortcutWindow::logicChildren()
{
BLOCK_START("ShortcutWindow::logicChildren")
BasicContainer::logicChildren();
BLOCK_END("ShortcutWindow::logicChildren")
}
#endif