Subversion Repositories DevTools

Rev

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