<?php # Mantis - a php based bugtracking system # Copyright (C) 2000 - 2002 Kenzaburo Ito - kenito@300baud.org # Copyright (C) 2002 - 2007 Mantis Team - mantisbt-dev@lists.sourceforge.net # Mantis is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 2 of the License, or # (at your option) any later version. # # Mantis is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with Mantis. If not, see <http://www.gnu.org/licenses/>. # -------------------------------------------------------- # $Id: manage_proj_edit_page.php,v 1.104.2.2 2007-10-19 07:25:59 vboctor Exp $ # -------------------------------------------------------- require_once( 'core.php' ); $t_core_path = config_get( 'core_path' ); require_once( $t_core_path . 'category_api.php' ); require_once( $t_core_path . 'version_api.php' ); require_once( $t_core_path . 'custom_field_api.php' ); require_once( $t_core_path . 'icon_api.php' ); auth_reauthenticate(); $f_project_id = gpc_get_int( 'project_id' ); access_ensure_project_level( config_get( 'manage_project_threshold' ), $f_project_id ); $row = project_get_row( $f_project_id ); html_page_top1( project_get_field( $f_project_id, 'name' ) ); html_page_top2(); print_manage_menu( 'manage_proj_edit_page.php' ); ?> <br /> <!-- PROJECT PROPERTIES --> <div align="center"> <form method="post" action="manage_proj_update.php"> <?php echo form_security_field( 'manage_proj_update' ) ?> <table class="width75" cellspacing="1"> <!-- Title --> <tr class="title"> <td class="form-title" colspan="2"> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <?php echo lang_get( 'edit_project_title' ) ?> </td> </tr> <!-- Name --> <tr <?php echo helper_alternate_class() ?>> <td class="category" width="25%"> <?php echo lang_get( 'project_name' ) ?> </td> <td width="75%"> <input type="text" name="name" size="50" maxlength="128" value="<?php echo string_attribute( $row['name'] ) ?>" /> </td> </tr> <!-- Status --> <tr <?php echo helper_alternate_class() ?>> <td class="category"> <?php echo lang_get( 'status' ) ?> </td> <td> <select name="status"> <?php print_enum_string_option_list( 'project_status', $row['status'] ) ?> </select> </td> </tr> <!-- Enabled --> <tr <?php echo helper_alternate_class() ?>> <td class="category"> <?php echo lang_get( 'enabled' ) ?> </td> <td> <input type="checkbox" name="enabled" <?php check_checked( $row['enabled'], ON ); ?> /> </td> </tr> <!-- View Status (public/private) --> <tr <?php echo helper_alternate_class() ?>> <td class="category"> <?php echo lang_get( 'view_status' ) ?> </td> <td> <select name="view_state"> <?php print_enum_string_option_list( 'view_state', $row['view_state']) ?> </select> </td> </tr> <!-- File upload path (if uploading is enabled) --> <?php if ( file_is_uploading_enabled() ) { ?> <tr <?php echo helper_alternate_class() ?>> <td class="category"> <?php echo lang_get( 'upload_file_path' ) ?> </td> <td> <input type="text" name="file_path" size="50" maxlength="250" value="<?php echo string_attribute( $row['file_path'] ) ?>" /> </td> </tr> <?php } ?> <!-- Description --> <tr <?php echo helper_alternate_class() ?>> <td class="category"> <?php echo lang_get( 'description' ) ?> </td> <td> <textarea name="description" cols="60" rows="5"><?php echo string_textarea( $row['description'] ) ?></textarea> </td> </tr> <!-- Submit Button --> <tr> <td> </td> <td> <input type="submit" class="button" value="<?php echo lang_get( 'update_project_button' ) ?>" /> </td> </tr> </table> </form> </div> <br /> <!-- PROJECT DELETE --> <?php # You must have global permissions to delete projects if ( access_has_global_level ( config_get( 'delete_project_threshold' ) ) ) { ?> <div class="border-center"> <form method="post" action="manage_proj_delete.php"> <?php echo form_security_field( 'manage_proj_delete' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <input type="submit" class="button" value="<?php echo lang_get( 'delete_project_button' ) ?>" /> </form> </div> <?php } ?> <br /> <?php # reset the class counter helper_alternate_class( 0 ); ?> <!-- SUBPROJECTS --> <div align="center"> <table class="width75" cellspacing="1"> <!-- Title --> <tr class="title"> <td class="form-title" colspan="6"> <?php echo lang_get( 'subprojects' ) ?> <?php # Check the user's global access level before allowing project creation if ( access_has_global_level ( config_get( 'create_project_threshold' ) ) ) { print_button( 'manage_proj_create_page.php?parent_id=' . $f_project_id, lang_get( 'create_new_subproject_link' ) ); } ?> </td> </tr> <!-- Subprojects --> <?php $t_subproject_ids = current_user_get_accessible_subprojects( $f_project_id, /* show_disabled */ true ); if ( Array() != $t_subproject_ids ) { ?> <tr class="row-category"> <td width="20%"> <?php echo lang_get( 'name' ) ?> </td> <td width="10%"> <?php echo lang_get( 'status' ) ?> </td> <td width="10%"> <?php echo lang_get( 'enabled' ) ?> </td> <td width="10%"> <?php echo lang_get( 'view_status' ) ?> </td> <td width="30%"> <?php echo lang_get( 'description' ) ?> </td> <td width="20%"> <?php echo lang_get( 'actions' ) ?> </td> </tr> <?php foreach ( $t_subproject_ids as $t_subproject_id ) { $t_subproject = project_get_row( $t_subproject_id ); ?> <tr <?php echo helper_alternate_class() ?>> <td> <a href="manage_proj_edit_page.php?project_id=<?php echo $t_subproject['id'] ?>"><?php echo string_display( $t_subproject['name'] ) ?></a> </td> <td> <?php echo get_enum_element( 'project_status', $t_subproject['status'] ) ?> </td> <td> <?php echo trans_bool( $t_subproject['enabled'] ) ?> </td> <td> <?php echo get_enum_element( 'project_view_state', $t_subproject['view_state'] ) ?> </td> <td> <?php echo string_display_links( $t_subproject['description'] ) ?> </td> <td class="center"> <?php print_button( 'manage_proj_edit_page.php?project_id=' . $t_subproject['id'], lang_get( 'edit_link' ) ); echo ' '; print_button( 'manage_proj_subproj_delete.php?project_id=' . $f_project_id . '&subproject_id=' . $t_subproject['id'] . form_security_param( 'manage_proj_subproj_delete' ), lang_get( 'unlink_link' ) ); ?> </td> </tr> <?php } # End of foreach loop over subprojects } # End of hiding subproject listing if there are no subprojects ?> <!-- Add subproject --> <tr> <td class="left" colspan="2"> <form method="post" action="manage_proj_subproj_add.php"> <?php echo form_security_field( 'manage_proj_subproj_add' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <select name="subproject_id"> <?php $t_all_subprojects = project_hierarchy_get_subprojects( $f_project_id, /* $p_show_disabled */ true ); $t_all_subprojects[] = $f_project_id; $t_manage_access = config_get( 'manage_project_threshold' ); $t_projects = project_get_all_rows(); $t_projects = multi_sort( $t_projects, 'name', ASCENDING ); foreach ( $t_projects as $t_project ) { if ( in_array( $t_project['id'], $t_all_subprojects ) || in_array( $f_project_id, project_hierarchy_get_all_subprojects( $t_project['id'] ) ) || ! access_has_project_level( $t_manage_access, $t_project['id'] ) ) { continue; } ?> <option value="<?php echo $t_project['id'] ?>"><?php echo string_attribute( $t_project['name'] ) ?></option> <?php } # End looping over projects ?> </select> <input type="submit" value="<?php echo lang_get('add_subproject'); ?>"> </form> </td> </tr> </table> </div> <br /> <!-- PROJECT CATEGORIES --> <a name="categories" /> <div align="center"> <table class="width75" cellspacing="1"> <!-- Title --> <tr class="title"> <td class="form-title" colspan="3"> <?php echo lang_get( 'categories' ) ?> </td> </tr> <?php $t_categories = category_get_all_rows( $f_project_id ); if ( count( $t_categories ) > 0 ) { ?> <tr class="row-category"> <td> <?php echo lang_get( 'category' ) ?> </td> <td> <?php echo lang_get( 'assign_to' ) ?> </td> <td class="center"> <?php echo lang_get( 'actions' ) ?> </td> </tr> <?php } foreach ( $t_categories as $t_category ) { $t_name = $t_category['category']; if ( NO_USER != $t_category['user_id'] && user_exists( $t_category['user_id'] )) { $t_user_name = user_get_name( $t_category['user_id'] ); } else { $t_user_name = ''; } ?> <!-- Repeated Info Row --> <tr <?php echo helper_alternate_class() ?>> <td> <?php echo string_display( $t_name ) ?> </td> <td> <?php echo $t_user_name ?> </td> <td class="center"> <?php $t_name = urlencode( $t_name ); print_button( 'manage_proj_cat_edit_page.php?project_id=' . $f_project_id . '&category=' . $t_name, lang_get( 'edit_link' ) ); echo ' '; print_button( 'manage_proj_cat_delete.php?project_id=' . $f_project_id . '&category=' . $t_name . form_security_param( 'manage_proj_cat_delete' ), lang_get( 'delete_link' ) ); ?> </td> </tr> <?php } # end for loop ?> <!-- Add Category Form --> <tr> <td class="left" colspan="3"> <form method="post" action="manage_proj_cat_add.php"> <?php echo form_security_field( 'manage_proj_cat_add' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <input type="text" name="category" size="32" maxlength="64" /> <input type="submit" class="button" value="<?php echo lang_get( 'add_category_button' ) ?>" /> </form> </td> </tr> <!-- Copy Categories Form --> <tr> <td class="left" colspan="3"> <form method="post" action="manage_proj_cat_copy.php"> <?php echo form_security_field( 'manage_proj_cat_copy' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <select name="other_project_id"> <?php print_project_option_list( null, false, $f_project_id ); ?> </select> <input type="submit" name="copy_from" class="button" value="<?php echo lang_get( 'copy_categories_from' ) ?>" /> <input type="submit" name="copy_to" class="button" value="<?php echo lang_get( 'copy_categories_to' ) ?>" /> </form> </td> </tr> </table> <br /> <?php # reset the class counter helper_alternate_class( 0 ); ?> <!-- PROJECT VERSIONS --> <a name="versions" /> <table class="width75" cellspacing="1"> <!-- Title --> <tr class="title"> <td class="form-title" colspan="3"> <?php echo lang_get( 'versions' ) ?> </td> </tr> <?php $t_versions = version_get_all_rows( $f_project_id ); if ( count( $t_versions ) > 0 ) { ?> <tr class="row-category"> <td> <?php echo lang_get( 'version' ) ?> </td> <td class="center"> <?php echo lang_get( 'released' ) ?> </td> <td class="center"> <?php echo lang_get( 'timestamp' ) ?> </td> <td class="center"> <?php echo lang_get( 'actions' ) ?> </td> </tr> <?php } foreach ( $t_versions as $t_version ) { $t_name = $t_version['version']; $t_released = $t_version['released']; $t_date_order = $t_version['date_order']; $t_date_formatted = string_format_complete_date( $t_version['date_order'] ); ?> <!-- Repeated Info Rows --> <tr <?php echo helper_alternate_class() ?>> <td> <?php echo string_display( $t_name ) ?> </td> <td class="center"> <?php echo trans_bool( $t_released ) ?> </td> <td class="center"> <?php echo $t_date_formatted ?> </td> <td class="center"> <?php $t_version_id = version_get_id( $t_name, $f_project_id ); print_button( 'manage_proj_ver_edit_page.php?version_id=' . $t_version_id, lang_get( 'edit_link' ) ); echo ' '; print_button( 'manage_proj_ver_delete.php?version_id=' . $t_version_id . form_security_param( 'manage_proj_ver_delete' ), lang_get( 'delete_link' ) ); ?> </td> </tr> <?php } # end for loop ?> <!-- Version Add Form --> <tr> <td class="left" colspan="3"> <form method="post" action="manage_proj_ver_add.php"> <?php echo form_security_field( 'manage_proj_ver_add' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <input type="text" name="version" size="32" maxlength="64" /> <input type="submit" name="add_version" class="button" value="<?php echo lang_get( 'add_version_button' ) ?>" /> <input type="submit" name="add_and_edit_version" class="button" value="<?php echo lang_get( 'add_and_edit_version_button' ) ?>" /> </form> </td> </tr> <tr> <td class="left" colspan="3"> <form method="post" action="manage_proj_ver_copy.php"> <?php echo form_security_field( 'manage_proj_ver_copy' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <select name="other_project_id"> <?php print_project_option_list( null, false, $f_project_id ); ?> </select> <input type="submit" name="copy_from" class="button" value="<?php echo lang_get( 'copy_versions_from' ) ?>" /> <input type="submit" name="copy_to" class="button" value="<?php echo lang_get( 'copy_versions_to' ) ?>" /> </form> </td> </tr> </table> </div> <?php # reset the class counter helper_alternate_class( 0 ); ?> <!-- PROJECT CUSTOM FIELD --> <a name="customfields" /> <?php # You need either global permissions or project-specific permissions to link # custom fields if ( access_has_project_level( config_get( 'custom_field_link_threshold' ), $f_project_id ) && ( count( custom_field_get_ids() ) > 0 ) ) { ?> <br /> <div align="center"> <table class="width75" cellspacing="1"> <tr class="title"> <td class="form-title" colspan="3"> <?php echo lang_get( 'custom_fields_setup' ) ?> </td> </tr> <?php $t_custom_fields = custom_field_get_linked_ids( $f_project_id ); if ( count( $t_custom_fields ) > 0 ) { ?> <tr class="row-category"> <td width="50%"> <?php echo lang_get( 'custom_field' ) ?> </td> <td width="25%"> <?php echo lang_get( 'custom_field_sequence' ) ?> </td> <td class="center" width="25%"> <?php echo lang_get( 'actions' ); ?> </td> </tr> <?php $t_index = 0; $t_custom_field_security = form_security_field( 'manage_proj_custom_field_update' ); foreach( $t_custom_fields as $t_field_id ) { $t_desc = custom_field_get_definition( $t_field_id ); ?> <tr <?php echo helper_alternate_class() ?>> <td> <?php echo string_display( $t_desc['name'] ) ?> </td> <td> <form method="post" action="manage_proj_custom_field_update.php"> <?php echo $t_custom_field_security ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <input type="hidden" name="field_id" value="<?php echo $t_field_id ?>" /> <input type="text" name="sequence" value="<?php echo custom_field_get_sequence( $t_field_id, $f_project_id ) ?>" size="2" /> <input type="submit" class="button-small" value="<?php echo lang_get( 'update' ) ?>" /> </form> <?php $t_index++; ?> </td> <td class="center"> <?php # You need global permissions to edit custom field defs print_button( "manage_proj_custom_field_remove.php?field_id={$t_field_id}&project_id={$f_project_id}", lang_get( 'remove_link' ) ); ?> </td> </tr> <?php } # end for loop } ?> <tr> <td class="left" colspan="3"> <form method="post" action="manage_proj_custom_field_add_existing.php"> <?php echo form_security_field( 'manage_proj_custom_field_add_existing' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <select name="field_id"> <?php $t_custom_fields = custom_field_get_ids(); foreach( $t_custom_fields as $t_field_id ) { if( !custom_field_is_linked( $t_field_id, $f_project_id ) ) { $t_desc = custom_field_get_definition( $t_field_id ); echo "<option value=\"$t_field_id\">" . string_attribute( $t_desc['name'] ) . '</option>' ; } } ?> </select> <input type="submit" class="button" value="<?php echo lang_get( 'add_existing_custom_field' ) ?>" /> </form> </td> </tr> <tr> <td class="left" colspan="3"> <form method="post" action="manage_proj_custom_field_copy.php"> <?php echo form_security_field( 'manage_proj_custom_field_copy' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <select name="other_project_id"> <?php print_project_option_list( null, false, $f_project_id ); ?> </select> <input type="submit" name="copy_from" class="button" value="<?php echo lang_get( 'copy_from' ) ?>" /> <input type="submit" name="copy_to" class="button" value="<?php echo lang_get( 'copy_to' ) ?>" /> </form> </td> </tr> </table> </div> <?php } ?> <!-- PROJECT VIEW STATUS --> <br /> <div align="center"> <table class="width75" cellspacing="1"> <tr> <td class="center"> <?php if ( VS_PUBLIC == project_get_field( $f_project_id, 'view_state' ) ) { echo lang_get( 'public_project_msg' ); } else { echo lang_get( 'private_project_msg' ); } ?> </td> </tr> </table> </div> <!-- USER MANAGEMENT (ADD) --> <?php # We want to allow people with global permissions and people with high enough # permissions on the project we are editing if ( access_has_project_level( config_get( 'project_user_threshold' ), $f_project_id ) ) { ?> <br /> <div align="center"> <table class="width75" cellspacing="1"> <form method="post" action="manage_proj_user_add.php"> <?php echo form_security_field( 'manage_proj_user_add' ) ?> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <tr class="title"> <td class="form-title" colspan="5"> <?php echo lang_get( 'add_user_title' ) ?> </td> </tr> <tr class="row-1" valign="top"> <td class="category"> <?php echo lang_get( 'username' ) ?> </td> <td class="category"> <?php echo lang_get( 'access_level' ) ?> </td> <td class="category"> </td> </tr> <tr class="row-1" valign="top"> <td> <select name="user_id[]" multiple="multiple" size="10"> <?php print_project_user_list_option_list( $f_project_id ) ?> </select> </td> <td> <select name="access_level"> <?php # only access levels that are less than or equal current user access level for current project ?> <?php print_project_access_levels_option_list( config_get( 'default_new_account_access_level' ), $f_project_id ) ?> </select> </td> <td> <input type="submit" class="button" value="<?php echo lang_get( 'add_user_button' ) ?>" /> </td> </tr> </form> <!-- Copy Users Form --> <form method="post" action="manage_proj_user_copy.php"> <?php echo form_security_field( 'manage_proj_user_copy' ) ?> <tr> <td class="left" colspan="3"> <input type="hidden" name="project_id" value="<?php echo $f_project_id ?>" /> <select name="other_project_id"> <?php print_project_option_list( null, false, $f_project_id ); ?> </select> <input type="submit" name="copy_from" class="button" value="<?php echo lang_get( 'copy_users_from' ) ?>" /> <input type="submit" name="copy_to" class="button" value="<?php echo lang_get( 'copy_users_to' ) ?>" /> </td> </tr> </form> </table> </div> <?php } ?> <!-- LIST OF USERS --> <br /> <div align="center"> <table class="width75" cellspacing="1"> <tr class="title"> <td class="form-title" colspan="4"> <?php echo lang_get( 'manage_accounts_title' ) ?> </td> </tr> <tr class="row-category"> <td> <?php echo lang_get( 'username' ) ?> </td> <td> <?php echo lang_get( 'email' ) ?> </td> <td> <?php echo lang_get( 'access_level' ) ?> </td> <td class="center"> <?php echo lang_get( 'actions' ) ?> </td> </tr> <?php $t_users = project_get_all_user_rows( $f_project_id ); $t_display = array(); $t_sort = array(); foreach ( $t_users as $t_user ) { $t_user_name = string_attribute( $t_user['username'] ); $t_sort_name = strtolower( $t_user_name ); if ( ( isset( $t_user['realname'] ) ) && ( $t_user['realname'] > "" ) && ( ON == config_get( 'show_realname' ) ) ){ $t_user_name = string_attribute( $t_user['realname'] ) . " (" . $t_user_name . ")"; if ( ON == config_get( 'sort_by_last_name') ) { $t_sort_name_bits = split( ' ', strtolower( $t_user_name ), 2 ); $t_sort_name = $t_sort_name_bits[1] . ', ' . $t_sort_name_bits[1]; } else { $t_sort_name = strtolower( $t_user_name ); } } $t_display[] = $t_user_name; $t_sort[] = $t_sort_name; } array_multisort( $t_sort, SORT_ASC, SORT_STRING, $t_users, $t_display ); # reset the class counter helper_alternate_class( 0 ); $t_user_remove_security = form_security_param( 'manage_proj_user_remove' ); for ($i = 0; $i < count( $t_sort ); $i++ ) { $t_user = $t_users[$i]; ?> <tr <?php echo helper_alternate_class() ?>> <td> <?php echo $t_display[$i] ?> </td> <td> <?php $t_email = user_get_email( $t_user['id'] ); print_email_link( $t_email, $t_email ); ?> </td> <td> <?php echo get_enum_element( 'access_levels', $t_user['access_level'] ) ?> </td> <td class="center"> <?php # You need global or project-specific permissions to remove users # from this project if ( access_has_project_level( config_get( 'project_user_threshold' ), $f_project_id ) ) { if ( project_includes_user( $f_project_id, $t_user['id'] ) ) { print_button( 'manage_proj_user_remove.php?project_id=' . $f_project_id . '&user_id=' . $t_user['id'] . $t_user_remove_security, lang_get( 'remove_link' ) ); } } ?> </td> </tr> <?php } # end for ?> <tr> <td> </td> <td> </td> <td> </td> <td class="center"> <?php # You need global or project-specific permissions to remove users # from this project if ( access_has_project_level( config_get( 'project_user_threshold' ), $f_project_id ) ) { print_button( 'manage_proj_user_remove.php?project_id=' . $f_project_id . $t_user_remove_security, lang_get( 'remove_all_link' ) ); } ?> </td> </tr> </table> </div> <?php html_page_bottom1( __FILE__ ) ?>