1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-11-29 18:22:41 +01:00

Improve UI for "wait" and "answered" MFA challenges

Summary:
Depends on D19906. Ref T13222. This isn't going to win any design awards, but make the "wait" and "answered" elements a little more clear.

Ideally, the icon parts could be animated Google Authenticator-style timers (but I think we'd need to draw them in a `<canvas />` unless there's some clever trick that I don't know) or maybe we could just have the background be like a "water level" that empties out. Not sure I'm going to actually write the JS for either of those, but the UI at least looks a little more intentional.

Test Plan:
{F6070914}

{F6070915}

Reviewers: amckinley

Reviewed By: amckinley

Maniphest Tasks: T13222

Differential Revision: https://secure.phabricator.com/D19908
This commit is contained in:
epriestley 2018-12-18 12:37:00 -08:00
parent 918f4ebcd8
commit 1729e7b467
6 changed files with 121 additions and 7 deletions

View file

@ -9,7 +9,7 @@ return array(
'names' => array( 'names' => array(
'conpherence.pkg.css' => 'e68cf1fa', 'conpherence.pkg.css' => 'e68cf1fa',
'conpherence.pkg.js' => '15191c65', 'conpherence.pkg.js' => '15191c65',
'core.pkg.css' => '9d1148a4', 'core.pkg.css' => '47535fd5',
'core.pkg.js' => 'bd89cb1d', 'core.pkg.js' => 'bd89cb1d',
'differential.pkg.css' => '06dc617c', 'differential.pkg.css' => '06dc617c',
'differential.pkg.js' => 'ef0b989b', 'differential.pkg.js' => 'ef0b989b',
@ -151,7 +151,7 @@ return array(
'rsrc/css/phui/phui-document.css' => 'c4ac41f9', 'rsrc/css/phui/phui-document.css' => 'c4ac41f9',
'rsrc/css/phui/phui-feed-story.css' => '44a9c8e9', 'rsrc/css/phui/phui-feed-story.css' => '44a9c8e9',
'rsrc/css/phui/phui-fontkit.css' => '1320ed01', 'rsrc/css/phui/phui-fontkit.css' => '1320ed01',
'rsrc/css/phui/phui-form-view.css' => '2f43fae7', 'rsrc/css/phui/phui-form-view.css' => 'b04e08d9',
'rsrc/css/phui/phui-form.css' => '7aaa04e3', 'rsrc/css/phui/phui-form.css' => '7aaa04e3',
'rsrc/css/phui/phui-head-thing.css' => 'fd311e5f', 'rsrc/css/phui/phui-head-thing.css' => 'fd311e5f',
'rsrc/css/phui/phui-header-view.css' => '1ba8b707', 'rsrc/css/phui/phui-header-view.css' => '1ba8b707',
@ -819,7 +819,7 @@ return array(
'phui-font-icon-base-css' => '870a7360', 'phui-font-icon-base-css' => '870a7360',
'phui-fontkit-css' => '1320ed01', 'phui-fontkit-css' => '1320ed01',
'phui-form-css' => '7aaa04e3', 'phui-form-css' => '7aaa04e3',
'phui-form-view-css' => '2f43fae7', 'phui-form-view-css' => 'b04e08d9',
'phui-head-thing-view-css' => 'fd311e5f', 'phui-head-thing-view-css' => 'fd311e5f',
'phui-header-view-css' => '1ba8b707', 'phui-header-view-css' => '1ba8b707',
'phui-hovercard' => '1bd28176', 'phui-hovercard' => '1bd28176',

View file

@ -1946,6 +1946,7 @@ phutil_register_library_map(array(
'PHUIFormInsetView' => 'view/form/PHUIFormInsetView.php', 'PHUIFormInsetView' => 'view/form/PHUIFormInsetView.php',
'PHUIFormLayoutView' => 'view/form/PHUIFormLayoutView.php', 'PHUIFormLayoutView' => 'view/form/PHUIFormLayoutView.php',
'PHUIFormNumberControl' => 'view/form/control/PHUIFormNumberControl.php', 'PHUIFormNumberControl' => 'view/form/control/PHUIFormNumberControl.php',
'PHUIFormTimerControl' => 'view/form/control/PHUIFormTimerControl.php',
'PHUIHandleListView' => 'applications/phid/view/PHUIHandleListView.php', 'PHUIHandleListView' => 'applications/phid/view/PHUIHandleListView.php',
'PHUIHandleTagListView' => 'applications/phid/view/PHUIHandleTagListView.php', 'PHUIHandleTagListView' => 'applications/phid/view/PHUIHandleTagListView.php',
'PHUIHandleView' => 'applications/phid/view/PHUIHandleView.php', 'PHUIHandleView' => 'applications/phid/view/PHUIHandleView.php',
@ -7574,6 +7575,7 @@ phutil_register_library_map(array(
'PHUIFormInsetView' => 'AphrontView', 'PHUIFormInsetView' => 'AphrontView',
'PHUIFormLayoutView' => 'AphrontView', 'PHUIFormLayoutView' => 'AphrontView',
'PHUIFormNumberControl' => 'AphrontFormControl', 'PHUIFormNumberControl' => 'AphrontFormControl',
'PHUIFormTimerControl' => 'AphrontFormControl',
'PHUIHandleListView' => 'AphrontTagView', 'PHUIHandleListView' => 'AphrontTagView',
'PHUIHandleTagListView' => 'AphrontTagView', 'PHUIHandleTagListView' => 'AphrontTagView',
'PHUIHandleView' => 'AphrontView', 'PHUIHandleView' => 'AphrontView',

View file

@ -190,16 +190,25 @@ abstract class PhabricatorAuthFactor extends Phobject {
$error = $result->getErrorMessage(); $error = $result->getErrorMessage();
return id(new AphrontFormMarkupControl()) $icon = id(new PHUIIconView())
->setValue($error) ->setIcon('fa-clock-o', 'red');
return id(new PHUIFormTimerControl())
->setIcon($icon)
->appendChild($error)
->setError(pht('Wait')); ->setError(pht('Wait'));
} }
private function newAnsweredControl( private function newAnsweredControl(
PhabricatorAuthFactorResult $result) { PhabricatorAuthFactorResult $result) {
return id(new AphrontFormMarkupControl()) $icon = id(new PHUIIconView())
->setValue(pht('Answered!')); ->setIcon('fa-check-circle-o', 'green');
return id(new PHUIFormTimerControl())
->setIcon($icon)
->appendChild(
pht('You responded to this challenge correctly.'));
} }

View file

@ -1673,6 +1673,51 @@ final class PhabricatorUSEnglishTranslation
'pass: %2$s.', 'pass: %2$s.',
), ),
'This factor recently issued a challenge to a different login '.
'session. Wait %s second(s) for the code to cycle, then try '.
'again.' => array(
'This factor recently issued a challenge to a different login '.
'session. Wait %s second for the code to cycle, then try '.
'again.',
'This factor recently issued a challenge to a different login '.
'session. Wait %s seconds for the code to cycle, then try '.
'again.',
),
'This factor recently issued a challenge for a different '.
'workflow. Wait %s second(s) for the code to cycle, then try '.
'again.' => array(
'This factor recently issued a challenge for a different '.
'workflow. Wait %s second for the code to cycle, then try '.
'again.',
'This factor recently issued a challenge for a different '.
'workflow. Wait %s seconds for the code to cycle, then try '.
'again.',
),
'This factor recently issued a challenge which has expired. '.
'A new challenge can not be issued yet. Wait %s second(s) for '.
'the code to cycle, then try again.' => array(
'This factor recently issued a challenge which has expired. '.
'A new challenge can not be issued yet. Wait %s second for '.
'the code to cycle, then try again.',
'This factor recently issued a challenge which has expired. '.
'A new challenge can not be issued yet. Wait %s seconds for '.
'the code to cycle, then try again.',
),
'You recently provided a response to this factor. Responses '.
'may not be reused. Wait %s second(s) for the code to cycle, '.
'then try again.' => array(
'You recently provided a response to this factor. Responses '.
'may not be reused. Wait %s second for the code to cycle, '.
'then try again.',
'You recently provided a response to this factor. Responses '.
'may not be reused. Wait %s seconds for the code to cycle, '.
'then try again.',
),
); );
} }

View file

@ -0,0 +1,40 @@
<?php
final class PHUIFormTimerControl extends AphrontFormControl {
private $icon;
public function setIcon(PHUIIconView $icon) {
$this->icon = $icon;
return $this;
}
public function getIcon() {
return $this->icon;
}
protected function getCustomControlClass() {
return 'phui-form-timer';
}
protected function renderInput() {
$icon_cell = phutil_tag(
'td',
array(
'class' => 'phui-form-timer-icon',
),
$this->getIcon());
$content_cell = phutil_tag(
'td',
array(
'class' => 'phui-form-timer-content',
),
$this->renderChildren());
$row = phutil_tag('tr', array(), array($icon_cell, $content_cell));
return phutil_tag('table', array(), $row);
}
}

View file

@ -556,3 +556,21 @@ properly, and submit values. */
.phuix-form-checkbox-label { .phuix-form-checkbox-label {
margin-left: 4px; margin-left: 4px;
} }
.phui-form-timer-icon {
width: 28px;
height: 28px;
padding: 4px;
font-size: 18px;
background: {$greybackground};
border-radius: 4px;
text-align: center;
vertical-align: middle;
text-shadow: 1px 1px rgba(0, 0, 0, 0.05);
}
.phui-form-timer-content {
padding: 4px 8px;
color: {$darkgreytext};
vertical-align: middle;
}