From 7cae104de1cd89141261af718e777f55c571d7bb Mon Sep 17 00:00:00 2001 From: Frederic Guillot Date: Sat, 27 Jun 2015 15:40:42 -0400 Subject: Improve user creation form to automatically add project member and enable notifications --- app/Controller/User.php | 9 ++++++--- app/Template/user/index.php | 3 --- app/Template/user/new.php | 38 +++++++++++++++++++++++--------------- 3 files changed, 29 insertions(+), 21 deletions(-) (limited to 'app') diff --git a/app/Controller/User.php b/app/Controller/User.php index 1a7810b0..6628bcb6 100644 --- a/app/Controller/User.php +++ b/app/Controller/User.php @@ -69,7 +69,6 @@ class User extends Base $this->response->html( $this->template->layout('user/index', array( 'board_selector' => $this->projectPermission->getAllowedProjects($this->userSession->getId()), - 'projects' => $this->project->getList(), 'title' => t('Users').' ('.$paginator->getTotal().')', 'paginator' => $paginator, ))); @@ -105,14 +104,19 @@ class User extends Base if ($valid) { + $project_id = empty($values['project_id']) ? 0 : $values['project_id']; + unset($values['project_id']); + $user_id = $this->user->create($values); if ($user_id !== false) { + $this->projectPermission->addMember($project_id, $user_id); $this->session->flash(t('User created successfully.')); $this->response->redirect($this->helper->url->to('user', 'show', array('user_id' => $user_id))); } else { $this->session->flashError(t('Unable to create your user.')); + $values['project_id'] = $project_id; } } @@ -128,7 +132,6 @@ class User extends Base { $user = $this->getUser(); $this->response->html($this->layout('user/show', array( - 'projects' => $this->projectPermission->getAllowedProjects($user['id']), 'user' => $user, 'timezones' => $this->config->getTimezones(true), 'languages' => $this->config->getLanguages(true), @@ -230,7 +233,7 @@ class User extends Base } $this->response->html($this->layout('user/notifications', array( - 'projects' => $this->projectPermission->getAllowedProjects($user['id']), + 'projects' => $this->projectPermission->getMemberProjects($user['id']), 'notifications' => $this->notification->readSettings($user['id']), 'user' => $user, ))); diff --git a/app/Template/user/index.php b/app/Template/user/index.php index 08184698..fc575466 100644 --- a/app/Template/user/index.php +++ b/app/Template/user/index.php @@ -42,9 +42,6 @@ - - e($projects[$user['default_project_id']]) : t('None'); ?> - diff --git a/app/Template/user/new.php b/app/Template/user/new.php index 5c55b0bb..0db1e824 100644 --- a/app/Template/user/new.php +++ b/app/Template/user/new.php @@ -9,28 +9,36 @@ form->csrf() ?> - form->label(t('Username'), 'username') ?> - form->text('username', $values, $errors, array('autofocus', 'required', 'maxlength="50"')) ?>
+
+ form->label(t('Username'), 'username') ?> + form->text('username', $values, $errors, array('autofocus', 'required', 'maxlength="50"')) ?>
- form->label(t('Name'), 'name') ?> - form->text('name', $values, $errors) ?>
+ form->label(t('Name'), 'name') ?> + form->text('name', $values, $errors) ?>
- form->label(t('Email'), 'email') ?> - form->email('email', $values, $errors) ?>
+ form->label(t('Email'), 'email') ?> + form->email('email', $values, $errors) ?>
- form->label(t('Password'), 'password') ?> - form->password('password', $values, $errors, array('required')) ?>
+ form->label(t('Password'), 'password') ?> + form->password('password', $values, $errors, array('required')) ?>
- form->label(t('Confirmation'), 'confirmation') ?> - form->password('confirmation', $values, $errors, array('required')) ?>
+ form->label(t('Confirmation'), 'confirmation') ?> + form->password('confirmation', $values, $errors, array('required')) ?>
+
+ +
+ form->label(t('Add project member'), 'project_id') ?> + form->select('project_id', $projects, $values, $errors) ?>
- form->label(t('Timezone'), 'timezone') ?> - form->select('timezone', $timezones, $values, $errors) ?>
+ form->label(t('Timezone'), 'timezone') ?> + form->select('timezone', $timezones, $values, $errors) ?>
- form->label(t('Language'), 'language') ?> - form->select('language', $languages, $values, $errors) ?>
+ form->label(t('Language'), 'language') ?> + form->select('language', $languages, $values, $errors) ?>
- form->checkbox('is_admin', t('Administrator'), 1, isset($values['is_admin']) && $values['is_admin'] == 1 ? true : false) ?> + form->checkbox('notifications_enabled', t('Enable notifications'), 1, isset($values['notifications_enabled']) && $values['notifications_enabled'] == 1 ? true : false) ?> + form->checkbox('is_admin', t('Administrator'), 1, isset($values['is_admin']) && $values['is_admin'] == 1 ? true : false) ?> +
-- cgit v1.2.3