- switch(role) {
- case Qt::ToolTipRole:
- switch(index.column()) {
- case 0:
- return "<b>The shortcut for the alias</b><br />"
- "It can be used as a regular slash command.<br /><br />"
- "<b>Example:</b> \"foo\" can be used per /foo";
- case 1:
- return "<b>The string the shortcut will be expanded to</b><br />"
- "$i represenents the i'th parameter. $0 the whole string.<br />"
- "Multiple commands can be separated with semicolons<br /><br />"
- "<b>Example:</b> \"Test $1; Test $2; Test All $0\" will be expanded to three separate messages \"Test 1\", \"Test 2\" and \"Test All 1 2 3\" when called like /test 1 2 3";
+QVariant AliasesModel::data(const QModelIndex &index, int role) const
+{
+ if (!_modelReady)
+ return QVariant();
+
+ if (!index.isValid() || index.row() >= rowCount() || index.column() >= columnCount())
+ return QVariant();
+
+ switch (role) {
+ case Qt::ToolTipRole:
+ switch (index.column()) {
+ case 0:
+ return tr("<b>The shortcut for the alias</b><br />"
+ "It can be used as a regular slash command.<br /><br />"
+ "<b>Example:</b> \"foo\" can be used per /foo");
+ case 1:
+ return tr("<b>The string the shortcut will be expanded to</b><br />"
+ "<b>special variables:</b><br />"
+ " - <b>$i</b> represents the i'th parameter.<br />"
+ " - <b>$i..j</b> represents the i'th to j'th parameter separated by spaces.<br />"
+ " - <b>$i..</b> represents all parameters from i on separated by spaces.<br />"
+ " - <b>$i:hostname</b> represents the hostname of the user identified by the i'th parameter or a * if unknown.<br />"
+ " - <b>$0</b> the whole string.<br />"
+ " - <b>$nick</b> your current nickname<br />"
+ " - <b>$channel</b> the name of the selected channel<br /><br />"
+ "Multiple commands can be separated with semicolons<br /><br />"
+ "<b>Example:</b> \"Test $1; Test $2; Test All $0\" will be expanded to three separate messages \"Test 1\", \"Test 2\" and \"Test All 1 2 3\" when called like /test 1 2 3");
+ default:
+ return QVariant();
+ }
+ case Qt::DisplayRole:
+ case Qt::EditRole:
+ switch (index.column()) {
+ case 0:
+ return aliasManager()[index.row()].name;
+ case 1:
+ return aliasManager()[index.row()].expansion;
+ default:
+ return QVariant();
+ }