Subversion Repositories DevTools

Rev

Rev 6508 | Rev 6579 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
5357 dpurdie 1
<%@LANGUAGE="VBSCRIPT"%>
2
<%
3
'=====================================================
4
'|                                                   |
5
'|              Edit Project View Details            |
6
'|                                                   |
7
'=====================================================
8
Option explicit
9
' Good idea to set when using redirect
10
Response.Expires = 0  ' always load the page, dont store
11
%>
12
<!--#include file="common/conf.asp"-->
13
<!--#include file="common/globals.asp"-->
14
<!--#include file="common/formating.asp"-->
15
<!--#include file="common/qstr.asp"-->
16
<!--#include file="common/common_subs.asp"-->
17
<!--#include file="common/_form_window_common.asp"-->
18
<%
19
' Set rfile parameter. This is a return page after Login
20
Call objPMod.StoreParameter ( "rfile", "rtree.asp" )
21
objPMod.PersistInQryString("proj_id")
22
'------------ ACCESS CONTROL ------------------
23
%>
24
<!--#include file="_access_control_login.asp"-->
25
<!--#include file="_access_control_general.asp"-->
26
<%
27
'------------ Variable Definition -------------
28
Dim objSortHelper
29
Dim rsQry
30
Dim parProjId
6508 dpurdie 31
Dim parViewId
5357 dpurdie 32
'------------ Constants Declaration -----------
33
'------------ Variable Init -------------------
34
parProjId = Request("proj_id")
6508 dpurdie 35
parViewId = NiceInt(Request("FRview_id"), -1 )
5357 dpurdie 36
objPMod.PersistInQryString("proj_id")
37
'----------------------------------------------
38
'--------------------------------------------------------------------------------------------------------------------------
39
Sub GetFormDetails ( parProjId, ByRef outobjDetails )
40
  Dim rsQry, query
41
 
42
  OraDatabase.Parameters.Add "PROJ_ID",   parProjId,    ORAPARM_INPUT, ORATYPE_NUMBER
43
 
44
  query = _
45
  " SELECT prj.* "&_
46
  " FROM PROJECTS prj"&_
47
  " WHERE prj.PROJ_ID = :PROJ_ID"
48
 
49
  Set rsQry = OraDatabase.DbCreateDynaset( query, ORADYN_DEFAULT )
50
 
51
  OraDatabase.Parameters.Remove "PROJ_ID"
52
 
53
  If rsQry.RecordCount > 0 Then
54
    outobjDetails.Item ("proj_id") = rsQry("proj_id")
55
    outobjDetails.Item ("proj_name") = rsQry("proj_name")
56
  Else
57
    Err.Raise 8, "Sub GetFormDetails in "& ScriptName, "Empty record set returned. parProjId="& parProjId
58
  End If
59
 
60
  rsQry.Close
61
  Set rsQry = Nothing
62
End Sub
63
'--------------------------------------------------------------------------------------------------------------------------
64
Sub DeleteViewOwner (userId, viewId)
65
 
66
  On Error Resume Next
67
 
6508 dpurdie 68
  OraDatabase.Parameters.Add "PROJ_ID",         Request("proj_id"),         ORAPARM_INPUT, ORATYPE_NUMBER
69
  OraDatabase.Parameters.Add "VIEW_ID",         viewId,                     ORAPARM_INPUT, ORATYPE_NUMBER
70
  OraDatabase.Parameters.Add "USER_ID_LIST",    userId,                     ORAPARM_INPUT, ORATYPE_VARCHAR2
71
  OraDatabase.Parameters.Add "USER_ID",         objAccessControl.UserId,    ORAPARM_INPUT, ORATYPE_NUMBER
5357 dpurdie 72
 
73
  objEH.TryORA ( OraSession )
74
 
75
  OraDatabase.ExecuteSQL _
76
  "BEGIN   REMOVE_PROJECT_VIEW_OWNER ( :PROJ_ID, :VIEW_ID, :USER_ID_LIST, :USER_ID );   END;"
77
 
78
  objEH.CatchORA ( OraSession )
79
 
80
  OraDatabase.Parameters.Remove "PROJ_ID"
81
  OraDatabase.Parameters.Remove "VIEW_ID"
82
  OraDatabase.Parameters.Remove "USER_ID_LIST"
83
  OraDatabase.Parameters.Remove "USER_ID"
84
 
85
End Sub
86
'--------------------------------------------------------------------------------------------------------------------------
87
Sub GetUserViewId(value, posComma)
88
    txt = value
89
    posComma = InStr(txt, ",")
90
End Sub
91
'--------------------------------------------------------------------------------------------------------------------------
92
'------------ RUN BEFORE PAGE RENDER ----------
93
' --- Get Form details from DB ---
94
Call GetFormDetails ( Request("proj_id"), objFormCollector )
95
 
96
' --- Enter Form Validation Rule Changes here... ----
97
'----------------------------------------------------
98
 
99
' --- RUN onPostBack ---
100
If Request("action") <> "" Then
101
  If objForm.IsValidOnPostBack Then
102
    Dim txt,posComma, posUnderscore, userId, viewId, value
103
 
104
    Call GetUserViewId(Request("user_view_id_list"), posComma)
105
 
106
    While posComma <> 0
107
      value = Mid(txt, 1, posComma-1)
108
      posUnderscore = Instr(value, "_")
109
      userId = Mid(value, 1, posUnderscore - 1)
110
      viewId = Mid(value, posUnderscore + 1, posComma-1)
111
      Call DeleteViewOwner(userId, viewId)
112
      txt = Mid(txt, posComma + 1, Len(txt))
113
      posComma = InStr(txt, ",")
114
    Wend
115
 
116
    If posComma = 0 Then
117
      posUnderscore = Instr(txt, "_")
118
      If posUnderscore>0 Then
119
      userId = Mid(txt, 1, posUnderscore - 1)
120
      viewId = Mid(txt, posUnderscore + 1)
121
      Call DeleteViewOwner(userId, viewId)
122
      End If
123
    End if
124
 
125
    If objEH.Finally Then
6508 dpurdie 126
      Call OpenInWindow ( "form_edit_project_view.asp?proj_id="&parProjId&"&FRview_id="&parViewId )
5357 dpurdie 127
    End If
128
 
129
  End If
130
 
131
End If
6508 dpurdie 132
'----------------------------------------------
133
Sub BaseViewCombo
134
    OraDatabase.Parameters.Add "PROJ_ID", parProjId,   ORAPARM_INPUT, ORATYPE_NUMBER
135
    Dim ProjectWideId : ProjectWideId = 0
136
    Dim selectedFound : selectedFound = FALSE
137
    Dim rsQry
5357 dpurdie 138
 
6508 dpurdie 139
    Response.write "<select name='FRview_id' onChange=""Cascaded_Menu('parent','"& scriptName &"?proj_id="& parProjId &"&FRview_id=',this,0)"" class='form_item'>"
140
 
141
    Dim Query_String : Query_String = _
142
                "SELECT DISTINCT vi.view_id, vi.view_name" &_
143
                " FROM VIEWS vi" &_
144
                " WHERE vi.view_name = 'PROJECT WIDE'"
145
 
146
    Set rsQry = OraDatabase.DbCreateDynaset( Query_String , cint(0) )
147
    If (NOT rsQry.BOF) AND (NOT rsQry.EOF) Then
148
        ProjectWideId = rsQry("view_id") 
149
        '
150
        '   Display PROJECT_WIDE first
151
        '   It may be selected too.
152
        '
153
        Dim selectProjectWide : selectProjectWide = ""
154
        If parViewId = -1 Then
155
            parViewId = rsQry("view_id")
156
        End If
157
        If CDbl(parViewId) = CDbl(rsQry("view_id"))  Then
158
            selectProjectWide = " selected"
159
            selectedFound = TRUE
160
        End If
161
        Response.write "<option value='"& rsQry("view_id") &"'" & selectProjectWide & ">" & rsQry("view_name")  & "</option>"
162
    End If
163
    rsQry.Close()
164
 
165
    '
166
    '   Add in all the other project views
167
 
168
      Query_String = _
169
            "  SELECT DISTINCT vi.view_id, vi.view_name"&_
170
            "  FROM VIEWS vi,"&_
171
            "   RELEASE_CONTENT rc,"&_
172
            "   RELEASE_TAGS rt"&_
173
            "  WHERE rc.BASE_VIEW_ID = vi.VIEW_ID"&_
174
            "   AND rt.proj_id = "& parProjId &_
175
            "   AND rc.rtag_id = rt.rtag_id"&_
176
            "   ORDER BY UPPER( vi.view_name )"
177
 
178
    Set rsQry = OraDatabase.DbCreateDynaset( Query_String , cint(0) )
179
 
180
    OraDatabase.Parameters.Remove "PROJ_ID"
181
    While (NOT rsQry.BOF) AND (NOT rsQry.EOF)
182
      Dim selected : selected = ""
183
      If (CDbl(parViewId) = CDbl(rsQry("view_id"))) Then
184
          selected = " selected"
185
          selectedFound = TRUE
186
      End If
187
      Response.write "<option value='"& rsQry("view_id") &"'" & selected &">" & rsQry("view_name") &"</option>"
188
      rsQry.MoveNext
189
    WEnd
190
 
191
    rsQry.Close()
192
    Set rsQry = nothing
193
    OraDatabase.Parameters.Remove "PROJ_ID"
194
 
195
    ' Set the projectWideId if none have been correctly selected
196
    If NOT selectedFound Then
197
        parViewId = ProjectWideId
198
    End If
199
    Response.write "</select>"
200
End Sub
5357 dpurdie 201
%>
202
 
203
<html>
204
<head>
205
<title>Release Manager</title>
206
<link rel="shortcut icon" href="<%=FavIcon%>"/>
207
<meta HTTP-EQUIV="Pragma" CONTENT="no-cache">
208
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
209
<link rel="stylesheet" href="images/release_manager_style.css" type="text/css">
210
<link rel="stylesheet" href="images/navigation.css" type="text/css">
211
<script language="JavaScript" src="images/common.js"></script>
212
<!-- DROPDOWN MENUS -->
213
<!--#include file="_menu_def.asp"-->
5632 dpurdie 214
<!--#include file="_jquery_includes.asp"-->
5357 dpurdie 215
<script language="JavaScript1.2" src="images/popup_menu.js"></script>
216
</head>
217
<body bgcolor="#FFFFFF" text="#000000" leftmargin="0" topmargin="0">
218
<!-- HEADER -->
219
<!--#include file="_header.asp"-->
220
<!-- BODY ---->
221
 
222
<table width="100%" border="0" cellspacing="0" cellpadding="0">
223
<%
224
'-- FROM START ---------------------------------------------------------------------------------------------------------
225
objFormComponent.FormName = "FormName"
226
objFormComponent.Action = ScriptName
227
Call objFormComponent.FormStart()
228
%>
229
  <tr>
230
    <td width="1" background="images/bg_home_orange.gif" valign="top">
231
    </td>
232
    <td width="100%" rowspan="2" align="center" valign="top" bgcolor="#EEEFEF">
233
      <table width="10" border="0" cellspacing="0" cellpadding="0">
234
        <tr>
235
          <td width="1%"></td>
236
          <td width="100%">
237
            <table width="100%"  border="0" cellspacing="0" cellpadding="0">
238
              <tr>
239
                <td nowrap class="body_txt">
240
                </td>
241
              </tr>
242
            </table>
243
            <table width="100%" border="0" cellspacing="0" cellpadding="0">
244
              <tr>
245
                <td nowrap class="form_ttl"><p>&nbsp;</p>
6510 dpurdie 246
                  <p>PROJECT VIEW DETAILS </p></td>
5357 dpurdie 247
                <td align="right" valign="bottom"></td>
248
              </tr>
249
            </table>
250
          </td>
251
          <td width="1%"></td>
252
        </tr>
253
        <tr>
254
          <td align="left" valign="top" background="images/lbox_bg_blue.gif"><img src="images/lbox_tl_cnr_b.gif" width="13" height="13"></td>
255
          <td background="images/lbox_bg_blue.gif" class="lbox_ttl_w"><img src="images/h_trsp_dot.gif" width="600" height="15"></td>
256
          <td align="right" valign="top"  background="images/lbox_bg_blue.gif"><img src="images/lbox_tr_cnr_b.gif" width="13" height="13"></td>
257
        </tr>
258
        <tr>
259
          <td bgcolor="#FFFFFF"><img src="images/h_trsp_dot.gif" width="10" height="100"></td>
260
          <td bgcolor="#FFFFFF" valign="top">
261
<!-- MESSAGE +++++++++++++++++++++++++++++++++++++++++++++++++++ -->
262
<!--#include file="messages/_msg_inline.asp"-->
263
<!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
264
            <br>
5590 dpurdie 265
            <div style="min-height:300px;max-height:500px;overflow:auto;">
5357 dpurdie 266
            <table width="100%"  border="0" cellspacing="2" cellpadding="0">
267
              <tr>
268
                <td valign="top" nowrap class="form_iname">Project Name </td>
269
                <td valign="top" nowrap><%=objFormComponent.TextBox ( "project_name", objForm.GetValue( "project_name", objFormCollector.Item("proj_name") ), "class='form_ivalue' readonly" )%></td>
270
              </tr>
6510 dpurdie 271
<%If canActionControlInProject("AdminView") Then%>
5357 dpurdie 272
              <tr>
273
                <td nowrap class="form_iname" valign="top">Select Base View </td>
274
                <td valign="top" nowrap class="form_iname">
6508 dpurdie 275
                    <%Call BaseViewCombo%>
5357 dpurdie 276
<!-- BUTTONS CONTROL +++++++++++++++++++ -->
6508 dpurdie 277
                  <a href="javascript:;" class ="form_iname" onClick="MM_openVixIFrame('wAddApplicationUser.asp?proj_id=<%=parProjId%>&view_id=<%=parViewId%>','Add View Owner')"><img src="images/email-contact-orange.gif">Add View Owner</a>
5357 dpurdie 278
<!-- +++++++++++++++++++++++++++++++++++ -->
279
                </td>
6510 dpurdie 280
<%End If%>
5357 dpurdie 281
                <td width="9%" valign="top"></td>
282
                  <tr>
283
                    <td valign="top" nowrap background="images/bg_table_col.gif" class="body_col"></td>
284
                    <td valign="top" nowrap background="images/bg_table_col.gif" class="body_col">Base View</td>
285
                    <td valign="top" nowrap background="images/bg_table_col.gif" class="body_col">Full Name</td>
286
                    <td valign="top" nowrap background="images/bg_table_col.gif" class="body_col">User Name</td>
287
                    <td valign="top" nowrap background="images/bg_table_col.gif" class="body_col">User Email</td>
288
                    <td valign="top">
289
                  </tr>
290
<%
291
Dim currViewId
292
currViewId = -1
293
  Set rsQry = OraDatabase.DbCreateDynaset( "SELECT * FROM USERS USR, MEMBERS_GROUP MG, VIEWS V, AUTOBUILD_FAILURE AF WHERE  AF.PROJ_ID = "& Request("proj_id") &" AND AF.GROUP_EMAIL_ID = MG.GROUP_EMAIL_ID AND USR.USER_ID = MG.USER_ID AND V.VIEW_ID = AF.VIEW_ID ORDER BY V.VIEW_NAME, USR.FULL_NAME" , cint(0) )
294
'--- Render rows ---
295
Do While (NOT rsQry.BOF) AND (NOT rsQry.EOF)
296
' -------- GROUP BY BASE VIEW  -----------------
297
If CDbl(currViewid) <> CDbl(rsQry("view_id")) Then
298
%>
299
                  <tr>
300
                    <td colspan="5" background="images/bg_rep_line.gif"><img src="images/spacer.gif" width="1" height="1"></td>
301
                  </tr>
302
                  <tr>
303
                    <td nowrap class="body_scol"></td>
304
                    <td nowrap class="body_scol"><%=rsQry("view_name")%></td>
305
                    <td nowrap class="body_scol"></td>
306
                    <td nowrap class="body_scol"></td>
307
                    <td nowrap class="body_scol"></td>
308
                  </tr>
309
<%
310
  currViewId = CDbl(rsQry("view_id"))
311
End If
312
%>
313
                  <tr>
314
                    <td align="center"><input type="checkbox" name="user_view_id_list" value="<%=rsQry("user_id")%>_<%=rsQry("view_id")%>"></td>
315
                    <td nowrap class="body_rowg"></td>
316
                    <td nowrap class="body_rowg"><%=rsQry("full_name")%></td>
317
                    <td nowrap class="body_rowg"><%=rsQry("user_name")%></td>
318
                    <td nowrap class="body_rowg"><%=rsQry("user_email")%></td>
319
                  </tr>
320
<%
321
  rsQry.MoveNext
322
  If (NOT rsQry.BOF) AND (NOT rsQry.EOF) Then
323
%>
324
                  <tr>
325
                    <td colspan="8" background="images/bg_table_border.gif"><img src="images/spacer.gif" width="1" height="1"></td>
326
                  </tr>
327
<%
328
  End If
329
Loop
330
rsQry.Close()
331
Set rsQry = nothing
332
%>
333
                  <tr>
334
                    <td class="form_iname">&nbsp;</td>
335
                    <td>&nbsp;</td>
336
                    <td class="val_err"></td>
337
                  </tr>
338
            </table>
5590 dpurdie 339
            </div>
5357 dpurdie 340
          </td>
341
          <td background="images/lbox_bgside_white.gif">&nbsp;</td>
342
        </tr>
343
        <tr>
344
          <td background="images/bg_action_norm.gif" ></td>
345
          <td align="right" background="images/bg_action_norm.gif" >
5632 dpurdie 346
<%=objFormComponent.CancelButton ( "OK", "class='form_btn'", "rtree.asp?CANCEL=OK&"& objPMod.ComposeURL() )%>
5357 dpurdie 347
<%=objPMod.ComposeHiddenTags()%>
348
<%
349
If canActionControlInProject("AdminView") Then
350
%>
351
            <input name="btn" type="submit" class="form_btn" value="Remove View Owner(s)">
352
<%
353
End If
354
%>
355
            <input type="hidden" name="user_id_list" value="<%=Request("user_id_list")%>">
356
            <input type="hidden" name="action" value="true">
357
          </td>
358
          <td background="images/bg_action_norm.gif" ><img src="images/h_trsp_dot.gif" width="5" height="30"></td>
359
        </tr>
360
        <tr>
361
          <td background="images/lbox_bg_blue.gif" valign="bottom"><img src="images/lbox_bl_cnr_b.gif" width="13" height="13"></td>
362
          <td background="images/lbox_bg_blue.gif"></td>
363
          <td background="images/lbox_bg_blue.gif" valign="bottom" align="right"><img src="images/lbox_br_cnr_b.gif" width="13" height="13"></td>
364
        </tr>
365
      </table>
366
 
367
  <!-- ACTION BUTTONS ---------------------------------------------->
368
  <!-- ACTION BUTTONS END  ------------------------------------------>
369
    </td>
370
    <td width="1" valign="top"><img src="images/h_trsp_dot.gif" width="1" height="1"></td>
371
  </tr>
372
  <tr>
373
    <td valign="bottom" align="center" background="images/bg_home_orange.gif"><img src="images/img_vtree.gif" width="86" height="99" vspace="20" hspace="30"></td>
374
    <td background="images/bg_lght_gray.gif" valign="top"><img src="images/h_trsp_dot.gif" width="1" height="500"></td>
375
  </tr>
376
<%
377
Call objFormComponent.FormEnd()
378
'-- FROM END ----------------------------------------------------------------------------------------------------------------
379
%>
380
</table>
381
<!-- FOOTER -->
382
<!--#include file="_footer.asp"-->
383
</body>
384
</html>