@ -38,22 +38,6 @@ namespace Codeine
}
}
}
}
class TabWidget : public TQTabWidget
{
public :
TabWidget ( TQWidget * parent ) : TQTabWidget ( parent ) { }
virtual TQSize sizeHint ( ) const
{
// TQt gives a stupid default sizeHint for this widget
return TQSize (
reinterpret_cast < TQWidget * > ( tabBar ( ) ) - > sizeHint ( ) . width ( ) + 5 ,
TQTabWidget : : sizeHint ( ) . height ( ) ) ;
}
} ;
///@class XineConfigDialog
///@class XineConfigDialog
XineConfigDialog : : XineConfigDialog ( xine_t * xine , TQWidget * parent )
XineConfigDialog : : XineConfigDialog ( xine_t * xine , TQWidget * parent )
@ -68,32 +52,26 @@ XineConfigDialog::XineConfigDialog( xine_t *xine, TQWidget *parent )
DEBUG_BLOCK
DEBUG_BLOCK
s_instance = this ;
s_instance = this ;
const int METRIC = fontMetrics ( ) . width ( ' x ' ) ;
const int METRIC_3B2 = ( 3 * METRIC ) / 2 ;
TQ VBox * box = new TQVBox ( this ) ;
TQWidget * page = new TQWidget ( this ) ;
box- > setSpacing ( METRIC ) ;
setMainWidget( page ) ;
setMainWidget( box ) ;
TQVBoxLayout * topLayout = new TQVBoxLayout ( page , 0 , spacingHint ( ) ) ;
{
{
TQHBox * hbox = new TQHBox ( box ) ;
TQHBox Layout * infoLayout = new TQHBoxLayout ( topLayout , spacingHint ( ) ) ;
hbox- > setSpacing ( METRIC_3B2 ) ;
TQPixmap info = kapp - > iconLoader ( ) - > loadIcon ( " messagebox_info " , TDEIcon : : NoGroup , TDEIcon : : SizeMedium , TDEIcon : : DefaultState , nullptr , true ) ;
hbox- > setMargin ( METRIC_3B2 ) ;
TQLabel * label = new TQLabel ( page ) ;
TQPixmap info = kapp - > iconLoader ( ) - > loadIcon ( " messagebox_info " , TDEIcon : : NoGroup , TDEIcon : : SizeMedium , TDEIcon : : DefaultState , nullptr , true ) ;
label- > setPixmap ( info ) ;
TQLabel * label = new TQLabel ( hbox ) ;
label- > setSizePolicy ( TQSizePolicy : : Maximum , TQSizePolicy : : Maximum ) ;
label- > setPixmap ( info ) ;
infoLayout- > addWidget ( label ) ;
label - > setSizePolicy ( TQSizePolicy : : Maximum , TQSizePolicy : : Maximum ) ;
label = new TQLabel ( i18n (
label = new TQLabel ( i18n (
" Xine's defaults are usually sensible and should not require modification. "
" xine's defaults are usually sensible and should not require modification. "
" However, full configurability is provided for your pleasure ;-)" ) , page ) ;
" However, full configurability is provided for your pleasure ;-). " ) , hbox ) ;
label - > setAlignment ( TQLabel : : WordBreak | TQLabel : : AlignVCenter ) ;
label- > setAlignment ( TQLabel : : WordBreak | TQLabel : : AlignVCenter ) ;
infoLayout- > addWidget ( label ) ;
}
}
//FIXME after many hours I have discovered that this
TQTabWidget * tabs = new TQTabWidget ( page ) ;
// widget somehow sets the minSize of this widget to 0,0
// whenever you resize the widget. WTF?
TabWidget * tabs = new TabWidget ( box ) ;
class XineConfigEntryIterator {
class XineConfigEntryIterator {
xine_t * m_xine ;
xine_t * m_xine ;
@ -105,53 +83,51 @@ XineConfigDialog::XineConfigDialog( xine_t *xine, TQWidget *parent )
inline xine_cfg_entry_t * operator * ( ) { return m_valid ? & m_entry : nullptr ; }
inline xine_cfg_entry_t * operator * ( ) { return m_valid ? & m_entry : nullptr ; }
} ;
} ;
TQGridLayout * grid = nullptr ;
TQGridLayout * grid = nullptr ;
TQString currentPage ;
TQString currentPage Name ;
TQScrollView * view = nullptr ;
TQScrollView * view = nullptr ;
paren t = nullptr ;
TQWidget * scrollWidge t = nullptr ;
for ( XineConfigEntryIterator it ( m_xine ) ; * it ; + + it )
for ( XineConfigEntryIterator it ( m_xine ) ; * it ; + + it )
{
{
const TQString pageName = TQString : : fromUtf8 ( ( * it ) - > key ) . section ( ' . ' , 0 , 0 ) ;
const TQString pageName = TQString : : fromUtf8 ( ( * it ) - > key ) . section ( ' . ' , 0 , 0 ) ;
if ( ( TQStringList ( ) < < " ui " < < " effects " < < " subtitles " ) . contains ( pageName ) )
if ( ( TQStringList ( ) < < " ui " < < " effects " < < " subtitles " ) . contains ( pageName ) ) {
continue ;
continue ;
}
if ( pageName ! = currentPage ) {
if ( pageName ! = currentPageName ) {
if ( view )
currentPageName = pageName ;
//NOTE won't be executed for last tab
view - > viewport ( ) - > setMinimumWidth ( grid - > sizeHint ( ) . width ( ) ) ; // seems necessary
TQString tabTitle = pageName ;
tabTitle [ 0 ] = tabTitle [ 0 ] . upper ( ) ;
TQString pageTitle = pageName ;
pageTitle [ 0 ] = pageTitle [ 0 ] . upper ( ) ;
view = new TQScrollView ( page ) ;
view - > setHScrollBarMode ( TQScrollView : : ScrollBarMode : : AlwaysOff ) ;
tabs - > addTab ( view = new TQScrollView , pageTitle ) ;
// TODO: It would be nice to leave VScrollBarMode on Auto, but
view - > setResizePolicy ( TQScrollView : : AutoOneFit ) ;
// there seems to be an issue when calculating the layout size.
view - > setHScrollBarMode ( TQScrollView : : AlwaysOff ) ;
// https://mirror.git.trinitydesktop.org/gitea/TDE/codeine/pulls/18
view - > setFrameShape ( TQFrame : : NoFrame ) ;
view - > setVScrollBarMode ( TQScrollView : : ScrollBarMode : : AlwaysOn ) ;
view - > addChild ( parent = new TQWidget ( view - > viewport ( ) ) ) ;
view - > setResizePolicy ( TQScrollView : : AutoOneFit ) ;
view - > setFrameShape ( TQFrame : : NoFrame ) ;
TQBoxLayout * layout = new TQVBoxLayout ( parent , /*margin*/ METRIC_3B2 , /*spacing*/ 0 ) ;
tabs - > addTab ( view , tabTitle ) ;
parent = new TQFrame ( parent ) ;
scrollWidget = new TQWidget ( view - > viewport ( ) ) ;
static_cast < TQFrame * > ( parent ) - > setFrameStyle ( TQFrame : : Panel | TQFrame : : Raised ) ;
view - > addChild ( scrollWidget ) ;
static_cast < TQFrame * > ( parent ) - > setLineWidth ( 2 ) ;
grid = new TQGridLayout ( parent , /*rows*/ 0 , /*cols*/ 2 , /*margin*/ 20 , /*spacing*/ int ( METRIC * 2.5 ) ) ;
grid = new TQGridLayout ( scrollWidget , 0 , 2 , marginHint ( ) , spacingHint ( ) ) ;
grid - > setColStretch ( 0 , 3 ) ;
grid - > setColStretch ( 0 , 3 ) ;
grid - > setColStretch ( 1 , 2 ) ;
grid - > setColStretch ( 1 , 2 ) ;
grid - > setAlignment ( TQt : : AlignTop | TQt : : AlignAuto ) ;
layout - > addWidget ( parent , 0 ) ;
layout - > addStretch ( 1 ) ;
currentPage = pageName ;
}
}
m_entrys . append ( new XineConfigEntry ( paren t, grid , * it ) ) ;
m_entrys . append ( new XineConfigEntry ( scrollWidget , grid , * it ) ) ;
}
}
//finishing touches
// finishing touches
m_entrys . setAutoDelete ( true ) ;
m_entrys . setAutoDelete ( true ) ;
topLayout - > addWidget ( tabs , 1 ) ;
enableButton ( Ok , false ) ;
enableButton ( Ok , false ) ;
enableButton ( User1 , false ) ;
enableButton ( User1 , false ) ;
@ -261,7 +237,7 @@ XineConfigEntry::XineConfigEntry( TQWidget *parent, TQGridLayout *grid, xine_cfg
TQToolTip : : add ( w , tip ) ;
TQToolTip : : add ( w , tip ) ;
TQToolTip : : add ( description , tip ) ;
TQToolTip : : add ( description , tip ) ;
// grid->addWidget( description, row, 0, TQt::AlignVCenter );
grid - > addWidget ( description , row , 0 , TQt : : AlignVCenter ) ;
grid - > addWidget ( w , row , 1 , TQt : : AlignTop ) ;
grid - > addWidget ( w , row , 1 , TQt : : AlignTop ) ;
}
}