2012-08-15 10:45:06 -07:00
|
|
|
/**
|
2013-09-17 09:12:37 -07:00
|
|
|
* @provides phui-header-view-css
|
2012-08-15 10:45:06 -07:00
|
|
|
*/
|
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
.phui-header-shell {
|
2015-05-18 10:00:15 -07:00
|
|
|
border-bottom: 1px solid {$thinblueborder};
|
2013-07-09 16:23:22 -07:00
|
|
|
overflow: hidden;
|
2015-05-22 08:22:25 -07:00
|
|
|
padding: 0 4px 12px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-header-view {
|
|
|
|
display: table;
|
|
|
|
width: 100%
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-header-row {
|
|
|
|
display: table-row;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-header-col1 {
|
|
|
|
display: table-cell;
|
|
|
|
vertical-align: middle;
|
|
|
|
width: 62px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-header-col2 {
|
|
|
|
display: table-cell;
|
|
|
|
vertical-align: middle;
|
2015-06-25 16:13:32 -07:00
|
|
|
word-break: break-word;
|
2015-05-22 08:22:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.phui-header-col3 {
|
|
|
|
display: table-cell;
|
|
|
|
vertical-align: middle;
|
2012-12-11 14:01:35 -08:00
|
|
|
}
|
|
|
|
|
2017-10-09 10:48:01 -07:00
|
|
|
body .phui-header-shell.phui-header-no-background {
|
2013-09-05 12:29:07 -07:00
|
|
|
background-color: transparent;
|
|
|
|
border: none;
|
|
|
|
}
|
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
body .phui-header-shell.phui-bleed-header {
|
2014-03-06 11:28:24 -08:00
|
|
|
background-color: #fff;
|
|
|
|
border-bottom: 1px solid {$thinblueborder};
|
2013-09-05 12:29:07 -07:00
|
|
|
width: auto;
|
2014-03-06 11:28:24 -08:00
|
|
|
margin: 16px;
|
2013-09-05 12:29:07 -07:00
|
|
|
}
|
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
body .phui-header-shell.phui-bleed-header
|
|
|
|
.phui-header-view {
|
2014-03-06 11:28:24 -08:00
|
|
|
padding: 8px 24px 8px 0;
|
[Redesign] Mobile/Phone design pass
Summary: Ref T8099, Quick descent pass at making header, object lists, tables, filter view, mobile friendly.
Test Plan:
Test home, differential diff, maniphest task, new task, search, and a few other views.
{F414034}
Reviewers: btrahan, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T8099
Differential Revision: https://secure.phabricator.com/D12984
2015-05-22 17:52:51 -07:00
|
|
|
color: {$darkbluetext};
|
2013-09-05 12:29:07 -07:00
|
|
|
}
|
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
.phui-header-shell + .phabricator-form-view {
|
2012-12-11 14:01:35 -08:00
|
|
|
border-top-width: 0;
|
|
|
|
}
|
|
|
|
|
2013-10-11 07:53:56 -07:00
|
|
|
.phui-property-list-view + .diviner-document-section {
|
2013-09-10 07:26:00 -07:00
|
|
|
margin-top: -1px;
|
|
|
|
}
|
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
.phui-header-view {
|
2015-05-31 08:36:44 -07:00
|
|
|
position: relative;
|
2015-06-26 09:33:03 -07:00
|
|
|
font-size: {$normalfontsize};
|
2015-05-31 08:36:44 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.phui-header-header {
|
2015-06-16 06:46:53 -07:00
|
|
|
font-size: 16px;
|
2015-05-31 12:15:15 -07:00
|
|
|
line-height: 24px;
|
2015-06-03 20:44:33 -07:00
|
|
|
color: {$darkbluetext};
|
[Redesign] Mobile/Phone design pass
Summary: Ref T8099, Quick descent pass at making header, object lists, tables, filter view, mobile friendly.
Test Plan:
Test home, differential diff, maniphest task, new task, search, and a few other views.
{F414034}
Reviewers: btrahan, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T8099
Differential Revision: https://secure.phabricator.com/D12984
2015-05-22 17:52:51 -07:00
|
|
|
}
|
|
|
|
|
2016-03-02 08:45:53 -08:00
|
|
|
.phui-header-header .phui-header-icon {
|
|
|
|
margin-right: 8px;
|
|
|
|
color: {$lightbluetext};
|
|
|
|
|
2016-04-29 16:52:27 -07:00
|
|
|
/* This allows the header text to be triple-clicked to select it in Firefox,
|
|
|
|
see T10905 for discussion. */
|
|
|
|
display: inline;
|
2016-04-29 16:37:45 -07:00
|
|
|
}
|
|
|
|
|
2015-05-31 08:36:44 -07:00
|
|
|
.phui-object-box .phui-header-tall .phui-header-header,
|
|
|
|
.phui-document-view .phui-header-tall .phui-header-header {
|
2015-06-16 06:46:53 -07:00
|
|
|
font-size: 18px;
|
[Redesign] New PHUIObjectItemListView
Summary:
New, cleaner, ObjectItemLists. Lots of minor style tweaks, basic overview:
- Remove FootIcons
- Remove Stackable
- Remove Plain List
- Add StatusIcon
- Add setting ObjectList to an ObjectBox
- Minor retouches to Headers
Mostly, this should give us an idea of life with the new Object Lists. I'll take another application by application pass down the road. This mostly looks at implementation in Maniphest, Differential, Audit, Workboards. Checked a few other areas and dialogs while testing, and everything looks square.
Test Plan: Maniphest, Differential, Homepage, Audit, People, and other applications. Drag reorder, etc.
Reviewers: btrahan, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Differential Revision: https://secure.phabricator.com/D12865
2015-05-15 13:28:59 -07:00
|
|
|
}
|
|
|
|
|
2015-05-31 08:36:44 -07:00
|
|
|
.phui-header-view .phui-header-header a {
|
2015-06-03 20:44:33 -07:00
|
|
|
color: {$darkbluetext};
|
|
|
|
}
|
|
|
|
|
2017-02-06 10:50:09 -08:00
|
|
|
.phui-box-blue-property .phui-header-view .phui-header-header a {
|
|
|
|
color: {$bluetext};
|
|
|
|
}
|
|
|
|
|
2015-06-03 20:44:33 -07:00
|
|
|
.device-desktop .phui-header-view .phui-header-header a:hover {
|
|
|
|
text-decoration: none;
|
[Redesign] Move basefont to Lato, remove Source Sans Pro
Summary: Working towards a more unified look and feel. This brings in Lato as a complete base font over Helvetica Neue, as well as removing Source Sans Pro from DocumentView and Conpherence. Design-wise Lato provides the nice readability at larger font sizes that Source Sans Pro did, with the ability to scale down to tables and UI widgets with ease. This gives us one font instead of two, and now Object descriptions and Timeline posts all can benefit from a consistent, readable font.
Test Plan:
Test main UI, smaller elements like tables, menus, DocumentViews, Previews, Conpherence.
{F498135}
{F498136}
Reviewers: btrahan, epriestley
Reviewed By: epriestley
Subscribers: epriestley, Korvin
Differential Revision: https://secure.phabricator.com/D13276
2015-06-13 20:32:45 +01:00
|
|
|
color: {$blue};
|
2013-12-05 07:16:25 -08:00
|
|
|
}
|
|
|
|
|
2013-12-03 08:34:04 -08:00
|
|
|
.phui-header-view .phui-header-action-links {
|
2015-01-13 16:10:57 -08:00
|
|
|
float: right;
|
2014-05-08 14:21:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.phui-object-box .phui-header-view .phui-header-action-links {
|
2015-05-22 08:22:25 -07:00
|
|
|
margin-right: 4px;
|
2015-06-26 09:33:03 -07:00
|
|
|
font-size: {$normalfontsize};
|
2013-12-03 08:34:04 -08:00
|
|
|
}
|
|
|
|
|
2016-02-23 07:23:58 -08:00
|
|
|
.phui-header-action-link {
|
|
|
|
margin-bottom: 4px;
|
|
|
|
margin-top: 4px;
|
|
|
|
float: right;
|
|
|
|
}
|
|
|
|
|
2013-12-03 08:34:04 -08:00
|
|
|
.device-phone .phui-header-action-link .phui-button-text {
|
|
|
|
visibility: hidden;
|
|
|
|
width: 0;
|
2017-06-04 08:52:36 -07:00
|
|
|
margin-left: 8px;
|
2013-10-14 09:40:05 -07:00
|
|
|
}
|
|
|
|
|
2015-07-18 12:18:59 -07:00
|
|
|
.device-phone .phui-header-action-link.button .phui-icon-view {
|
|
|
|
width: 12px;
|
|
|
|
text-align: center;
|
|
|
|
}
|
|
|
|
|
2013-10-14 09:40:05 -07:00
|
|
|
.phui-header-divider {
|
|
|
|
margin: 0 4px;
|
|
|
|
font-weight: normal;
|
|
|
|
color: {$lightbluetext};
|
|
|
|
}
|
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
.phui-header-tags {
|
2013-01-31 11:49:38 -08:00
|
|
|
margin-left: 12px;
|
2015-06-26 09:33:03 -07:00
|
|
|
font-size: {$normalfontsize};
|
Modernize Macro application
Summary: Adds feed, email, notifications, comments, partial editing, subscriptions, enable/disable, flags and crumbs to Macro.
Test Plan:
{F26839}
{F26840}
{F26841}
{F26842}
{F26843}
{F26844}
{F26845}
Reviewers: vrana, btrahan, chad
Reviewed By: vrana
CC: aran
Maniphest Tasks: T2157, T175, T2104
Differential Revision: https://secure.phabricator.com/D4141
2012-12-11 14:01:03 -08:00
|
|
|
}
|
2013-01-31 11:49:38 -08:00
|
|
|
|
2014-01-14 14:09:52 -08:00
|
|
|
.phui-header-tags .phui-tag-view {
|
2013-01-31 11:49:38 -08:00
|
|
|
margin-left: 4px;
|
|
|
|
}
|
2013-07-09 16:23:22 -07:00
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
.phui-header-image {
|
2013-07-09 16:23:22 -07:00
|
|
|
display: inline-block;
|
|
|
|
background-repeat: no-repeat;
|
2015-05-13 08:14:47 -07:00
|
|
|
background-size: 100%;
|
2013-07-09 16:23:22 -07:00
|
|
|
width: 50px;
|
|
|
|
height: 50px;
|
2016-01-24 13:18:42 -08:00
|
|
|
border-radius: 3px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-header-image-href {
|
|
|
|
position: relative;
|
|
|
|
display: block;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-header-image-edit {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.device-desktop .phui-header-image-href:hover .phui-header-image-edit {
|
|
|
|
display: block;
|
|
|
|
position: absolute;
|
|
|
|
left: 0;
|
2016-02-14 21:29:56 -08:00
|
|
|
background: rgba({$alphablack},0.4);
|
2016-01-24 13:18:42 -08:00
|
|
|
color: #fff;
|
|
|
|
font-weight: normal;
|
|
|
|
bottom: 4px;
|
|
|
|
padding: 4px 8px;
|
|
|
|
font-size: 12px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.device-desktop .phui-header-image-edit:hover {
|
|
|
|
text-decoration: underline;
|
2013-07-09 16:23:22 -07:00
|
|
|
}
|
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
.phui-header-subheader {
|
2013-07-09 16:23:22 -07:00
|
|
|
font-weight: normal;
|
2015-06-26 09:33:03 -07:00
|
|
|
font-size: {$biggerfontsize};
|
2015-05-22 08:22:25 -07:00
|
|
|
margin-top: 8px;
|
2013-07-09 16:23:22 -07:00
|
|
|
}
|
2013-09-17 09:12:37 -07:00
|
|
|
|
2016-03-05 15:25:06 +00:00
|
|
|
.phui-header-subheader .phui-icon-view {
|
|
|
|
margin-right: 4px;
|
|
|
|
}
|
|
|
|
|
2017-08-24 19:10:28 -07:00
|
|
|
.phui-header-subheader .phui-tag-view span.phui-icon-view,
|
|
|
|
.phui-header-subheader .policy-header-callout span.phui-icon-view {
|
2013-09-17 09:12:37 -07:00
|
|
|
display: inline-block;
|
|
|
|
margin: -2px 4px -2px 0;
|
2015-01-05 10:33:42 -08:00
|
|
|
font-size: 15px;
|
2013-09-17 09:12:37 -07:00
|
|
|
}
|
|
|
|
|
2015-01-05 10:33:42 -08:00
|
|
|
.phui-header-subheader,
|
2013-09-17 09:12:37 -07:00
|
|
|
.phui-header-subheader .policy-link {
|
2015-01-05 10:33:42 -08:00
|
|
|
color: {$darkbluetext};
|
2013-09-17 09:12:37 -07:00
|
|
|
}
|
2013-09-24 08:42:04 -07:00
|
|
|
|
2015-06-23 12:03:46 +01:00
|
|
|
.policy-header-callout,
|
2016-03-04 15:44:24 -08:00
|
|
|
.phui-header-subheader .phui-tag-core {
|
2015-06-23 12:03:46 +01:00
|
|
|
padding: 3px 9px;
|
2015-06-22 11:46:59 -07:00
|
|
|
border-radius: 3px;
|
2016-03-04 15:44:24 -08:00
|
|
|
background: rgba({$alphablue}, 0.1);
|
2015-06-23 12:03:46 +01:00
|
|
|
margin-right: 8px;
|
2016-03-04 15:44:24 -08:00
|
|
|
-webkit-font-smoothing: auto;
|
|
|
|
border-color: transparent;
|
|
|
|
}
|
|
|
|
|
2016-03-04 18:34:37 -08:00
|
|
|
|
|
|
|
.phui-header-subheader .phui-tag-view,
|
2016-03-04 15:44:24 -08:00
|
|
|
.phui-header-subheader .phui-tag-type-shade .phui-tag-core {
|
|
|
|
border: none;
|
2016-03-04 18:34:37 -08:00
|
|
|
font-weight: normal;
|
2016-03-04 15:44:24 -08:00
|
|
|
-webkit-font-smoothing: auto;
|
2015-06-22 11:46:59 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout.policy-adjusted-weaker {
|
2015-06-23 12:03:46 +01:00
|
|
|
background: {$sh-greenbackground};
|
2015-06-22 11:46:59 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout.policy-adjusted-weaker .policy-link,
|
|
|
|
.policy-header-callout.policy-adjusted-weaker .phui-icon-view {
|
2015-06-23 12:03:46 +01:00
|
|
|
color: {$sh-greentext};
|
2015-06-22 11:46:59 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout.policy-adjusted-stronger {
|
2015-06-23 12:03:46 +01:00
|
|
|
background: {$sh-redbackground};
|
2015-06-22 11:46:59 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout.policy-adjusted-stronger .policy-link,
|
|
|
|
.policy-header-callout.policy-adjusted-stronger .phui-icon-view {
|
2015-06-23 12:03:46 +01:00
|
|
|
color: {$sh-redtext};
|
2015-06-22 11:46:59 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout.policy-adjusted-different {
|
2015-06-23 12:03:46 +01:00
|
|
|
background: {$sh-orangebackground};
|
2015-06-22 11:46:59 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout.policy-adjusted-different .policy-link,
|
|
|
|
.policy-header-callout.policy-adjusted-different .phui-icon-view {
|
2015-06-23 12:03:46 +01:00
|
|
|
color: {$sh-orangetext};
|
2015-06-22 11:46:59 -07:00
|
|
|
}
|
|
|
|
|
Require several advanced postgraduate degrees to understand object policies
Summary:
Fixes T11836. See some prior discussion in T8376#120613.
The policy hint in headers in the UI is not exhaustive, and can not reasonably be exhaustive. For example, on a revision, it may say "All Users", but really mean "All users who can see the space this object is in and the repository it belongs to, plus the revision author and reviewers".
These rules are explained if you click (and, often, in the documentation), but "All Users" is still at least somewhat misleading.
I don't think there's any perfect solution here that balances the needs of both new and experienced users perfectly, but this change tries to do a bit better about avoiding cases where we say something very open (like "All Users") when the real policy is not very open.
Specifically, I've made these changes to the header:
- Spaces are now listed in the tag, so it will say `(S3 > All Users)` instead of `(All Users)`. They're already listed in the header, this just makes it more explicit that Spaces are a policy container and part of the view policy.
- Extended policy objects are now listed in the tag, so it will say `(S3 > rARC > All Users)` for a revision in the Arcanist repository which is also in Space 3.
- Objects can now provide a "Policy Codex", which is an object that represents a rulebook of more sophisticated policy descriptions. This codex can replace the tag with something else.
- Imported calendar events now say "Uses Import Policy" instead of, e.g., "All Users".
I've made these changes to the policy dialog:
- Split it into more visually separate sections.
- Added an explicit section for extended policies ("You must also have access to these other objects: ...").
- Broken the object policy rules into a "Special Rules" section (for rules like "you can only see a revision if you can see the repository it is part of") and an "Object Policy" section (for the actual object policy).
- Tried to make it a little more readable?
- The new policy dialogs are great to curl up with in front of a fire with a nice cup of cocoa.
I've made these changes to infrastructure:
- Implementing `PhabricatorPolicyInterface` no longer requires you to implement `describeAutomaticCapability()`.
- Instead, implement `PhabricatorPolicyCodexInterface` and return a `PhabricatorPolicyCodex` object.
- This "codex" is a policy rulebook which can set all the policy icons, labels, colors, rules, etc., to properly explain complex policies.
- Broadly, the old method was usually either not useful (most objects have no special rules) or not powerful enough (objects with special rules often need to do more in order to explain them).
Test Plan:
{F1912860}
{F1912861}
{F1912862}
{F1912863}
Reviewers: chad
Reviewed By: chad
Subscribers: avivey
Maniphest Tasks: T11836
Differential Revision: https://secure.phabricator.com/D16830
2016-11-09 10:02:25 -08:00
|
|
|
.policy-header-callout.policy-adjusted-special {
|
|
|
|
background: {$sh-indigobackground};
|
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout.policy-adjusted-special .policy-link,
|
|
|
|
.policy-header-callout.policy-adjusted-special .phui-icon-view {
|
|
|
|
color: {$sh-indigotext};
|
|
|
|
}
|
|
|
|
|
Allow task statuses to specify that either "comments" or "edits" are "locked"
Summary:
Ref T13249. See PHI1059. This allows "locked" in `maniphest.statuses` to specify that either "comments" are locked (current behavior, advisory, overridable by users with edit permission, e.g. for calming discussion on a contentious issue or putting a guard rail on things); or "edits" are locked (hard lock, only task owner can edit things).
Roughly, "comments" is a soft/advisory lock. "edits" is a hard/strict lock. (I think both types of locks have reasonable use cases, which is why I'm not just making locks stronger across the board.)
When "edits" are locked:
- The edit policy looks like "no one" to normal callers.
- In one special case, we sneak the real value through a back channel using PolicyCodex in the specific narrow case that you're editing the object. Otherwise, the policy selector control incorrectly switches to "No One".
- We also have to do a little more validation around applying a mixture of status + owner transactions that could leave the task uneditable.
For now, I'm allowing you to reassign a hard-locked task to someone else. If you get this wrong, we can end up in a state where no one can edit the task. If this is an issue, we could respond in various ways: prevent these edits; prevent assigning to disabled users; provide a `bin/task reassign`; uh maybe have a quorum convene?
Test Plan:
- Defined "Soft Locked" and "Hard Locked" statues.
- "Hard Locked" a task, hit errors (trying to unassign myself, trying to hard lock an unassigned task).
- Saw nice new policy guidance icon in header.
{F6210362}
Reviewers: amckinley
Reviewed By: amckinley
Maniphest Tasks: T13249
Differential Revision: https://secure.phabricator.com/D20165
2019-02-08 06:07:24 -08:00
|
|
|
.policy-header-callout.policy-adjusted-locked {
|
|
|
|
background: {$sh-pinkbackground};
|
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout.policy-adjusted-locked .policy-link,
|
|
|
|
.policy-header-callout.policy-adjusted-locked .phui-icon-view {
|
|
|
|
color: {$sh-pinktext};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
Require several advanced postgraduate degrees to understand object policies
Summary:
Fixes T11836. See some prior discussion in T8376#120613.
The policy hint in headers in the UI is not exhaustive, and can not reasonably be exhaustive. For example, on a revision, it may say "All Users", but really mean "All users who can see the space this object is in and the repository it belongs to, plus the revision author and reviewers".
These rules are explained if you click (and, often, in the documentation), but "All Users" is still at least somewhat misleading.
I don't think there's any perfect solution here that balances the needs of both new and experienced users perfectly, but this change tries to do a bit better about avoiding cases where we say something very open (like "All Users") when the real policy is not very open.
Specifically, I've made these changes to the header:
- Spaces are now listed in the tag, so it will say `(S3 > All Users)` instead of `(All Users)`. They're already listed in the header, this just makes it more explicit that Spaces are a policy container and part of the view policy.
- Extended policy objects are now listed in the tag, so it will say `(S3 > rARC > All Users)` for a revision in the Arcanist repository which is also in Space 3.
- Objects can now provide a "Policy Codex", which is an object that represents a rulebook of more sophisticated policy descriptions. This codex can replace the tag with something else.
- Imported calendar events now say "Uses Import Policy" instead of, e.g., "All Users".
I've made these changes to the policy dialog:
- Split it into more visually separate sections.
- Added an explicit section for extended policies ("You must also have access to these other objects: ...").
- Broken the object policy rules into a "Special Rules" section (for rules like "you can only see a revision if you can see the repository it is part of") and an "Object Policy" section (for the actual object policy).
- Tried to make it a little more readable?
- The new policy dialogs are great to curl up with in front of a fire with a nice cup of cocoa.
I've made these changes to infrastructure:
- Implementing `PhabricatorPolicyInterface` no longer requires you to implement `describeAutomaticCapability()`.
- Instead, implement `PhabricatorPolicyCodexInterface` and return a `PhabricatorPolicyCodex` object.
- This "codex" is a policy rulebook which can set all the policy icons, labels, colors, rules, etc., to properly explain complex policies.
- Broadly, the old method was usually either not useful (most objects have no special rules) or not powerful enough (objects with special rules often need to do more in order to explain them).
Test Plan:
{F1912860}
{F1912861}
{F1912862}
{F1912863}
Reviewers: chad
Reviewed By: chad
Subscribers: avivey
Maniphest Tasks: T11836
Differential Revision: https://secure.phabricator.com/D16830
2016-11-09 10:02:25 -08:00
|
|
|
.policy-header-callout .policy-space-container {
|
|
|
|
font-weight: bold;
|
|
|
|
color: {$sh-redtext};
|
|
|
|
}
|
|
|
|
|
|
|
|
.policy-header-callout .policy-tier-separator {
|
|
|
|
padding: 0 0 0 4px;
|
|
|
|
color: {$lightgreytext};
|
|
|
|
}
|
|
|
|
|
2015-01-12 07:24:35 -08:00
|
|
|
.phui-header-action-links .phui-mobile-menu {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.device .phui-header-action-links .phui-mobile-menu {
|
|
|
|
display: inline-block;
|
|
|
|
}
|
[Redesign] Convert Dashboard Panels to ObjectBox
Summary: Moves Dashboard Panels to use PHUIObjectBoxView and PHUIHeaderView
Test Plan:
Tested the most common dashboards, Differential, Maniphest, Projects, Feed, Audit. Some edge cases (Legalpad, Macro) still are in progress. Tested laying out a new Dashboard, removing panels, moving panels.
{F406170}
Reviewers: btrahan, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T8099
Differential Revision: https://secure.phabricator.com/D12873
2015-05-17 07:05:14 -07:00
|
|
|
|
2015-05-31 07:54:48 -07:00
|
|
|
.phui-header-action-list {
|
[Redesign] Convert Dashboard Panels to ObjectBox
Summary: Moves Dashboard Panels to use PHUIObjectBoxView and PHUIHeaderView
Test Plan:
Tested the most common dashboards, Differential, Maniphest, Projects, Feed, Audit. Some edge cases (Legalpad, Macro) still are in progress. Tested laying out a new Dashboard, removing panels, moving panels.
{F406170}
Reviewers: btrahan, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T8099
Differential Revision: https://secure.phabricator.com/D12873
2015-05-17 07:05:14 -07:00
|
|
|
float: right;
|
|
|
|
}
|
|
|
|
|
2015-05-31 07:54:48 -07:00
|
|
|
.phui-header-action-list li {
|
|
|
|
margin: 0 0 0 8px;
|
[Redesign] Convert Dashboard Panels to ObjectBox
Summary: Moves Dashboard Panels to use PHUIObjectBoxView and PHUIHeaderView
Test Plan:
Tested the most common dashboards, Differential, Maniphest, Projects, Feed, Audit. Some edge cases (Legalpad, Macro) still are in progress. Tested laying out a new Dashboard, removing panels, moving panels.
{F406170}
Reviewers: btrahan, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T8099
Differential Revision: https://secure.phabricator.com/D12873
2015-05-17 07:05:14 -07:00
|
|
|
float: right;
|
|
|
|
}
|
2015-05-18 10:00:15 -07:00
|
|
|
|
2016-03-04 18:34:37 -08:00
|
|
|
.phui-header-action-list .phui-header-action-item .phui-icon-view {
|
2015-05-31 07:54:48 -07:00
|
|
|
height: 18px;
|
|
|
|
width: 16px;
|
|
|
|
font-size: 16px;
|
|
|
|
line-height: 20px;
|
|
|
|
display: block;
|
2015-05-18 10:00:15 -07:00
|
|
|
}
|
2015-06-10 07:44:58 -07:00
|
|
|
|
2015-06-05 10:42:49 -07:00
|
|
|
.spaces-name {
|
|
|
|
color: {$lightbluetext};
|
|
|
|
}
|
|
|
|
|
2015-06-16 13:43:27 -07:00
|
|
|
.phui-object-box .phui-header-tall .spaces-name {
|
|
|
|
font-size: 18px;
|
|
|
|
}
|
|
|
|
|
2016-03-01 11:43:58 -08:00
|
|
|
.spaces-name .phui-handle,
|
2018-07-30 15:59:48 -07:00
|
|
|
.spaces-name a.phui-handle,
|
|
|
|
.phui-profile-header.phui-header-shell .spaces-name .phui-handle {
|
2015-06-16 13:43:27 -07:00
|
|
|
color: {$sh-redtext};
|
2015-06-05 10:42:49 -07:00
|
|
|
}
|
2015-07-11 11:59:00 -07:00
|
|
|
|
2016-03-01 11:43:58 -08:00
|
|
|
.device-desktop .spaces-name a.phui-handle:hover {
|
|
|
|
color: {$sh-redtext};
|
|
|
|
text-decoration: underline;
|
|
|
|
}
|
|
|
|
|
2016-01-24 08:34:28 -08:00
|
|
|
|
|
|
|
/*** Profile Header ***********************************************************/
|
|
|
|
|
|
|
|
.phui-profile-header {
|
|
|
|
padding: 24px 20px 20px 24px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.device-phone .phui-profile-header {
|
|
|
|
padding: 12px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-profile-header.phui-header-shell {
|
|
|
|
margin: 0;
|
|
|
|
border: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-profile-header .phui-header-image {
|
|
|
|
height: 80px;
|
|
|
|
width: 80px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-profile-header .phui-header-col1 {
|
|
|
|
width: 96px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-profile-header .phui-header-subheader {
|
|
|
|
margin-top: 12px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-profile-header.phui-header-shell .phui-header-header {
|
|
|
|
font-size: 24px;
|
2017-07-17 11:08:17 -07:00
|
|
|
color: {$blacktext};
|
2016-01-24 08:34:28 -08:00
|
|
|
}
|
|
|
|
|
2017-09-05 19:01:18 -07:00
|
|
|
.phui-profile-header.phui-header-shell .phui-header-header a {
|
|
|
|
color: {$blacktext};
|
|
|
|
}
|
|
|
|
|
2017-05-22 10:47:19 -07:00
|
|
|
.phui-header-view .phui-tag-indigo a {
|
2016-03-17 12:01:22 -07:00
|
|
|
color: {$sh-indigotext};
|
|
|
|
}
|
Require several advanced postgraduate degrees to understand object policies
Summary:
Fixes T11836. See some prior discussion in T8376#120613.
The policy hint in headers in the UI is not exhaustive, and can not reasonably be exhaustive. For example, on a revision, it may say "All Users", but really mean "All users who can see the space this object is in and the repository it belongs to, plus the revision author and reviewers".
These rules are explained if you click (and, often, in the documentation), but "All Users" is still at least somewhat misleading.
I don't think there's any perfect solution here that balances the needs of both new and experienced users perfectly, but this change tries to do a bit better about avoiding cases where we say something very open (like "All Users") when the real policy is not very open.
Specifically, I've made these changes to the header:
- Spaces are now listed in the tag, so it will say `(S3 > All Users)` instead of `(All Users)`. They're already listed in the header, this just makes it more explicit that Spaces are a policy container and part of the view policy.
- Extended policy objects are now listed in the tag, so it will say `(S3 > rARC > All Users)` for a revision in the Arcanist repository which is also in Space 3.
- Objects can now provide a "Policy Codex", which is an object that represents a rulebook of more sophisticated policy descriptions. This codex can replace the tag with something else.
- Imported calendar events now say "Uses Import Policy" instead of, e.g., "All Users".
I've made these changes to the policy dialog:
- Split it into more visually separate sections.
- Added an explicit section for extended policies ("You must also have access to these other objects: ...").
- Broken the object policy rules into a "Special Rules" section (for rules like "you can only see a revision if you can see the repository it is part of") and an "Object Policy" section (for the actual object policy).
- Tried to make it a little more readable?
- The new policy dialogs are great to curl up with in front of a fire with a nice cup of cocoa.
I've made these changes to infrastructure:
- Implementing `PhabricatorPolicyInterface` no longer requires you to implement `describeAutomaticCapability()`.
- Instead, implement `PhabricatorPolicyCodexInterface` and return a `PhabricatorPolicyCodex` object.
- This "codex" is a policy rulebook which can set all the policy icons, labels, colors, rules, etc., to properly explain complex policies.
- Broadly, the old method was usually either not useful (most objects have no special rules) or not powerful enough (objects with special rules often need to do more in order to explain them).
Test Plan:
{F1912860}
{F1912861}
{F1912862}
{F1912863}
Reviewers: chad
Reviewed By: chad
Subscribers: avivey
Maniphest Tasks: T11836
Differential Revision: https://secure.phabricator.com/D16830
2016-11-09 10:02:25 -08:00
|
|
|
|
|
|
|
.phui-policy-section-view {
|
|
|
|
margin-bottom: 24px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-policy-section-view-header {
|
|
|
|
background: {$bluebackground};
|
|
|
|
border-bottom: 1px solid {$lightblueborder};
|
|
|
|
padding: 4px 8px;
|
|
|
|
color: {$darkbluetext};
|
|
|
|
margin-bottom: 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-policy-section-view-header-text {
|
|
|
|
font-weight: bold;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-policy-section-view-header .phui-icon-view {
|
|
|
|
margin-right: 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-policy-section-view-link {
|
|
|
|
float: right;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-policy-section-view-link .phui-icon-view {
|
|
|
|
color: {$bluetext};
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-policy-section-view-hint {
|
|
|
|
color: {$greytext};
|
|
|
|
background: {$lightbluebackground};
|
|
|
|
padding: 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-policy-section-view-body {
|
|
|
|
padding: 0 12px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.phui-policy-section-view-inactive-rule {
|
|
|
|
color: {$greytext};
|
|
|
|
}
|