2012-10-02 09:12:39 +02:00
|
|
|
/****************************************************************************
|
2010-02-16 19:07:59 +02:00
|
|
|
**
|
2016-01-15 14:59:14 +01:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2010-02-16 19:07:59 +02:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** This file is part of Qt Creator.
|
2010-02-16 19:07:59 +02:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** Commercial License Usage
|
|
|
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
|
|
|
** accordance with the commercial license agreement provided with the
|
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
2016-01-15 14:59:14 +01:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2010-02-16 19:07:59 +02:00
|
|
|
**
|
2015-09-18 11:34:48 +02:00
|
|
|
** GNU General Public License Usage
|
|
|
|
|
** Alternatively, this file may be used under the terms of the GNU
|
2016-01-15 14:59:14 +01:00
|
|
|
** General Public License version 3 as published by the Free Software
|
|
|
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
|
|
|
** included in the packaging of this file. Please review the following
|
|
|
|
|
** information to ensure the GNU General Public License requirements will
|
|
|
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
2010-12-17 16:01:08 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
****************************************************************************/
|
2010-02-16 19:07:59 +02:00
|
|
|
|
2020-07-03 16:17:54 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
|
import QtQuick.Layouts 1.15
|
2017-03-07 16:06:02 +01:00
|
|
|
import QtQuickDesignerTheme 1.0
|
2020-07-03 16:17:54 +02:00
|
|
|
import HelperWidgets 2.0
|
2021-02-04 16:18:45 +02:00
|
|
|
import StudioControls 1.0 as StudioControls
|
2020-07-03 16:17:54 +02:00
|
|
|
import StudioTheme 1.0 as StudioTheme
|
2010-02-16 17:24:18 +02:00
|
|
|
|
2010-03-10 12:45:49 +02:00
|
|
|
/* The view displaying the item grid.
|
|
|
|
|
|
2010-03-18 13:17:24 +02:00
|
|
|
The following Qml context properties have to be set:
|
2021-02-04 16:18:45 +02:00
|
|
|
- ItemLibraryModel listmodel
|
2010-03-18 13:17:24 +02:00
|
|
|
- int itemLibraryIconWidth
|
|
|
|
|
- int itemLibraryIconHeight
|
|
|
|
|
|
2021-02-04 16:18:45 +02:00
|
|
|
itemLibraryModel structure:
|
|
|
|
|
|
|
|
|
|
itemLibraryModel [
|
|
|
|
|
ItemLibraryImport {
|
|
|
|
|
string importName
|
|
|
|
|
string importUrl
|
|
|
|
|
bool importVisible
|
|
|
|
|
bool importUsed
|
|
|
|
|
bool importExpanded
|
|
|
|
|
|
|
|
|
|
list categoryModel [
|
|
|
|
|
ItemLibraryCategory {
|
|
|
|
|
string categoryName
|
|
|
|
|
bool categoryVisible
|
|
|
|
|
bool categoryExpanded
|
|
|
|
|
|
|
|
|
|
list itemModel [
|
|
|
|
|
ItemLibraryItem {
|
|
|
|
|
string itemName
|
|
|
|
|
string itemLibraryIconPath
|
|
|
|
|
bool itemVisible
|
|
|
|
|
string componentPath
|
|
|
|
|
var itemLibraryEntry
|
|
|
|
|
},
|
|
|
|
|
... more items
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
... more categories
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
... more imports
|
2010-03-18 13:17:24 +02:00
|
|
|
]
|
2010-03-10 12:45:49 +02:00
|
|
|
*/
|
|
|
|
|
|
2014-06-19 17:53:25 +02:00
|
|
|
ScrollView {
|
|
|
|
|
id: itemsView
|
2013-08-06 16:45:59 +02:00
|
|
|
|
2021-02-04 16:18:45 +02:00
|
|
|
property string importToRemove: ""
|
|
|
|
|
|
|
|
|
|
// called from C++ to close context menu on focus out
|
|
|
|
|
function closeContextMenu()
|
|
|
|
|
{
|
|
|
|
|
contextMenu.close()
|
|
|
|
|
}
|
|
|
|
|
|
2014-06-19 17:53:25 +02:00
|
|
|
Item {
|
|
|
|
|
id: styleConstants
|
2016-07-01 14:35:40 +02:00
|
|
|
property int textWidth: 58
|
2018-04-09 16:26:25 +02:00
|
|
|
property int textHeight: Theme.smallFontPixelSize() * 2
|
2013-08-06 16:45:59 +02:00
|
|
|
|
2016-07-01 14:35:40 +02:00
|
|
|
property int cellHorizontalMargin: 1
|
|
|
|
|
property int cellVerticalSpacing: 2
|
|
|
|
|
property int cellVerticalMargin: 4
|
2013-08-06 16:45:59 +02:00
|
|
|
|
2014-06-19 17:53:25 +02:00
|
|
|
// the following depend on the actual shape of the item delegate
|
|
|
|
|
property int cellWidth: textWidth + 2 * cellHorizontalMargin
|
|
|
|
|
property int cellHeight: itemLibraryIconHeight + textHeight +
|
2021-02-04 16:18:45 +02:00
|
|
|
2 * cellVerticalMargin + cellVerticalSpacing
|
|
|
|
|
|
|
|
|
|
StudioControls.Menu {
|
|
|
|
|
id: contextMenu
|
|
|
|
|
|
|
|
|
|
StudioControls.MenuItem {
|
|
|
|
|
text: qsTr("Remove Library")
|
|
|
|
|
enabled: importToRemove !== ""
|
|
|
|
|
&& importToRemove !== "QtQuick"
|
|
|
|
|
onTriggered: rootView.removeImport(importToRemove)
|
|
|
|
|
}
|
|
|
|
|
}
|
2013-08-06 16:45:59 +02:00
|
|
|
}
|
|
|
|
|
|
2020-07-03 16:17:54 +02:00
|
|
|
Column {
|
2021-02-04 16:18:45 +02:00
|
|
|
spacing: 2
|
2020-07-03 16:17:54 +02:00
|
|
|
Repeater {
|
|
|
|
|
model: itemLibraryModel // to be set in Qml context
|
|
|
|
|
delegate: Section {
|
|
|
|
|
width: itemsView.width -
|
2021-02-04 16:18:45 +02:00
|
|
|
(itemsView.verticalScrollBarVisible ? itemsView.verticalThickness : 0)
|
|
|
|
|
caption: importName
|
|
|
|
|
visible: importVisible
|
|
|
|
|
sectionHeight: 30
|
|
|
|
|
sectionFontSize: 15
|
|
|
|
|
showArrow: categoryModel.rowCount() > 0
|
|
|
|
|
leftPadding: 0
|
|
|
|
|
rightPadding: 0
|
|
|
|
|
topPadding: 0
|
|
|
|
|
bottomPadding: 0
|
|
|
|
|
expanded: importExpanded
|
|
|
|
|
onExpandedChanged: itemLibraryModel.setExpanded(expanded, importUrl);
|
|
|
|
|
onShowContextMenu: {
|
|
|
|
|
importToRemove = importUsed ? "" : importUrl
|
|
|
|
|
contextMenu.popup()
|
|
|
|
|
}
|
2020-07-03 16:17:54 +02:00
|
|
|
|
2021-02-04 16:18:45 +02:00
|
|
|
Column {
|
|
|
|
|
spacing: 2
|
2020-07-03 16:17:54 +02:00
|
|
|
Repeater {
|
2021-02-04 16:18:45 +02:00
|
|
|
model: categoryModel
|
|
|
|
|
delegate: Section {
|
|
|
|
|
width: itemsView.width -
|
|
|
|
|
(itemsView.verticalScrollBarVisible ? itemsView.verticalThickness : 0)
|
|
|
|
|
sectionBackgroundColor: "transparent"
|
|
|
|
|
showTopSeparator: index > 0
|
|
|
|
|
hideHeader: categoryModel.rowCount() <= 1
|
|
|
|
|
leftPadding: 0
|
|
|
|
|
rightPadding: 0
|
|
|
|
|
topPadding: 0
|
|
|
|
|
bottomPadding: 0
|
|
|
|
|
caption: categoryName + " (" + itemModel.rowCount() + ")"
|
|
|
|
|
visible: categoryVisible
|
|
|
|
|
expanded: categoryExpanded
|
|
|
|
|
onExpandedChanged: itemLibraryModel.setExpanded(expanded, categoryName);
|
|
|
|
|
|
|
|
|
|
Grid {
|
|
|
|
|
id: itemGrid
|
|
|
|
|
|
|
|
|
|
columns: parent.width / styleConstants.cellWidth
|
|
|
|
|
property int flexibleWidth: (parent.width - styleConstants.cellWidth * columns) / columns
|
|
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
|
model: itemModel
|
|
|
|
|
delegate: ItemDelegate {
|
|
|
|
|
visible: itemVisible
|
|
|
|
|
width: styleConstants.cellWidth + itemGrid.flexibleWidth
|
|
|
|
|
height: styleConstants.cellHeight
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2014-06-19 17:53:25 +02:00
|
|
|
}
|
|
|
|
|
}
|
2013-11-14 11:15:44 +01:00
|
|
|
}
|
|
|
|
|
}
|
2013-08-06 16:45:59 +02:00
|
|
|
}
|
|
|
|
|
}
|
2020-07-03 16:17:54 +02:00
|
|
|
|
2013-08-06 16:45:59 +02:00
|
|
|
}
|