First cut of progress bars (PHUISegmentBarView)
Summary:
Ref T10288.
I couldn't figure out how to reasonably get the interior right borders to round like the mock, but I think this is otherwise mostly faithful. Feel free to fix stuff.
Test Plan: {F1100415}
Reviewers: chad
Reviewed By: chad
Maniphest Tasks: T10288
Differential Revision: https://secure.phabricator.com/D15219
			
			
This commit is contained in:
		| @@ -149,6 +149,7 @@ return array( | |||||||
|     'rsrc/css/phui/phui-profile-menu.css' => '4a243229', |     'rsrc/css/phui/phui-profile-menu.css' => '4a243229', | ||||||
|     'rsrc/css/phui/phui-property-list-view.css' => '27b2849e', |     'rsrc/css/phui/phui-property-list-view.css' => '27b2849e', | ||||||
|     'rsrc/css/phui/phui-remarkup-preview.css' => '1a8f2591', |     'rsrc/css/phui/phui-remarkup-preview.css' => '1a8f2591', | ||||||
|  |     'rsrc/css/phui/phui-segment-bar-view.css' => '728e4d19', | ||||||
|     'rsrc/css/phui/phui-spacing.css' => '042804d6', |     'rsrc/css/phui/phui-spacing.css' => '042804d6', | ||||||
|     'rsrc/css/phui/phui-status.css' => '888cedb8', |     'rsrc/css/phui/phui-status.css' => '888cedb8', | ||||||
|     'rsrc/css/phui/phui-tag-view.css' => '9d5d4400', |     'rsrc/css/phui/phui-tag-view.css' => '9d5d4400', | ||||||
| @@ -825,6 +826,7 @@ return array( | |||||||
|     'phui-profile-menu-css' => '4a243229', |     'phui-profile-menu-css' => '4a243229', | ||||||
|     'phui-property-list-view-css' => '27b2849e', |     'phui-property-list-view-css' => '27b2849e', | ||||||
|     'phui-remarkup-preview-css' => '1a8f2591', |     'phui-remarkup-preview-css' => '1a8f2591', | ||||||
|  |     'phui-segment-bar-view-css' => '728e4d19', | ||||||
|     'phui-spacing-css' => '042804d6', |     'phui-spacing-css' => '042804d6', | ||||||
|     'phui-status-list-view-css' => '888cedb8', |     'phui-status-list-view-css' => '888cedb8', | ||||||
|     'phui-tag-view-css' => '9d5d4400', |     'phui-tag-view-css' => '9d5d4400', | ||||||
|   | |||||||
| @@ -1522,6 +1522,8 @@ phutil_register_library_map(array( | |||||||
|     'PHUIPropertyListView' => 'view/phui/PHUIPropertyListView.php', |     'PHUIPropertyListView' => 'view/phui/PHUIPropertyListView.php', | ||||||
|     'PHUIRemarkupPreviewPanel' => 'view/phui/PHUIRemarkupPreviewPanel.php', |     'PHUIRemarkupPreviewPanel' => 'view/phui/PHUIRemarkupPreviewPanel.php', | ||||||
|     'PHUIRemarkupView' => 'infrastructure/markup/view/PHUIRemarkupView.php', |     'PHUIRemarkupView' => 'infrastructure/markup/view/PHUIRemarkupView.php', | ||||||
|  |     'PHUISegmentBarSegmentView' => 'view/phui/PHUISegmentBarSegmentView.php', | ||||||
|  |     'PHUISegmentBarView' => 'view/phui/PHUISegmentBarView.php', | ||||||
|     'PHUISpacesNamespaceContextView' => 'applications/spaces/view/PHUISpacesNamespaceContextView.php', |     'PHUISpacesNamespaceContextView' => 'applications/spaces/view/PHUISpacesNamespaceContextView.php', | ||||||
|     'PHUIStatusItemView' => 'view/phui/PHUIStatusItemView.php', |     'PHUIStatusItemView' => 'view/phui/PHUIStatusItemView.php', | ||||||
|     'PHUIStatusListView' => 'view/phui/PHUIStatusListView.php', |     'PHUIStatusListView' => 'view/phui/PHUIStatusListView.php', | ||||||
| @@ -5705,6 +5707,8 @@ phutil_register_library_map(array( | |||||||
|     'PHUIPropertyListView' => 'AphrontView', |     'PHUIPropertyListView' => 'AphrontView', | ||||||
|     'PHUIRemarkupPreviewPanel' => 'AphrontTagView', |     'PHUIRemarkupPreviewPanel' => 'AphrontTagView', | ||||||
|     'PHUIRemarkupView' => 'AphrontView', |     'PHUIRemarkupView' => 'AphrontView', | ||||||
|  |     'PHUISegmentBarSegmentView' => 'AphrontTagView', | ||||||
|  |     'PHUISegmentBarView' => 'AphrontTagView', | ||||||
|     'PHUISpacesNamespaceContextView' => 'AphrontView', |     'PHUISpacesNamespaceContextView' => 'AphrontView', | ||||||
|     'PHUIStatusItemView' => 'AphrontTagView', |     'PHUIStatusItemView' => 'AphrontTagView', | ||||||
|     'PHUIStatusListView' => 'AphrontTagView', |     'PHUIStatusListView' => 'AphrontTagView', | ||||||
|   | |||||||
| @@ -12,10 +12,7 @@ final class PhabricatorAphrontBarUIExample extends PhabricatorUIExample { | |||||||
|  |  | ||||||
|   public function renderExample() { |   public function renderExample() { | ||||||
|     $out = array(); |     $out = array(); | ||||||
|     $out[] = $this->renderTestThings('AphrontProgressBarView', 13, 10); |     $out[] = $this->renderRainbow(); | ||||||
|     $out[] = $this->renderTestThings('AphrontGlyphBarView', 13, 10); |  | ||||||
|     $out[] = $this->renderWeirdOrderGlyphBars(); |  | ||||||
|     $out[] = $this->renderAsciiStarBar(); |  | ||||||
|     return $out; |     return $out; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -26,48 +23,46 @@ final class PhabricatorAphrontBarUIExample extends PhabricatorUIExample { | |||||||
|       ->appendChild($thing); |       ->appendChild($thing); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   private function renderTestThings($class, $max, $incr) { |   private function renderRainbow() { | ||||||
|  |     $colors = array( | ||||||
|  |       'red', | ||||||
|  |       'orange', | ||||||
|  |       'yellow', | ||||||
|  |       'green', | ||||||
|  |       'blue', | ||||||
|  |       'indigo', | ||||||
|  |       'violet', | ||||||
|  |     ); | ||||||
|  |  | ||||||
|  |     $labels = array( | ||||||
|  |       pht('Empty'), | ||||||
|  |       pht('Red'), | ||||||
|  |       pht('Orange'), | ||||||
|  |       pht('Yellow'), | ||||||
|  |       pht('Green'), | ||||||
|  |       pht('Blue'), | ||||||
|  |       pht('Indigo'), | ||||||
|  |       pht('Violet'), | ||||||
|  |     ); | ||||||
|  |  | ||||||
|     $bars = array(); |     $bars = array(); | ||||||
|     for ($ii = 0; $ii <= $max; $ii++) { |  | ||||||
|       $bars[] = newv($class, array()) |  | ||||||
|         ->setValue($ii * $incr) |  | ||||||
|         ->setMax($max * $incr) |  | ||||||
|         ->setCaption("{$ii} outta {$max} ain't bad!"); |  | ||||||
|     } |  | ||||||
|     return $this->wrap("Test {$class}", $bars); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   private function renderWeirdOrderGlyphBars() { |     for ($jj = -1; $jj < count($colors); $jj++) { | ||||||
|     $views = array(); |       $bar = id(new PHUISegmentBarView()) | ||||||
|     $indices = array(1, 3, 7, 4, 2, 8, 9, 5, 10, 6); |         ->setLabel($labels[$jj + 1]); | ||||||
|     $max = count($indices); |       for ($ii = 0; $ii <= $jj; $ii++) { | ||||||
|     foreach ($indices as $index) { |         $bar->newSegment() | ||||||
|       $views[] = id(new AphrontGlyphBarView()) |           ->setWidth(1 / 7) | ||||||
|         ->setValue($index) |           ->setColor($colors[$ii]); | ||||||
|         ->setMax($max) |       } | ||||||
|         ->setNumGlyphs(5) |       $bars[] = $bar; | ||||||
|         ->setCaption("Lol score is {$index}/{$max}") |  | ||||||
|         ->setGlyph(hsprintf('%s', 'LOL!')) |  | ||||||
|         ->setBackgroundGlyph(hsprintf('%s', '____')); |  | ||||||
|       $views[] = hsprintf('<div style="clear:both;"></div>'); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return $this->wrap( |     $bars = phutil_implode_html( | ||||||
|       pht('Glyph bars in weird order'), |       phutil_tag('br'), | ||||||
|       $views); |       $bars); | ||||||
|   } |  | ||||||
|  |  | ||||||
|   private function renderAsciiStarBar() { |     return $this->wrap(pht('Rainbow Bars'), $bars); | ||||||
|     $bar = id(new AphrontGlyphBarView()) |  | ||||||
|         ->setValue(50) |  | ||||||
|         ->setMax(100) |  | ||||||
|         ->setCaption(pht('Glyphs!')) |  | ||||||
|         ->setNumGlyphs(10) |  | ||||||
|         ->setGlyph(hsprintf('%s', '*')); |  | ||||||
|  |  | ||||||
|     return $this->wrap( |  | ||||||
|       pht('ASCII star glyph bar'), |  | ||||||
|       $bar); |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										57
									
								
								src/view/phui/PHUISegmentBarSegmentView.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								src/view/phui/PHUISegmentBarSegmentView.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | final class PHUISegmentBarSegmentView extends AphrontTagView { | ||||||
|  |  | ||||||
|  |   private $width; | ||||||
|  |   private $color; | ||||||
|  |   private $position; | ||||||
|  |  | ||||||
|  |   public function setWidth($width) { | ||||||
|  |     $this->width = $width; | ||||||
|  |     return $this; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public function getWidth() { | ||||||
|  |     return $this->width; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public function setColor($color) { | ||||||
|  |     $this->color = $color; | ||||||
|  |     return $this; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public function setPosition($position) { | ||||||
|  |     $this->position = $position; | ||||||
|  |     return $this; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   protected function canAppendChild() { | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   protected function getTagAttributes() { | ||||||
|  |     $classes = array( | ||||||
|  |       'phui-segment-bar-segment-view', | ||||||
|  |     ); | ||||||
|  |  | ||||||
|  |     if ($this->color) { | ||||||
|  |       $classes[] = $this->color; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Convert width to a percentage, and round it up slightly so that bars | ||||||
|  |     // are full if they have, e.g., three segments at 1/3 + 1/3 + 1/3. | ||||||
|  |     $width = 100 * $this->width; | ||||||
|  |     $width = ceil(100 * $width) / 100; | ||||||
|  |     $width = sprintf('%.2f%%', $width); | ||||||
|  |  | ||||||
|  |     $left = 100 * $this->position; | ||||||
|  |     $left = floor(100 * $left) / 100; | ||||||
|  |     $left = sprintf('%.2f%%', $left); | ||||||
|  |  | ||||||
|  |     return array( | ||||||
|  |       'class' => implode(' ', $classes), | ||||||
|  |       'style' => "left: {$left}; width: {$width};", | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										65
									
								
								src/view/phui/PHUISegmentBarView.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/view/phui/PHUISegmentBarView.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | final class PHUISegmentBarView extends AphrontTagView { | ||||||
|  |  | ||||||
|  |   private $label; | ||||||
|  |   private $segments = array(); | ||||||
|  |  | ||||||
|  |   public function setLabel($label) { | ||||||
|  |     $this->label = $label; | ||||||
|  |     return $this; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public function newSegment() { | ||||||
|  |     $segment = new PHUISegmentBarSegmentView(); | ||||||
|  |     $this->segments[] = $segment; | ||||||
|  |     return $segment; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   protected function canAppendChild() { | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   protected function getTagAttributes() { | ||||||
|  |     return array( | ||||||
|  |       'class' => 'phui-segment-bar-view', | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   protected function getTagContent() { | ||||||
|  |     require_celerity_resource('phui-segment-bar-view-css'); | ||||||
|  |  | ||||||
|  |     $label = $this->label; | ||||||
|  |     if (strlen($label)) { | ||||||
|  |       $label = phutil_tag( | ||||||
|  |         'div', | ||||||
|  |         array( | ||||||
|  |           'class' => 'phui-segment-bar-label', | ||||||
|  |         ), | ||||||
|  |         $label); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     $segments = $this->segments; | ||||||
|  |  | ||||||
|  |     $position = 0; | ||||||
|  |     foreach ($segments as $segment) { | ||||||
|  |       $segment->setPosition($position); | ||||||
|  |       $position += $segment->getWidth(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     $segments = array_reverse($segments); | ||||||
|  |  | ||||||
|  |     $segments = phutil_tag( | ||||||
|  |       'div', | ||||||
|  |       array( | ||||||
|  |         'class' => 'phui-segment-bar-segments', | ||||||
|  |       ), | ||||||
|  |       $segments); | ||||||
|  |  | ||||||
|  |     return array( | ||||||
|  |       $label, | ||||||
|  |       $segments, | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										71
									
								
								webroot/rsrc/css/phui/phui-segment-bar-view.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								webroot/rsrc/css/phui/phui-segment-bar-view.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | |||||||
|  | /** | ||||||
|  |  * @provides phui-segment-bar-view-css | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | .phui-segment-bar-label { | ||||||
|  |   font-size: {$smallerfontsize}; | ||||||
|  |   margin-bottom: 4px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segments { | ||||||
|  |   background: {$lightgreybackground}; | ||||||
|  |   border-radius: 4px; | ||||||
|  |   position: relative; | ||||||
|  |   overflow: hidden; | ||||||
|  |   height: 8px; | ||||||
|  |   border: 1px solid rgba(0, 0, 0, 0.15); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view { | ||||||
|  |   position: absolute; | ||||||
|  |   top: 0; | ||||||
|  |   bottom: 0; | ||||||
|  |   margin-left: -4px; | ||||||
|  |   border-right: 5px solid; | ||||||
|  |   border-radius: 0 4px 4px 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.red { | ||||||
|  |   background: {$red}; | ||||||
|  |   border-color: {$red}; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.orange { | ||||||
|  |   background: {$orange}; | ||||||
|  |   border-color: {$orange}; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.yellow { | ||||||
|  |   background: {$yellow}; | ||||||
|  |   border-color: {$yellow} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.green { | ||||||
|  |   background: {$green}; | ||||||
|  |   border-color: {$green}; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.blue { | ||||||
|  |   background: {$blue}; | ||||||
|  |   border-color: {$blue}; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.indigo { | ||||||
|  |   background: {$indigo}; | ||||||
|  |   border-color: {$indigo}; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.violet { | ||||||
|  |   background: {$violet}; | ||||||
|  |   border-color: {$violet}; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.pink { | ||||||
|  |   background: {$pink}; | ||||||
|  |   border-color: {$pink}; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .phui-segment-bar-segment-view.sky { | ||||||
|  |   background: {$sky}; | ||||||
|  |   border-color: {$sky}; | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user
	 epriestley
					epriestley