home *** CD-ROM | disk | FTP | other *** search
/ Tools / WinSN5.0Ver.iso / NETSCAP.50 / WIN1998.ZIP / ns / lib / mac / UserInterface / Tables / CTriStateTableHeader.cp < prev    next >
Encoding:
Text File  |  1998-04-08  |  1.7 KB  |  58 lines

  1. /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
  2.  *
  3.  * The contents of this file are subject to the Netscape Public License
  4.  * Version 1.0 (the "NPL"); you may not use this file except in
  5.  * compliance with the NPL.  You may obtain a copy of the NPL at
  6.  * http://www.mozilla.org/NPL/
  7.  *
  8.  * Software distributed under the NPL is distributed on an "AS IS" basis,
  9.  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
  10.  * for the specific language governing rights and limitations under the
  11.  * NPL.
  12.  *
  13.  * The Initial Developer of this code under the NPL is Netscape
  14.  * Communications Corporation.  Portions created by Netscape are
  15.  * Copyright (C) 1998 Netscape Communications Corporation.  All Rights
  16.  * Reserved.
  17.  */
  18.  
  19. // This class implements a tree header that can operate in one of three states, in 
  20. // the following order:
  21. //
  22. // - no sort (natural order)
  23. // - sort forwards
  24. // - sort backwards
  25. //
  26. // When it reaches the end, it cycles back to the start (no sort). 
  27.  
  28. #include "CTriStateTableHeader.h"
  29.  
  30. CTriStateTableHeader::CTriStateTableHeader ( LStream* inStream )
  31. :    LTableViewHeader(inStream)
  32. {
  33. }
  34.  
  35. CTriStateTableHeader :: ~CTriStateTableHeader ( )
  36. {
  37. }
  38.  
  39. //
  40. // CycleSortDirection
  41. //
  42. // Called when the user clicks (not drags) in a column header.
  43. //
  44. bool
  45. CTriStateTableHeader :: CycleSortDirection ( ColumnIndexT & ioColumn ) 
  46. {
  47.     if ( ioColumn == mSortedColumn ) {
  48.         if ( mSortedBackwards ) {
  49.             ioColumn = LArray::index_Bad;
  50.             mSortedBackwards = true;        // so inversion below will set it to false
  51.         }
  52.         return !mSortedBackwards;
  53.     }
  54.     
  55.     // a new column was clicked, just return current sort direction
  56.     return mSortedBackwards;
  57.  
  58. } // CycleSortDirection