2012-04-04 21:14:10 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class AphrontFormDateControl extends AphrontFormControl {
|
|
|
|
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
private $initialTime;
|
2013-05-31 01:19:43 +02:00
|
|
|
private $zone;
|
2012-04-04 21:14:10 +02:00
|
|
|
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
private $valueDay;
|
|
|
|
private $valueMonth;
|
|
|
|
private $valueYear;
|
|
|
|
private $valueTime;
|
2013-05-31 01:19:43 +02:00
|
|
|
private $allowNull;
|
|
|
|
|
|
|
|
public function setAllowNull($allow_null) {
|
|
|
|
$this->allowNull = $allow_null;
|
|
|
|
return $this;
|
|
|
|
}
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
|
|
|
|
const TIME_START_OF_DAY = 'start-of-day';
|
|
|
|
const TIME_END_OF_DAY = 'end-of-day';
|
|
|
|
const TIME_START_OF_BUSINESS = 'start-of-business';
|
|
|
|
const TIME_END_OF_BUSINESS = 'end-of-business';
|
|
|
|
|
|
|
|
public function setInitialTime($time) {
|
|
|
|
$this->initialTime = $time;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2012-04-04 21:14:10 +02:00
|
|
|
public function readValueFromRequest(AphrontRequest $request) {
|
|
|
|
$day = $request->getInt($this->getDayInputName());
|
|
|
|
$month = $request->getInt($this->getMonthInputName());
|
|
|
|
$year = $request->getInt($this->getYearInputName());
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
$time = $request->getStr($this->getTimeInputName());
|
2013-05-31 01:19:43 +02:00
|
|
|
$enabled = $request->getBool($this->getCheckboxInputName());
|
|
|
|
|
|
|
|
if ($this->allowNull && !$enabled) {
|
|
|
|
$this->setError(null);
|
|
|
|
$this->setValue(null);
|
|
|
|
return;
|
|
|
|
}
|
2012-04-04 21:14:10 +02:00
|
|
|
|
|
|
|
$err = $this->getError();
|
|
|
|
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
if ($day || $month || $year || $time) {
|
|
|
|
$this->valueDay = $day;
|
|
|
|
$this->valueMonth = $month;
|
|
|
|
$this->valueYear = $year;
|
|
|
|
$this->valueTime = $time;
|
2012-04-04 21:14:10 +02:00
|
|
|
|
|
|
|
// Assume invalid.
|
|
|
|
$err = 'Invalid';
|
|
|
|
|
2013-05-31 01:19:43 +02:00
|
|
|
$zone = $this->getTimezone();
|
|
|
|
|
2012-04-04 21:14:10 +02:00
|
|
|
try {
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
$date = new DateTime("{$year}-{$month}-{$day} {$time}", $zone);
|
|
|
|
$value = $date->format('U');
|
2012-04-04 21:14:10 +02:00
|
|
|
} catch (Exception $ex) {
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
$value = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($value) {
|
|
|
|
$this->setValue($value);
|
|
|
|
$err = null;
|
|
|
|
} else {
|
|
|
|
$this->setValue(null);
|
|
|
|
}
|
|
|
|
} else {
|
2013-05-31 01:19:43 +02:00
|
|
|
$value = $this->getInitialValue();
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
if ($value) {
|
|
|
|
$this->setValue($value);
|
|
|
|
} else {
|
|
|
|
$this->setValue(null);
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->setError($err);
|
|
|
|
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
return $this->getValue();
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|
|
|
|
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
protected function getCustomControlClass() {
|
|
|
|
return 'aphront-form-control-date';
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|
|
|
|
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
public function setValue($epoch) {
|
|
|
|
$result = parent::setValue($epoch);
|
2012-04-04 21:14:10 +02:00
|
|
|
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
if ($epoch === null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$readable = $this->formatTime($epoch, 'Y!m!d!g:i A');
|
|
|
|
$readable = explode('!', $readable, 4);
|
|
|
|
|
|
|
|
$this->valueYear = $readable[0];
|
|
|
|
$this->valueMonth = $readable[1];
|
|
|
|
$this->valueDay = $readable[2];
|
|
|
|
$this->valueTime = $readable[3];
|
|
|
|
|
|
|
|
return $result;
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private function getMinYear() {
|
|
|
|
$cur_year = $this->formatTime(
|
|
|
|
time(),
|
|
|
|
'Y');
|
|
|
|
$val_year = $this->getYearInputValue();
|
|
|
|
|
|
|
|
return min($cur_year, $val_year) - 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getMaxYear() {
|
|
|
|
$cur_year = $this->formatTime(
|
|
|
|
time(),
|
|
|
|
'Y');
|
|
|
|
$val_year = $this->getYearInputValue();
|
|
|
|
|
|
|
|
return max($cur_year, $val_year) + 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getDayInputValue() {
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
return $this->valueDay;
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private function getMonthInputValue() {
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
return $this->valueMonth;
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private function getYearInputValue() {
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
return $this->valueYear;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getTimeInputValue() {
|
|
|
|
return $this->valueTime;
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private function formatTime($epoch, $fmt) {
|
|
|
|
return phabricator_format_local_time(
|
|
|
|
$epoch,
|
|
|
|
$this->user,
|
|
|
|
$fmt);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getDayInputName() {
|
|
|
|
return $this->getName().'_d';
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getMonthInputName() {
|
|
|
|
return $this->getName().'_m';
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getYearInputName() {
|
|
|
|
return $this->getName().'_y';
|
|
|
|
}
|
|
|
|
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
private function getTimeInputName() {
|
|
|
|
return $this->getName().'_t';
|
|
|
|
}
|
|
|
|
|
2013-05-31 01:19:43 +02:00
|
|
|
private function getCheckboxInputName() {
|
|
|
|
return $this->getName().'_e';
|
|
|
|
}
|
|
|
|
|
2012-04-04 21:14:10 +02:00
|
|
|
protected function renderInput() {
|
2013-05-31 01:19:43 +02:00
|
|
|
|
|
|
|
$disabled = null;
|
|
|
|
if ($this->getValue() === null) {
|
|
|
|
$this->setValue($this->getInitialValue());
|
|
|
|
if ($this->allowNull) {
|
|
|
|
$disabled = 'disabled';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-04-04 21:14:10 +02:00
|
|
|
$min_year = $this->getMinYear();
|
|
|
|
$max_year = $this->getMaxYear();
|
|
|
|
|
|
|
|
$days = range(1, 31);
|
2013-01-26 02:06:55 +01:00
|
|
|
$days = array_fuse($days);
|
2012-04-04 21:14:10 +02:00
|
|
|
|
|
|
|
$months = array(
|
2013-03-02 00:37:32 +01:00
|
|
|
1 => pht('Jan'),
|
|
|
|
2 => pht('Feb'),
|
|
|
|
3 => pht('Mar'),
|
|
|
|
4 => pht('Apr'),
|
|
|
|
5 => pht('May'),
|
|
|
|
6 => pht('Jun'),
|
|
|
|
7 => pht('Jul'),
|
|
|
|
8 => pht('Aug'),
|
|
|
|
9 => pht('Sep'),
|
|
|
|
10 => pht('Oct'),
|
|
|
|
11 => pht('Nov'),
|
|
|
|
12 => pht('Dec'),
|
2012-04-04 21:14:10 +02:00
|
|
|
);
|
|
|
|
|
2013-05-31 01:19:43 +02:00
|
|
|
$checkbox = null;
|
|
|
|
if ($this->allowNull) {
|
|
|
|
$checkbox = javelin_tag(
|
|
|
|
'input',
|
|
|
|
array(
|
|
|
|
'type' => 'checkbox',
|
|
|
|
'name' => $this->getCheckboxInputName(),
|
|
|
|
'sigil' => 'calendar-enable',
|
|
|
|
'class' => 'aphront-form-date-enabled-input',
|
|
|
|
'value' => 1,
|
|
|
|
'checked' => ($disabled === null ? 'checked' : null),
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
2012-04-04 21:14:10 +02:00
|
|
|
$years = range($this->getMinYear(), $this->getMaxYear());
|
2013-01-26 02:06:55 +01:00
|
|
|
$years = array_fuse($years);
|
2012-04-04 21:14:10 +02:00
|
|
|
|
|
|
|
$days_sel = AphrontFormSelectControl::renderSelectTag(
|
|
|
|
$this->getDayInputValue(),
|
|
|
|
$days,
|
|
|
|
array(
|
|
|
|
'name' => $this->getDayInputName(),
|
|
|
|
'sigil' => 'day-input',
|
2013-05-31 01:19:43 +02:00
|
|
|
'disabled' => $disabled,
|
2012-04-04 21:14:10 +02:00
|
|
|
));
|
|
|
|
|
|
|
|
$months_sel = AphrontFormSelectControl::renderSelectTag(
|
|
|
|
$this->getMonthInputValue(),
|
|
|
|
$months,
|
|
|
|
array(
|
|
|
|
'name' => $this->getMonthInputName(),
|
|
|
|
'sigil' => 'month-input',
|
2013-05-31 01:19:43 +02:00
|
|
|
'disabled' => $disabled,
|
2012-04-04 21:14:10 +02:00
|
|
|
));
|
|
|
|
|
|
|
|
$years_sel = AphrontFormSelectControl::renderSelectTag(
|
|
|
|
$this->getYearInputValue(),
|
|
|
|
$years,
|
|
|
|
array(
|
|
|
|
'name' => $this->getYearInputName(),
|
|
|
|
'sigil' => 'year-input',
|
2013-05-31 01:19:43 +02:00
|
|
|
'disabled' => $disabled,
|
2012-04-04 21:14:10 +02:00
|
|
|
));
|
|
|
|
|
2013-01-25 21:57:17 +01:00
|
|
|
$cal_icon = javelin_tag(
|
2012-04-04 21:14:10 +02:00
|
|
|
'a',
|
|
|
|
array(
|
|
|
|
'href' => '#',
|
|
|
|
'class' => 'calendar-button',
|
|
|
|
'sigil' => 'calendar-button',
|
|
|
|
),
|
|
|
|
'');
|
|
|
|
|
2013-05-31 01:19:43 +02:00
|
|
|
$time_sel = javelin_tag(
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
'input',
|
2012-04-04 21:14:10 +02:00
|
|
|
array(
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
'name' => $this->getTimeInputName(),
|
|
|
|
'sigil' => 'time-input',
|
|
|
|
'value' => $this->getTimeInputValue(),
|
|
|
|
'type' => 'text',
|
|
|
|
'class' => 'aphront-form-date-time-input',
|
2013-05-31 01:19:43 +02:00
|
|
|
'disabled' => $disabled,
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
),
|
|
|
|
'');
|
|
|
|
|
|
|
|
Javelin::initBehavior('fancy-datepicker', array());
|
2012-04-04 21:14:10 +02:00
|
|
|
|
2013-02-02 15:04:54 +01:00
|
|
|
return javelin_tag(
|
2012-04-04 21:14:10 +02:00
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'aphront-form-date-container',
|
Make date control include times
Summary:
See discussion in T404. Basically, the problem with date-only controls is that they may behave unpredictably in the presence of timezones. When you say "This needs to be done by Oct 23", you probably mean "Oct 23 5PM PST" or something like that, but someone in China may see the "Oct 24" and hit the deadline in good faith but be 10 hours too late. T404 has more discussion and examples. There are ways to fake this, but they get more complicated if the guy in China needs to move the date forward 24 hours.
I think the best solution to this is to not have date-only controls, and always display the time. This makes it absolutley unambiguous what something means, because the guy in the US will set "Oct 23 5PM" and the guy in China will see that accurately in local time.
The downside is that it's slightly more visual clutter and work for the user to specify things precisely, but I added some hints (start/end of day, start/end of business) that will hopefully let us pick the right default in most cases.
Test Plan:
Set some dates.
{F21956}
This has a couple of edge case issues on resize and some not-so-edge-case issues on mobile, but should be good to build T407 on without API changes.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T404, T407
Differential Revision: https://secure.phabricator.com/D3793
2012-10-23 21:00:20 +02:00
|
|
|
'sigil' => 'phabricator-date-control',
|
2013-05-31 01:19:43 +02:00
|
|
|
'meta' => array(
|
|
|
|
'disabled' => (bool)$disabled,
|
|
|
|
),
|
2012-04-04 21:14:10 +02:00
|
|
|
),
|
2013-02-02 15:04:54 +01:00
|
|
|
array(
|
2013-05-31 01:19:43 +02:00
|
|
|
$checkbox,
|
2013-02-02 15:04:54 +01:00
|
|
|
$days_sel,
|
|
|
|
$months_sel,
|
|
|
|
$years_sel,
|
|
|
|
$cal_icon,
|
|
|
|
$time_sel,
|
|
|
|
));
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|
|
|
|
|
2013-05-31 01:19:43 +02:00
|
|
|
private function getTimezone() {
|
|
|
|
if ($this->zone) {
|
|
|
|
return $this->zone;
|
|
|
|
}
|
|
|
|
|
|
|
|
$user = $this->getUser();
|
|
|
|
if (!$this->getUser()) {
|
|
|
|
throw new Exception("Call setUser() before getTimezone()!");
|
|
|
|
}
|
|
|
|
|
|
|
|
$user_zone = $user->getTimezoneIdentifier();
|
|
|
|
$this->zone = new DateTimeZone($user_zone);
|
|
|
|
return $this->zone;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getInitialValue() {
|
|
|
|
$zone = $this->getTimezone();
|
|
|
|
|
|
|
|
// TODO: We could eventually allow these to be customized per install or
|
|
|
|
// per user or both, but let's wait and see.
|
|
|
|
switch ($this->initialTime) {
|
|
|
|
case self::TIME_START_OF_DAY:
|
|
|
|
default:
|
|
|
|
$time = '12:00 AM';
|
|
|
|
break;
|
|
|
|
case self::TIME_START_OF_BUSINESS:
|
|
|
|
$time = '9:00 AM';
|
|
|
|
break;
|
|
|
|
case self::TIME_END_OF_BUSINESS:
|
|
|
|
$time = '5:00 PM';
|
|
|
|
break;
|
|
|
|
case self::TIME_END_OF_DAY:
|
|
|
|
$time = '11:59 PM';
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$today = $this->formatTime(time(), 'Y-m-d');
|
|
|
|
try {
|
|
|
|
$date = new DateTime("{$today} {$time}", $zone);
|
|
|
|
$value = $date->format('U');
|
|
|
|
} catch (Exception $ex) {
|
|
|
|
$value = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $value;
|
|
|
|
}
|
|
|
|
|
2012-04-04 21:14:10 +02:00
|
|
|
}
|