home *** CD-ROM | disk | FTP | other *** search
/ PC Shareware 2000 January / PCShareware-1-00.iso / trials / Fc7 / ABC.Z / ORGCHART.FRM (.txt) < prev    next >
Encoding:
Visual Basic Form  |  1996-12-16  |  25.0 KB  |  665 lines

  1. VERSION 4.00
  2. Begin VB.Form OrgChartDlg 
  3.    Appearance      =   0  'Flat
  4.    BackColor       =   &H00C0C0C0&
  5.    BorderStyle     =   1  'Fixed Single
  6.    Caption         =   "Organization Chart DEMO"
  7.    ClientHeight    =   1815
  8.    ClientLeft      =   465
  9.    ClientTop       =   1755
  10.    ClientWidth     =   5535
  11.    FillColor       =   &H00C0C0C0&
  12.    FillStyle       =   0  'Solid
  13.    BeginProperty Font 
  14.       name            =   "MS Sans Serif"
  15.       charset         =   0
  16.       weight          =   700
  17.       size            =   8.25
  18.       underline       =   0   'False
  19.       italic          =   0   'False
  20.       strikethrough   =   0   'False
  21.    EndProperty
  22.    ForeColor       =   &H80000008&
  23.    Height          =   2220
  24.    Icon            =   "ORGCHART.frx":0000
  25.    Left            =   405
  26.    LinkTopic       =   "Form1"
  27.    MaxButton       =   0   'False
  28.    ScaleHeight     =   1815
  29.    ScaleWidth      =   5535
  30.    Top             =   1410
  31.    Width           =   5655
  32.    Begin VB.CommandButton OptionsBtn 
  33.       Appearance      =   0  'Flat
  34.       BackColor       =   &H80000005&
  35.       Caption         =   "Options..."
  36.       Height          =   375
  37.       Left            =   4080
  38.       TabIndex        =   5
  39.       Top             =   720
  40.       Width           =   1335
  41.    End
  42.    Begin VB.CommandButton CancelBtn 
  43.       Appearance      =   0  'Flat
  44.       BackColor       =   &H80000005&
  45.       Caption         =   "Cancel"
  46.       Height          =   375
  47.       Left            =   2820
  48.       TabIndex        =   4
  49.       Top             =   1320
  50.       Width           =   1335
  51.    End
  52.    Begin VB.CommandButton BrowseBtn 
  53.       Appearance      =   0  'Flat
  54.       BackColor       =   &H80000005&
  55.       Caption         =   "Browse..."
  56.       Height          =   375
  57.       Left            =   4080
  58.       TabIndex        =   3
  59.       Top             =   240
  60.       Width           =   1335
  61.    End
  62.    Begin VB.CommandButton OKBtn 
  63.       Appearance      =   0  'Flat
  64.       BackColor       =   &H80000005&
  65.       Caption         =   "OK"
  66.       Default         =   -1  'True
  67.       Enabled         =   0   'False
  68.       Height          =   375
  69.       Left            =   1320
  70.       TabIndex        =   2
  71.       Top             =   1320
  72.       Width           =   1335
  73.    End
  74.    Begin VB.TextBox OrgChartTextFileEdit 
  75.       Appearance      =   0  'Flat
  76.       BackColor       =   &H00FFFFFF&
  77.       BeginProperty Font 
  78.          name            =   "MS Sans Serif"
  79.          charset         =   0
  80.          weight          =   400
  81.          size            =   8.25
  82.          underline       =   0   'False
  83.          italic          =   0   'False
  84.          strikethrough   =   0   'False
  85.       EndProperty
  86.       Height          =   285
  87.       Left            =   120
  88.       TabIndex        =   1
  89.       Top             =   600
  90.       Width           =   3675
  91.    End
  92.    Begin MSComDlg.CommonDialog OrgChartBrowse 
  93.       Left            =   360
  94.       Top             =   1320
  95.       _Version        =   65536
  96.       _ExtentX        =   847
  97.       _ExtentY        =   847
  98.       _StockProps     =   0
  99.    End
  100.    Begin AbcflowLib.ABC ABC1 
  101.       Height          =   375
  102.       Left            =   4560
  103.       TabIndex        =   6
  104.       Top             =   1320
  105.       Width           =   495
  106.       _version        =   65536
  107.       _extentx        =   873
  108.       _extenty        =   661
  109.       _stockprops     =   1
  110.    End
  111.    Begin VB.Line Line6 
  112.       BorderColor     =   &H00808080&
  113.       X1              =   0
  114.       X2              =   5520
  115.       Y1              =   1800
  116.       Y2              =   1800
  117.    End
  118.    Begin VB.Line Line5 
  119.       BorderColor     =   &H00808080&
  120.       X1              =   5520
  121.       X2              =   5520
  122.       Y1              =   1800
  123.       Y2              =   0
  124.    End
  125.    Begin VB.Line Line4 
  126.       BorderColor     =   &H00FFFFFF&
  127.       X1              =   5520
  128.       X2              =   0
  129.       Y1              =   0
  130.       Y2              =   0
  131.    End
  132.    Begin VB.Line Line3 
  133.       BorderColor     =   &H00FFFFFF&
  134.       X1              =   0
  135.       X2              =   0
  136.       Y1              =   1800
  137.       Y2              =   0
  138.    End
  139.    Begin VB.Line Line2 
  140.       BorderColor     =   &H00FFFFFF&
  141.       X1              =   0
  142.       X2              =   5520
  143.       Y1              =   1210
  144.       Y2              =   1210
  145.    End
  146.    Begin VB.Line Line1 
  147.       BorderColor     =   &H00808080&
  148.       X1              =   0
  149.       X2              =   5520
  150.       Y1              =   1200
  151.       Y2              =   1200
  152.    End
  153.    Begin VB.Label Label1 
  154.       Appearance      =   0  'Flat
  155.       BackColor       =   &H00C0C0C0&
  156.       Caption         =   "ASCII Text File:"
  157.       ForeColor       =   &H80000008&
  158.       Height          =   255
  159.       Left            =   120
  160.       TabIndex        =   0
  161.       Top             =   360
  162.       Width           =   2055
  163.    End
  164. Attribute VB_Name = "OrgChartDlg"
  165. Attribute VB_Creatable = False
  166. Attribute VB_Exposed = False
  167. Dim ABC As Object
  168. Dim FormatIter As Integer
  169. Dim LoopIter As Integer
  170. Dim TotalFormatIter As Integer
  171. Dim req_objs As Integer
  172. Private Sub ABC1_AppQuitNOTIFY()
  173.     End
  174. End Sub
  175. Private Sub BrowseBtn_Click()
  176.     OrgChartBrowse.Action = 1
  177.    ' OrgChartBrowse.Filename = OrgChartTextFileEdit.Text
  178.     OrgChartTextFileEdit.Text = LCase(OrgChartBrowse.Filename)
  179.     OrgChartBrowse.Filename = "*.txt"
  180. End Sub
  181. Private Function CalcPercent() As Integer
  182.     CalcPercent = 100 * ((LoopIter / req_objs) / TotalFormatIter + (FormatIter - 1) / TotalFormatIter) + 1
  183.     If CalcPerent > 100 Then CalcPercent = 100
  184.     If CalcPerent < 0 Then CalcPercent = 0
  185.     LoopIter = LoopIter + 1
  186. End Function
  187. Private Sub CancelBtn_Click()
  188.     Unload OrgChartDlg
  189. End Sub
  190. Private Sub Command2_Click()
  191.     OrgChartBrowse.Action = 1
  192. End Sub
  193. Private Function DoCreateOrgChart(ByVal Filename As String) As Integer
  194.     Dim OrgItem As String
  195.     Dim Chart As Object
  196.     Dim cur_pos As Integer
  197.     Dim len_str As Integer
  198.     Rem Make a new chart
  199.     Set Chart = ABC.New
  200.     Rem Set the right shape palette
  201.     Chart.CurrentShapePalette = "Standard"
  202.     Chart.CurrentShape = "Process"
  203.     ABC.ShapePaletteVisible = False
  204.     Rem Set the Chart's internal type
  205.     Chart.Type = "PROCESS"
  206.     Rem Turn off master items
  207.     Chart.MasterItems.Hideall
  208.     Chart.DrawDirection = 2
  209.     Chart.DrawPositionX = 4
  210.     Chart.DrawPositionY = 1
  211.     Chart.DrawSpacingY = 0.25
  212.     Chart.CurrentLineRouting = 3
  213.     If OrgChartOptionsDlg.TopToBottomRBtn.Value = True Or OrgChartOptionsDlg.BottomToTopRBtn = True Then
  214.         vertical = True
  215.     Else
  216.         vertical = False
  217.     End If
  218.     If OrgChartOptionsDlg.BottomToTopRBtn.Value = True Or OrgChartOptionsDlg.RightToLeftRBtn = True Then
  219.         inverted = True
  220.     Else
  221.         inverted = False
  222.     End If
  223.     If vertical Then
  224.         Chart.PageLayout.Orientation = 1
  225.     Else
  226.         Chart.PageLayout.Orientation = 0
  227.     End If
  228.     Chart.NoRepaint = True
  229.     len_file = FileLen(Filename)
  230.     If len_file < 32767 And len_file > 0 Then
  231.         Dim EntireFile As String
  232.         Dim test_ascCode As Integer
  233.         Dim rank As Integer
  234.         Dim index As Integer
  235.         Dim cur_obj_count As Integer
  236.         Dim num_levels As Integer
  237.         Open Filename For Binary Access Read As #1
  238.         EntireFile = String$(len_file, " ")
  239.         Get #1, , EntireFile
  240.         Close
  241.         Rem Set up the progess bar
  242.         ABC.PercentGauge "Organization Chart DEMO", "PASS 1 of 2: Reading & parsing file..."
  243.         DrawnCount = 0
  244.         req_objs = GetNumLines(EntireFile) + 1
  245.         ReDim ShapeList(req_objs) As Object
  246.         ReDim ShapeRefStack(req_objs) As Integer
  247.         ReDim RelationMap(req_objs, 3) As Integer
  248.         Const first_child = 1, next_sibling = 2, parent = 3
  249.                                                  
  250.         cur_pos = 1
  251.         index = 2
  252.         cur_obj_count = 1
  253.         ShapeRefStack(1) = 1
  254.         Do While cur_pos < len_file + 1
  255.             test_ascCode = Asc(Mid$(EntireFile, cur_pos, 1))
  256.             rank = 2
  257.             While test_ascCode <> 13 And test_ascCode <> 10 And cur_pos < len_file + 1
  258.                 If test_ascCode = 9 Then
  259.                     rank = rank + 1
  260.                 Else
  261.                     OrgItem = OrgItem + Chr$(test_ascCode)
  262.                 End If
  263.                 cur_pos = cur_pos + 1
  264.                 test_ascCode = Asc(Mid$(EntireFile, cur_pos, 1))
  265.             Wend
  266.             cur_pos = cur_pos + 1
  267.             OrgItem = FormatOrgString(OrgItem)
  268.             If rank > num_levels Then
  269.                 num_levels = rank
  270.             End If
  271.             If Len(OrgItem) > 0 Then
  272.                 If rank > index Then
  273.                     index = index + 1
  274.                 ElseIf rank < index Then
  275.                     index = rank
  276.                 End If
  277.                 
  278.                 Chart.DrawPositionX = 1 + (index)
  279.                 Chart.DrawPositionY = 2
  280.                 cur_obj_count = cur_obj_count + 1
  281.                 Set ShapeList(cur_obj_count) = Chart.DrawShape("Process")
  282.                 ShapeList(cur_obj_count).Text = OrgItem
  283.                 Rem update status bar
  284.                 DrawnCount = DrawnCount + 1
  285.                 ABC.PercentGaugeValue = 100 * DrawnCount / (req_objs - 1)
  286.                 
  287.                 'Give all the shapes some attributes here
  288.                 ShapeList(cur_obj_count).Shape.FillColor = ABC.YELLOW
  289.                 ShapeList(cur_obj_count).Shape.BorderColor = ABC.BLUE
  290.                 ShapeList(cur_obj_count).Shape.ShadowStyle = 1
  291.                 ShapeList(cur_obj_count).Shape.NumberShown = False
  292.                 ShapeList(cur_obj_count).Shape.BorderWidth = 3
  293.                 ShapeList(cur_obj_count).Shape.FitShapeToText
  294.                 ShapeRefStack(index) = cur_obj_count
  295.                 RelationMap(cur_obj_count, parent) = ShapeRefStack(index - 1)
  296.                 RelationMap(cur_obj_count, next_sibling) = RelationMap(RelationMap(cur_obj_count, parent), first_child)
  297.                 RelationMap(RelationMap(cur_obj_count, parent), first_child) = cur_obj_count
  298.                 RelationMap(cur_obj_count, first_child) = 0
  299.                 
  300.                 OrgItem = ""
  301.             End If
  302.             If ABC.PercentGaugeCancelled Then Exit Do
  303.         Loop
  304.         
  305.         If ABC.PercentGaugeCancelled Then GoTo DoCreateAbort
  306.         ABC.PercentGauge "Organization Chart DEMO", "PASS 2 of 2: Formatting chart..."
  307.         Rem There are currently five iterations of formatting
  308.         TotalFormatIter = 5
  309.         FormatIter = 0
  310.         
  311.         'We need to go through the list and make sure
  312.         'the sizes work according to the Options Dlg
  313.         Const size_cx = 1, size_cy = 2
  314.         Dim finished As Integer
  315.         ReDim obj_size_level(req_objs, 2) As Double
  316.         Dim counter As Integer
  317.         finished = False
  318.         cur_obj_count = 1
  319.         index = 1
  320.         Call NewGaugeLoop
  321.         'Here we traverse the tree gathering the maximum size box in each level
  322.         While Not ABC.PercentGaugeCancelled And Not finished
  323.             Rem update status bar
  324.             ABC.PercentGaugeValue = CalcPercent()
  325.             If cur_obj_count <> 1 Then
  326.                 If ShapeList(cur_obj_count).Height > obj_size_level(index, size_cy) Then
  327.                     obj_size_level(index, size_cy) = ShapeList(cur_obj_count).Height
  328.                 End If
  329.                 If ShapeList(cur_obj_count).Width > obj_size_level(index, size_cx) Then
  330.                     obj_size_level(index, size_cx) = ShapeList(cur_obj_count).Width
  331.                 End If
  332.             End If
  333.             If RelationMap(cur_obj_count, first_child) = 0 Then
  334.                 ShapeRefStack(index) = cur_obj_count
  335.                 cur_obj_count = RelationMap(cur_obj_count, next_sibling)
  336.                 While cur_obj_count = 0 And index <> 1
  337.                     index = index - 1
  338.                     If index > 1 Then
  339.                         cur_obj_count = ShapeRefStack(index)
  340.                         If cur_obj_count Then
  341.                             cur_obj_count = RelationMap(cur_obj_count, next_sibling)
  342.                         End If
  343.                     End If
  344.                 Wend
  345.             Else
  346.                 ShapeRefStack(index) = cur_obj_count
  347.                 index = index + 1
  348.                 cur_obj_count = RelationMap(cur_obj_count, first_child)
  349.             End If
  350.             If index = 1 Then
  351.                 finished = True
  352.             End If
  353.         Wend
  354.         
  355.         'Now we have to adjust if the manager's size increases.
  356.         If OrgChartOptionsDlg.IncreaseMgrSize.Value = True Then
  357.             For counter = num_levels - 1 To 2 Step -1
  358.                 If obj_size_level(counter, size_cx) < obj_size_level(counter + 1, size_cx) Then
  359.                     obj_size_level(counter, size_cx) = obj_size_level(counter + 1, size_cx)
  360.                 End If
  361.                 If obj_size_level(counter, size_cy) < obj_size_level(counter + 1, size_cy) Then
  362.                     obj_size_level(counter, size_cy) = obj_size_level(counter + 1, size_cy)
  363.                 End If
  364.             Next
  365.         End If
  366.         
  367.         'Reinitialize the loop vars
  368.         finished = False
  369.         cur_obj_count = 1
  370.         index = 1
  371.         Call NewGaugeLoop
  372.         'Here we traverse the tree gathering the maximum size box in each level
  373.         While Not ABC.PercentGaugeCancelled And Not finished
  374.             Rem update status bar
  375.             ABC.PercentGaugeValue = CalcPercent()
  376.             If cur_obj_count <> 1 Then
  377.                 If OrgChartOptionsDlg.EqualWithinLevels.Value = True Then
  378.                     ShapeList(cur_obj_count).Width = obj_size_level(index, size_cx)
  379.                     ShapeList(cur_obj_count).Height = obj_size_level(index, size_cy)
  380.                 Else    'The object has to be at least as big as the biggest on the next level
  381.                     If OrgChartOptionsDlg.IncreaseMgrSize.Value = True Then
  382.                         If index < num_levels And index > 1 Then
  383.                             If ShapeList(cur_obj_count).Width < obj_size_level(index + 1, size_cx) Then
  384.                                 ShapeList(cur_obj_count).Width = obj_size_level(index + 1, size_cx)
  385.                             End If
  386.                             If ShapeList(cur_obj_count).Height < obj_size_level(index + 1, size_cy) Then
  387.                                 ShapeList(cur_obj_count).Height = obj_size_level(index + 1, size_cy)
  388.                             End If
  389.                         End If
  390.                     End If
  391.                 End If
  392.             End If
  393.             If RelationMap(cur_obj_count, first_child) = 0 Then
  394.                 ShapeRefStack(index) = cur_obj_count
  395.                 cur_obj_count = RelationMap(cur_obj_count, next_sibling)
  396.                 While cur_obj_count = 0 And index <> 1
  397.                     index = index - 1
  398.                     If index > 1 Then
  399.                         cur_obj_count = ShapeRefStack(index)
  400.                         If cur_obj_count Then
  401.                             cur_obj_count = RelationMap(cur_obj_count, next_sibling)
  402.                         End If
  403.                     End If
  404.                 Wend
  405.             Else
  406.                 ShapeRefStack(index) = cur_obj_count
  407.                 index = index + 1
  408.                 cur_obj_count = RelationMap(cur_obj_count, first_child)
  409.             End If
  410.             If index = 1 Then
  411.                 finished = True
  412.             End If
  413.         Wend
  414.        
  415.         'Format the chart *here*
  416.         'start at the top (the "God" object)
  417.         ReDim size_branch(req_objs) As Double
  418.         ReDim size_level(req_objs) As Double
  419.         Dim box_spacing_peers As Double
  420.         Dim box_spacing_levels As Double
  421.        ' Dim vertical As Integer
  422.        ' Dim inverted As Integer
  423.         
  424.         
  425.         box_spacing_peers = Val(OrgChartOptionsDlg.BoxSpacing.Text)
  426.         box_spacing_levels = box_spacing_peers * 2
  427.         finished = False
  428.         cur_obj_count = 1
  429.         index = 1
  430.         Call NewGaugeLoop
  431.         'We're just calculating the sizes that these shapes need so far.
  432.         While Not ABC.PercentGaugeCancelled And Not finished
  433.             Rem update status bar
  434.             ABC.PercentGaugeValue = CalcPercent()
  435.             If cur_obj_count <> 1 Then
  436.                 If vertical = True Then
  437.                     If ShapeList(cur_obj_count).Height > size_level(index) Then
  438.                         size_level(index) = ShapeList(cur_obj_count).Height
  439.                     End If
  440.                 Else
  441.                     If ShapeList(cur_obj_count).Width > size_level(index) Then
  442.                         size_level(index) = ShapeList(cur_obj_count).Width
  443.                     End If
  444.                 End If
  445.             End If
  446.             If RelationMap(cur_obj_count, first_child) = 0 Then
  447.                 ShapeRefStack(index) = cur_obj_count
  448.                 For counter = 1 To index
  449.                     If vertical = True Then
  450.                         size_branch(ShapeRefStack(counter)) = size_branch(ShapeRefStack(counter)) + ShapeList(cur_obj_count).Width + box_spacing_peers
  451.                     Else
  452.                         size_branch(ShapeRefStack(counter)) = size_branch(ShapeRefStack(counter)) + ShapeList(cur_obj_count).Height + box_spacing_peers
  453.                     End If
  454.                 Next
  455.                 cur_obj_count = RelationMap(cur_obj_count, next_sibling)
  456.                 While cur_obj_count = 0 And index <> 1
  457.                     index = index - 1
  458.                     If index > 1 Then
  459.                         cur_obj_count = ShapeRefStack(index)
  460.                         If cur_obj_count Then
  461.                             cur_obj_count = RelationMap(cur_obj_count, next_sibling)
  462.                         End If
  463.                     End If
  464.                 Wend
  465.             Else
  466.                 ShapeRefStack(index) = cur_obj_count
  467.                 index = index + 1
  468.                 cur_obj_count = RelationMap(cur_obj_count, first_child)
  469.             End If
  470.             If index = 1 Then
  471.                 finished = True
  472.             End If
  473.         Wend
  474.         
  475.         Dim posX As Double
  476.         Dim posY As Double
  477.         Dim newline As Object
  478.         'I'll have to admit - this is a little hard to follow - but it's BASIC you know, Visual or not
  479.         'Can't do too much about the recursion stuff in BASIC
  480.         
  481.         posX = box_spacing_peers + size_branch(1)
  482.         posY = 0
  483.         mirrorX = box_spacing_peers + size_branch(1)
  484.         mirrorY = box_spacing_levels
  485.         cur_obj_count = 1
  486.         index = 1
  487.         finished = False
  488.         For counter = 2 To num_levels
  489.             mirrorY = mirrorY + size_level(counter) + box_spacing_levels
  490.         Next
  491.         Call NewGaugeLoop
  492.         'This is recursion in disguise....
  493.         'Don't be confused-> X and Y are reversed if this is not vertical
  494.         While Not ABC.PercentGaugeCancelled And Not finished
  495.             Rem update status bar
  496.             ABC.PercentGaugeValue = CalcPercent()
  497.             If cur_obj_count <> 1 Then
  498.                 If vertical Then
  499.                     ShapeList(cur_obj_count).CenterX = posX - (size_branch(cur_obj_count) / 2)
  500.                 Else
  501.                     ShapeList(cur_obj_count).CenterY = posX - (size_branch(cur_obj_count) / 2)
  502.                 End If
  503.                 posY = box_spacing_levels
  504.                 For counter = 2 To index - 1
  505.                     posY = posY + size_level(counter) + box_spacing_levels
  506.                 Next
  507.                 If vertical Then
  508.                     If inverted Then
  509.                         ShapeList(cur_obj_count).Bottom = mirrorY - posY
  510.                     Else
  511.                         ShapeList(cur_obj_count).Top = posY
  512.                     End If
  513.                 Else
  514.                     If inverted Then
  515.                         ShapeList(cur_obj_count).Right = mirrorY - posY
  516.                     Else
  517.                         ShapeList(cur_obj_count).Left = posY
  518.                     End If
  519.                 End If
  520.             End If
  521.             
  522.             If RelationMap(cur_obj_count, first_child) = 0 Then
  523.                 posX = posX - size_branch(cur_obj_count)
  524.                  
  525.                 cur_obj_count = RelationMap(cur_obj_count, next_sibling)
  526.                 While cur_obj_count = 0 And index <> 1
  527.                     index = index - 1
  528.                     If index > 1 Then
  529.                         cur_obj_count = ShapeRefStack(index)
  530.                         If cur_obj_count Then
  531.                             cur_obj_count = RelationMap(cur_obj_count, next_sibling)
  532.                         End If
  533.                     End If
  534.                 Wend
  535.             Else
  536.                 ShapeRefStack(index) = cur_obj_count
  537.                 index = index + 1
  538.                 cur_obj_count = RelationMap(cur_obj_count, first_child)
  539.             End If
  540.             
  541.             If index = 1 Then
  542.                 finished = True
  543.             End If
  544.         Wend
  545.         Call NewGaugeLoop
  546.         Junk = CalcPercent()  ' since we're skipping an object in this loop
  547.        
  548.         For counter = 2 To req_objs
  549.             If ABC.PercentGaugeCancelled Then Exit For
  550.             ABC.PercentGaugeValue = CalcPercent()
  551.             
  552.             If RelationMap(counter, parent) > 1 Then
  553.                 If vertical Then
  554.                     If inverted Then
  555.                         Set newline = Chart.DrawLine(ShapeList(RelationMap(counter, parent)), ShapeList(counter), 0, 2)
  556.                     Else
  557.                         Set newline = Chart.DrawLine(ShapeList(RelationMap(counter, parent)), ShapeList(counter), 2, 0)
  558.                     End If
  559.                 Else
  560.                     If inverted Then
  561.                         Set newline = Chart.DrawLine(ShapeList(RelationMap(counter, parent)), ShapeList(counter), 3, 1)
  562.                     Else
  563.                         Set newline = Chart.DrawLine(ShapeList(RelationMap(counter, parent)), ShapeList(counter), 1, 3)
  564.                     End If
  565.                 End If
  566.                 newline.Line_.StemWidth = 3
  567.                 newline.Line_.DestArrowStyle = 0
  568.                 newline.Line_.SourceArrowStyle = 0
  569.                 newline.Line_.Color = ABC.BLUE
  570.             End If
  571.         Next
  572.         DoCreateOrgChart = 1
  573.     Else
  574.         DoCreateOrgChart = 0
  575.     End If
  576. DoCreateAbort:
  577.     Chart.View = 2
  578.     Chart.NoRepaint = False
  579.     Chart.Repaint
  580.     ABC.HidePercentGauge
  581. End Function
  582. Private Sub Form_Load()
  583.     Set ABC = CreateObject("ABCFlow.application")
  584.     ABC.Visible = True
  585.     OrgChartTextFileEdit = LCase(App.Path + "\ORGCHRT1.TXT")
  586.     Load OrgChartOptionsDlg
  587.     ABC.RegisterEvent ABC1, APPNAME, "AppQuitNOTIFY"
  588. End Sub
  589. Private Sub Form_Unload(Cancel As Integer)
  590.     Unload OrgChartOptionsDlg
  591. End Sub
  592. Private Function FormatOrgString(ByVal OrgString As String) As String
  593.     Dim index As Integer
  594.     Dim len_str As Integer
  595.     Dim test_ascCode As Integer
  596.     Dim in_quotes As Integer
  597.     Dim FormattedStr As String
  598.     index = 1
  599.     in_quotes = False
  600.     len_str = Len(OrgString)
  601.     FormattedStr = ""
  602.     While index < (len_str + 1)
  603.         test_ascCode = Asc(Mid$(OrgString, index))
  604.         If test_ascCode = 34 Then
  605.             in_quotes = Not in_quotes
  606.         ElseIf in_quotes Then
  607.             FormattedStr = FormattedStr + Chr$(test_ascCode)
  608.         ElseIf test_ascCode = 44 Then: Rem comma
  609.             FormattedStr = FormattedStr + Chr$(13)
  610.         End If
  611.         index = index + 1
  612.         
  613.     Wend
  614.     FormatOrgString = FormattedStr
  615. End Function
  616. Private Function GetNumLines(test_str As String) As Integer
  617.     Dim len_str As Integer
  618.     Dim index As Integer
  619.     Dim in_line_feed As Integer
  620.     Dim test_ascCode As Integer
  621.     Dim total_lines As Integer
  622.     in_line_feed = True
  623.     index = 1
  624.     len_str = Len(test_str)
  625.     total_lines = 0
  626.     While index < len_str + 1
  627.         test_ascCode = Asc(Mid$(test_str, index))
  628.         If test_ascCode = 13 Or test_ascCode = 10 Then
  629.             If Not in_line_feed Then
  630.                 total_lines = total_lines + 1
  631.                 in_line_feed = True
  632.             End If
  633.         Else
  634.             in_line_feed = False
  635.         End If
  636.         index = index + 1
  637.     Wend
  638.     GetNumLines = total_lines
  639. End Function
  640. Private Sub NewGaugeLoop()
  641.     LoopIter = 0
  642.     FormatIter = FormatIter + 1
  643. End Sub
  644. Private Sub OKBtn_Click()
  645.     OrgChartDlg.WindowState = 1 ' iconize form
  646.     OrgChartDlg.Refresh
  647.     success = DoCreateOrgChart(OrgChartTextFileEdit.Text)
  648. End Sub
  649. Private Sub OptionsBtn_Click()
  650.     OrgChartDlg.Enabled = False
  651.     OrgChartOptionsDlg.Show
  652. End Sub
  653. Private Sub OrgChartTextFileEdit_Change()
  654.     Call ValidateFilename
  655. End Sub
  656. Private Sub ValidateFilename()
  657.    On Error Resume Next
  658.    Attr = GetAttr(OrgChartTextFileEdit)
  659.    If Err Then
  660.         OKBtn.Enabled = False
  661.    Else
  662.         OKBtn.Enabled = True
  663.    End If
  664. End Sub
  665.