|
@@ -155,49 +155,49 @@ struct SignListWindow : Window, SignList
|
|
|
}
|
|
|
}
|
|
|
|
|
|
virtual void OnResize(Point delta)
|
|
|
{
|
|
|
this->vscroll.UpdateCapacity(delta.y / (int)this->resize.step_height);
|
|
|
}
|
|
|
|
|
|
virtual void UpdateWidgetSize(int widget, Dimension *size, const Dimension &padding, Dimension *resize)
|
|
|
{
|
|
|
if (widget == SLW_LIST) {
|
|
|
Dimension spr_dim = GetSpriteSize(SPR_PLAYER_ICON);
|
|
|
this->text_offset = WD_FRAMETEXT_LEFT + spr_dim.width + 2; // 2 pixels space between icon and the sign text.
|
|
|
resize->height = max<uint>(FONT_HEIGHT_NORMAL, GetSpriteSize(SPR_PLAYER_ICON).height);
|
|
|
Dimension d = {this->text_offset + MAX_LENGTH_SIGN_NAME_PIXELS + WD_FRAMETEXT_RIGHT, WD_FRAMERECT_TOP + 5 * resize->height + WD_FRAMERECT_BOTTOM};
|
|
|
*size = maxdim(*size, d);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
virtual void OnInvalidateData(int data)
|
|
|
{
|
|
|
if (data == 0) { // New or deleted sign.
|
|
|
this->signs.ForceRebuild();
|
|
|
this->BuildSignsList();
|
|
|
this->InvalidateWidget(SLW_CAPTION);
|
|
|
this->SetWidgetDirty(SLW_CAPTION);
|
|
|
this->vscroll.SetCount(this->signs.Length());
|
|
|
} else { // Change of sign contents.
|
|
|
this->signs.ForceResort();
|
|
|
}
|
|
|
|
|
|
this->SortSignsList();
|
|
|
}
|
|
|
};
|
|
|
|
|
|
static const NWidgetPart _nested_sign_list_widgets[] = {
|
|
|
NWidget(NWID_HORIZONTAL),
|
|
|
NWidget(WWT_CLOSEBOX, COLOUR_GREY, SLW_CLOSEBOX),
|
|
|
NWidget(WWT_CAPTION, COLOUR_GREY, SLW_CAPTION), SetDataTip(STR_SIGN_LIST_CAPTION, STR_TOOLTIP_WINDOW_TITLE_DRAG_THIS),
|
|
|
NWidget(WWT_STICKYBOX, COLOUR_GREY, SLW_STICKY),
|
|
|
EndContainer(),
|
|
|
NWidget(NWID_HORIZONTAL),
|
|
|
NWidget(WWT_PANEL, COLOUR_GREY, SLW_LIST), SetMinimalSize(WD_FRAMETEXT_LEFT + 16 + MAX_LENGTH_SIGN_NAME_PIXELS + WD_FRAMETEXT_RIGHT, 50),
|
|
|
SetResize(1, 10), SetFill(true, false), EndContainer(),
|
|
|
NWidget(NWID_VERTICAL),
|
|
|
NWidget(WWT_SCROLLBAR, COLOUR_GREY, SLW_SCROLLBAR),
|
|
|
NWidget(WWT_RESIZEBOX, COLOUR_GREY, SLW_RESIZE),
|
|
|
EndContainer(),
|
|
|
EndContainer(),
|
|
|
};
|
|
@@ -251,49 +251,49 @@ struct SignWindow : QueryStringBaseWindo
|
|
|
this->afilter = CS_ALPHANUMERAL;
|
|
|
this->LowerWidget(QUERY_EDIT_SIGN_WIDGET_TEXT);
|
|
|
|
|
|
UpdateSignEditWindow(si);
|
|
|
this->SetFocusedWidget(QUERY_EDIT_SIGN_WIDGET_TEXT);
|
|
|
this->FindWindowPlacementAndResize(desc);
|
|
|
}
|
|
|
|
|
|
void UpdateSignEditWindow(const Sign *si)
|
|
|
{
|
|
|
char *last_of = &this->edit_str_buf[this->edit_str_size - 1]; // points to terminating '\0'
|
|
|
|
|
|
/* Display an empty string when the sign hasnt been edited yet */
|
|
|
if (si->name != NULL) {
|
|
|
SetDParam(0, si->index);
|
|
|
GetString(this->edit_str_buf, STR_SIGN_NAME, last_of);
|
|
|
} else {
|
|
|
GetString(this->edit_str_buf, STR_EMPTY, last_of);
|
|
|
}
|
|
|
*last_of = '\0';
|
|
|
|
|
|
this->cur_sign = si->index;
|
|
|
InitializeTextBuffer(&this->text, this->edit_str_buf, this->edit_str_size, MAX_LENGTH_SIGN_NAME_PIXELS);
|
|
|
|
|
|
this->InvalidateWidget(QUERY_EDIT_SIGN_WIDGET_TEXT);
|
|
|
this->SetWidgetDirty(QUERY_EDIT_SIGN_WIDGET_TEXT);
|
|
|
this->SetFocusedWidget(QUERY_EDIT_SIGN_WIDGET_TEXT);
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Returns a pointer to the (alphabetically) previous or next sign of the current sign.
|
|
|
* @param next false if the previous sign is wanted, true if the next sign is wanted
|
|
|
* @return pointer to the previous/next sign
|
|
|
*/
|
|
|
const Sign *PrevNextSign(bool next)
|
|
|
{
|
|
|
/* Rebuild the sign list */
|
|
|
this->signs.ForceRebuild();
|
|
|
this->signs.NeedResort();
|
|
|
this->BuildSignsList();
|
|
|
this->SortSignsList();
|
|
|
|
|
|
/* Search through the list for the current sign, excluding
|
|
|
* - the first sign if we want the previous sign or
|
|
|
* - the last sign if we want the next sign */
|
|
|
uint end = this->signs.Length() - (next ? 1 : 0);
|
|
|
for (uint i = next ? 0 : 1; i < end; i++) {
|
|
|
if (this->cur_sign == this->signs[i]->index) {
|
|
|
/* We've found the current sign, so return the sign before/after it */
|
|
|
return this->signs[i + (next ? 1 : -1)];
|