@primer/view-components 0.45.1-rc.015a120e → 0.45.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/app/assets/styles/primer_view_components.css +6963 -1
  2. package/app/assets/styles/primer_view_components.css.map +1 -1
  3. package/app/components/primer/alpha/action_bar.css +49 -1
  4. package/app/components/primer/alpha/action_list.css +525 -1
  5. package/app/components/primer/alpha/action_list.css.json +64 -64
  6. package/app/components/primer/alpha/auto_complete.css +131 -1
  7. package/app/components/primer/alpha/auto_complete.css.json +3 -3
  8. package/app/components/primer/alpha/banner.css +146 -1
  9. package/app/components/primer/alpha/banner.css.json +2 -2
  10. package/app/components/primer/alpha/button_marketing.css +183 -1
  11. package/app/components/primer/alpha/button_marketing.css.json +6 -6
  12. package/app/components/primer/alpha/dialog.css +377 -1
  13. package/app/components/primer/alpha/dialog.css.json +2 -2
  14. package/app/components/primer/alpha/dropdown.css +296 -1
  15. package/app/components/primer/alpha/dropdown.css.json +19 -19
  16. package/app/components/primer/alpha/layout.css +374 -1
  17. package/app/components/primer/alpha/layout.css.json +10 -10
  18. package/app/components/primer/alpha/menu.css +124 -1
  19. package/app/components/primer/alpha/menu.css.json +5 -5
  20. package/app/components/primer/alpha/overlay.css +25 -1
  21. package/app/components/primer/alpha/segmented_control.css +161 -1
  22. package/app/components/primer/alpha/segmented_control.css.json +5 -5
  23. package/app/components/primer/alpha/select_panel.css +10 -1
  24. package/app/components/primer/alpha/skeleton_box.css +36 -1
  25. package/app/components/primer/alpha/stack.css +255 -1
  26. package/app/components/primer/alpha/stack.css.json +84 -84
  27. package/app/components/primer/alpha/stack_item.css +27 -1
  28. package/app/components/primer/alpha/stack_item.css.json +6 -6
  29. package/app/components/primer/alpha/tab_nav.css +112 -1
  30. package/app/components/primer/alpha/tab_nav.css.json +5 -5
  31. package/app/components/primer/alpha/text_field.css +792 -1
  32. package/app/components/primer/alpha/text_field.css.json +39 -39
  33. package/app/components/primer/alpha/toggle_switch.css +230 -1
  34. package/app/components/primer/alpha/toggle_switch.css.json +10 -10
  35. package/app/components/primer/alpha/tree_view.css +396 -1
  36. package/app/components/primer/alpha/tree_view.css.json +25 -25
  37. package/app/components/primer/alpha/underline_nav.css +150 -1
  38. package/app/components/primer/alpha/underline_nav.css.json +6 -6
  39. package/app/components/primer/beta/avatar.css +77 -1
  40. package/app/components/primer/beta/avatar_stack.css +134 -1
  41. package/app/components/primer/beta/avatar_stack.css.json +6 -7
  42. package/app/components/primer/beta/blankslate.css +168 -1
  43. package/app/components/primer/beta/border_box.css +218 -1
  44. package/app/components/primer/beta/border_box.css.json +3 -3
  45. package/app/components/primer/beta/breadcrumbs.css +29 -1
  46. package/app/components/primer/beta/breadcrumbs.css.json +2 -2
  47. package/app/components/primer/beta/button.css +359 -1
  48. package/app/components/primer/beta/button.css.json +17 -17
  49. package/app/components/primer/beta/button_group.css +20 -1
  50. package/app/components/primer/beta/button_group.css.json +3 -3
  51. package/app/components/primer/beta/counter.css +38 -1
  52. package/app/components/primer/beta/flash.css +152 -1
  53. package/app/components/primer/beta/label.css +109 -1
  54. package/app/components/primer/beta/label.css.json +3 -3
  55. package/app/components/primer/beta/link.css +79 -1
  56. package/app/components/primer/beta/link.css.json +1 -1
  57. package/app/components/primer/beta/popover.css +215 -1
  58. package/app/components/primer/beta/popover.css.json +23 -23
  59. package/app/components/primer/beta/progress_bar.css +38 -1
  60. package/app/components/primer/beta/progress_bar.css.json +1 -1
  61. package/app/components/primer/beta/state.css +60 -1
  62. package/app/components/primer/beta/state.css.json +1 -1
  63. package/app/components/primer/beta/subhead.css +64 -1
  64. package/app/components/primer/beta/subhead.css.json +1 -1
  65. package/app/components/primer/beta/timeline_item.css +106 -1
  66. package/app/components/primer/beta/timeline_item.css.json +1 -1
  67. package/app/components/primer/beta/truncate.css +30 -1
  68. package/app/components/primer/beta/truncate.css.json +6 -6
  69. package/app/components/primer/truncate.css +23 -1
  70. package/app/components/primer/truncate.css.json +4 -4
  71. package/package.json +1 -1
@@ -1 +1,792 @@
1
- .FormControl{display:inline-flex;flex-direction:column;gap:var(--base-size-4)}.FormControl--fullWidth{display:flex}.FormControl-label{color:var(--fgColor-default);font-size:var(--text-body-size-medium);font-weight:var(--base-text-weight-semibold);line-height:var(--text-body-lineHeight-medium)}.FormControl-caption{color:var(--fgColor-muted);font-weight:var(--text-caption-weight);margin-bottom:0}.FormControl-caption,.FormControl-inlineValidation{font-size:var(--text-caption-size);line-height:var(--text-caption-lineHeight)}.FormControl-inlineValidation{color:var(--control-danger-fgColor-rest);display:flex;font-weight:var(--base-text-weight-semibold);fill:var(--control-danger-fgColor-rest);align-items:flex-start;flex-direction:row;gap:var(--base-size-4)}.FormControl-inlineValidation p{margin-bottom:0}.FormControl-inlineValidation--success{color:var(--fgColor-success);fill:var(--fgColor-success)}.FormControl-inlineValidation--visual{align-items:center;display:flex;min-height:var(--base-size-16)}.FormControl-spacingWrapper{display:flex;flex-direction:column;row-gap:var(--stack-gap-normal)}.FormControl-horizontalGroup{column-gap:.5rem;display:flex}.FormControl-input,.FormControl-select,.FormControl-textarea{background-color:var(--bgColor-default);border:var(--borderWidth-thin) solid var(--control-borderColor-rest,var(--color-border-default));box-shadow:var(--shadow-inset);color:var(--fgColor-default)}[disabled]:is(.FormControl-input,.FormControl-select,.FormControl-textarea){background-color:var(--control-bgColor-disabled);border-color:var(--control-borderColor-disabled);box-shadow:none;color:var(--control-fgColor-disabled);cursor:not-allowed;opacity:1;-webkit-text-fill-color:var(--control-fgColor-disabled)}[invalid=true]:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not(:focus){border-color:var(--control-borderColor-danger)}[invalid=false]:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not(:focus){border-color:var(--control-borderColor-success)}:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type=checkbox],[type=radio]):focus{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type=checkbox],[type=radio]):focus:not(:focus-visible){border-color:#0000;border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px #0000 var(--focus-outlineColor);outline:none}:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type=checkbox],[type=radio]):focus-visible{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-input,.FormControl-select,.FormControl-textarea{border-radius:var(--borderRadius-medium);font-size:var(--text-body-size-medium);line-height:var(--text-body-lineHeight-medium);padding-block:calc(var(--control-medium-paddingBlock) - var(--borderWidth-thin));padding-inline:var(--control-medium-paddingInline-condensed);transition:80ms cubic-bezier(.33,1,.68,1);transition-property:color,background-color,box-shadow,border-color;width:100%}[disabled]:is(.FormControl-input,.FormControl-select,.FormControl-textarea)::placeholder{color:var(--control-fgColor-disabled)}[readonly]:is(.FormControl-input,.FormControl-select,.FormControl-textarea){background-color:var(--control-bgColor-disabled)}:is(.FormControl-input,.FormControl-select,.FormControl-textarea)::placeholder{color:var(--control-fgColor-placeholder);opacity:1}.FormControl-small:is(.FormControl-input,.FormControl-select,.FormControl-textarea){font-size:var(--text-body-size-small);height:var(--control-small-size);padding-block:var(--control-small-paddingBlock);padding-inline:var(--control-small-paddingInline-normal)}.FormControl-medium:is(.FormControl-input,.FormControl-select,.FormControl-textarea){height:var(--control-medium-size)}.FormControl-large:is(.FormControl-input,.FormControl-select,.FormControl-textarea){height:var(--control-large-size);padding-block:var(--control-large-paddingBlock);padding-inline:var(--control-large-paddingInline-normal)}.FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea){background-color:var(--bgColor-muted)}.FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea):focus,.FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea):focus-visible{background-color:var(--bgColor-default)}.FormControl-monospace:is(.FormControl-input,.FormControl-select,.FormControl-textarea){font-family:var(--fontStack-monospace)}.FormControl-error:is(.FormControl-input,.FormControl-select,.FormControl-textarea){border-color:var(--control-borderColor-danger)}.FormControl-success:is(.FormControl-input,.FormControl-select,.FormControl-textarea){border-color:var(--control-borderColor-success)}.FormControl-warning:is(.FormControl-input,.FormControl-select,.FormControl-textarea){border-color:var(--control-borderColor-warning)}.FormControl-toggleSwitchInput{align-items:flex-start;display:flex;gap:var(--base-size-16)}.FormControl-input-wrap{display:grid;position:relative}.FormControl-input-wrap .FormControl-input-leadingVisualWrap{color:var(--fgColor-muted);display:block;height:var(--base-size-16);left:var(--base-size-8);pointer-events:none;position:absolute;top:var(--base-size-8);width:var(--base-size-16)}:is(.FormControl-input-wrap .FormControl-input-leadingVisualWrap) .FormControl-input-leadingVisual{display:block;-webkit-user-select:none;user-select:none}.FormControl-input-wrap .FormControl-input-trailingVisualWrap{align-items:center;color:var(--fgColor-muted);display:flex;gap:var(--base-size-4);height:var(--base-size-16);pointer-events:none;position:absolute;right:var(--base-size-8);top:var(--base-size-8)}:is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap):has(.FormControl-input-trailingVisualLabel),:is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap):has(.FormControl-input-trailingVisualText){max-width:25%;padding-left:var(--base-size-8)}:is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap) .FormControl-input-trailingVisualLabel{overflow:hidden;text-overflow:ellipsis}.FormControl-input-wrap .FormControl-input-trailingAction{align-items:center;background:#0000;border:0;border-radius:var(--borderRadius-small);color:var(--fgColor-muted);cursor:pointer;display:grid;height:var(--control-xsmall-size);justify-content:center;padding:0;position:absolute;right:var(--base-size-4);top:var(--base-size-4);transition:.2s cubic-bezier(.3,0,.5,1);transition-property:color,background-color,border-color;width:var(--control-xsmall-size);z-index:4}:is(.FormControl-input-wrap .FormControl-input-trailingAction) svg{-webkit-user-select:none;user-select:none}[disabled]:is(.FormControl-input-wrap .FormControl-input-trailingAction){color:var(--control-fgColor-disabled);pointer-events:none}:is(.FormControl-input-wrap .FormControl-input-trailingAction):hover{background:var(--control-transparent-bgColor-hover)}:is(.FormControl-input-wrap .FormControl-input-trailingAction):active{background:var(--control-transparent-bgColor-active)}.FormControl-input-trailingAction--divider:is(.FormControl-input-wrap .FormControl-input-trailingAction):before{background:var(--borderColor-default);content:"";display:block;height:var(--base-size-16);left:calc(var(--base-size-4)*-1);position:absolute;top:calc((var(--control-xsmall-size) - var(--base-size-16))/2);width:var(--borderWidth-thin)}:is(:is(.FormControl-input-wrap .FormControl-input-trailingAction):after){content:"";height:100%;left:50%;min-height:var(--control-medium-size) var(--control-medium-size);position:absolute;top:50%;transform:translateX(-50%) translateY(-50%);width:100%}@media (pointer:coarse){:is(.FormControl-input-wrap .FormControl-input-trailingAction):after{min-height:var(--control-minTarget-coarse);min-width:var(--control-minTarget-coarse)}}.FormControl-input-wrap.FormControl-input-wrap--leadingVisual .FormControl-input{padding-inline-start:calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap))}.FormControl-input-wrap.FormControl-input-wrap--trailingVisual .FormControl-input{padding-inline-end:calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap))}.FormControl-input-wrap.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualLabel) .FormControl-input,.FormControl-input-wrap.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualText) .FormControl-input{padding-inline-end:25%}.FormControl-input-wrap.FormControl-input-wrap--trailingAction .FormControl-input{padding-inline-end:calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap))}.FormControl-input-wrap.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input{padding-inline-end:calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap) + var(--borderWidth-thin))}.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-leadingVisualWrap{left:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2));top:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2))}.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingVisualWrap{right:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2));top:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2))}.FormControl-input-wrap.FormControl-input-wrap--small.FormControl-input-wrap--trailingAction .FormControl-input.FormControl-small{padding-inline-end:calc(var(--control-small-paddingInline-condensed) + var(--base-size-16) + var(--control-small-gap))}.FormControl-input-wrap.FormControl-input-wrap--small.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input.FormControl-small{padding-inline-end:calc(var(--control-small-paddingInline-condensed) + var(--base-size-16) + var(--control-small-gap) + var(--borderWidth-thin))}.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingAction{height:calc(var(--control-small-size) - var(--base-size-8));width:calc(var(--control-small-size) - var(--base-size-8))}:is(.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingAction):before{top:calc((var(--control-xsmall-size) - var(--base-size-16))/4)}.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-leadingVisualWrap{left:var(--control-medium-paddingInline-normal);top:var(--control-medium-paddingInline-normal)}.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingVisualWrap{right:var(--control-medium-paddingInline-normal);top:var(--control-medium-paddingInline-normal)}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--leadingVisual .FormControl-input.FormControl-large{padding-inline-start:calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap))}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual .FormControl-input{padding-inline-end:calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap))}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingLabel .FormControl-input.FormControl-large,.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingText .FormControl-input.FormControl-large,.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualLabel) .FormControl-input,.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualText) .FormControl-input{padding-inline-end:25%}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingAction .FormControl-input.FormControl-large{padding-inline-end:calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap))}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input.FormControl-large{padding-inline-end:calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap) + var(--borderWidth-thin))}.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingAction{height:var(--control-small-size);right:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2));top:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2));width:var(--control-small-size)}:is(.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingAction):before{height:var(--base-size-20);top:unset}.FormControl-select-wrap{display:grid;grid-template-columns:minmax(0,auto) var(--base-size-16)}.FormControl-select-wrap:after{background-color:var(--bgColor-neutral-emphasis);content:"";grid-column:2;grid-row:1;height:var(--base-size-16);mask:url("");mask-repeat:no-repeat;mask-size:contain;padding-right:var(--base-size-4);place-self:center end;pointer-events:none;width:var(--base-size-16)}.FormControl-select-wrap .FormControl-select{appearance:none;grid-column:1/-1;grid-row:1;padding-right:var(--base-size-20)}.FormControl-select-wrap[data-multiple]:after{content:none}.FormControl-select-wrap[data-multiple] .FormControl-select{padding-right:var(--base-size-8)}.FormControl-checkbox-wrap,.FormControl-radio-wrap{display:inline-grid;gap:var(--base-size-8);grid-template-columns:min-content auto}:is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-checkbox-labelWrap,:is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-radio-labelWrap{display:flex;flex-direction:column;gap:var(--base-size-4)}:is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-label{cursor:pointer}.FormControl-check-group-wrap fieldset,.FormControl-radio-group-wrap fieldset{border:0;margin:0;padding:0}.FormControl-checkbox{background-color:var(--bgColor-default);border:var(--borderWidth-thin) solid var(--control-borderColor-rest,var(--color-border-default));box-shadow:var(--shadow-inset);color:var(--fgColor-default)}.FormControl-checkbox[disabled]{background-color:var(--control-bgColor-disabled);border-color:var(--control-borderColor-disabled);box-shadow:none;color:var(--control-fgColor-disabled);cursor:not-allowed;opacity:1;-webkit-text-fill-color:var(--control-fgColor-disabled)}.FormControl-checkbox[invalid=true]:not(:focus){border-color:var(--control-borderColor-danger)}.FormControl-checkbox[invalid=false]:not(:focus){border-color:var(--control-borderColor-success)}.FormControl-checkbox:not([type=checkbox],[type=radio]):focus{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-checkbox:not([type=checkbox],[type=radio]):focus:not(:focus-visible){border-color:#0000;border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px #0000 var(--focus-outlineColor);outline:none}.FormControl-checkbox:not([type=checkbox],[type=radio]):focus-visible{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-checkbox{appearance:none;border-color:var(--control-borderColor-emphasis);border-radius:var(--borderRadius-small);cursor:pointer;display:grid;height:var(--base-size-16);margin:0;margin-top:var(--base-size-2);place-content:center;position:relative;transition:background-color,border-color 80ms cubic-bezier(.33,1,.68,1);width:var(--base-size-16)}.FormControl-checkbox:before{animation:checkmarkOut 80ms cubic-bezier(.65,0,.35,1) forwards;background-color:var(--control-checked-fgColor-rest);clip-path:inset(var(--base-size-16) 0 0 0);content:"";height:var(--base-size-16);mask-image:url("");mask-position:center;mask-repeat:no-repeat;mask-size:75%;transition:visibility 0s linear .23s;visibility:hidden;width:var(--base-size-16)}:is(.FormControl-checkbox:after){content:"";height:100%;left:50%;min-height:var(--control-medium-size) var(--control-medium-size);position:absolute;top:50%;transform:translateX(-50%) translateY(-50%);width:100%}:is(.FormControl-checkbox[disabled]~.FormControl-checkbox-labelWrap) .FormControl-label{color:var(--control-fgColor-disabled);cursor:not-allowed}.FormControl-checkbox:checked{background:var(--control-checked-bgColor-rest,var(--color-accent-fg));border-color:var(--control-checked-borderColor-rest,var(--color-accent-fg));transition:background-color,border-color 80ms cubic-bezier(.32,0,.67,0) 0s}.FormControl-checkbox:checked:before{animation:checkmarkIn 80ms cubic-bezier(.65,0,.35,1) 80ms forwards;transition:visibility 0s linear 0s;visibility:visible}.FormControl-checkbox:checked:disabled{background-color:var(--control-fgColor-disabled);border-color:var(--control-fgColor-disabled);cursor:not-allowed;opacity:1}.FormControl-checkbox:checked:disabled:before{background-color:var(--control-checked-fgColor-rest)}@media (forced-colors:active){.FormControl-checkbox:checked{background-color:canvastext;border-color:canvastext}}.FormControl-checkbox:focus-visible{box-shadow:none;outline:2px solid var(--focus-outlineColor);outline-offset:2px}.FormControl-checkbox:indeterminate:before{mask-image:url("");visibility:visible}.FormControl-radio{background-color:var(--bgColor-default);border:var(--borderWidth-thin) solid var(--control-borderColor-rest,var(--color-border-default));box-shadow:var(--shadow-inset);color:var(--fgColor-default)}.FormControl-radio[disabled]{background-color:var(--control-bgColor-disabled);border-color:var(--control-borderColor-disabled);box-shadow:none;color:var(--control-fgColor-disabled);cursor:not-allowed;opacity:1;-webkit-text-fill-color:var(--control-fgColor-disabled)}.FormControl-radio[invalid=true]:not(:focus){border-color:var(--control-borderColor-danger)}.FormControl-radio[invalid=false]:not(:focus){border-color:var(--control-borderColor-success)}.FormControl-radio:not([type=checkbox],[type=radio]):focus{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-radio:not([type=checkbox],[type=radio]):focus:not(:focus-visible){border-color:#0000;border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px #0000 var(--focus-outlineColor);outline:none}.FormControl-radio:not([type=checkbox],[type=radio]):focus-visible{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-radio{appearance:none;border-color:var(--control-borderColor-emphasis);border-radius:var(--borderRadius-full);cursor:pointer;height:var(--base-size-16);margin:0;margin-top:var(--base-size-2);position:relative;transition:background-color,border-color 80ms cubic-bezier(.33,1,.68,1);width:var(--base-size-16)}:is(.FormControl-radio:after){content:"";height:100%;left:50%;min-height:var(--control-medium-size) var(--control-medium-size);position:absolute;top:50%;transform:translateX(-50%) translateY(-50%);width:100%}:is(.FormControl-radio[disabled]~.FormControl-radio-labelWrap) .FormControl-label{color:var(--control-fgColor-disabled);cursor:not-allowed}.FormControl-radio:checked{border-color:var(--control-checked-borderColor-rest,var(--color-accent-fg));border-width:var(--base-size-4)}.FormControl-radio:checked:disabled,.FormControl-radio[disabled]:checked{border-color:var(--control-fgColor-disabled);cursor:not-allowed}:is(:is(.FormControl-radio[disabled]:checked,.FormControl-radio:checked:disabled)~.FormControl-radio-labelWrap) .FormControl-label{color:var(--control-fgColor-disabled);cursor:not-allowed}.FormControl-radio:focus-visible{box-shadow:none;outline:2px solid var(--focus-outlineColor);outline-offset:2px}@media (forced-colors:active){.FormControl-radio{background-color:canvastext;border-color:canvastext}}@keyframes checkmarkIn{0%{clip-path:inset(var(--base-size-16) 0 0 0)}to{clip-path:inset(0 0 0 0)}}@keyframes checkmarkOut{0%{clip-path:inset(0 0 0 0)}to{clip-path:inset(var(--base-size-16) 0 0 0)}}
1
+ /* stylelint-disable selector-max-type */
2
+ /* stylelint-disable max-nesting-depth */
3
+ /* stylelint-disable selector-max-specificity */
4
+ /* stylelint-disable primer/spacing */
5
+ /* FormControl */
6
+ /* groups label, field, caption and inline error message */
7
+ .FormControl {
8
+ display: inline-flex;
9
+ flex-direction: column;
10
+ gap: var(--base-size-4);
11
+ }
12
+ /* fill container */
13
+ .FormControl--fullWidth {
14
+ display: flex;
15
+ }
16
+ /* <label> */
17
+ .FormControl-label {
18
+ font-size: var(--text-body-size-medium);
19
+ font-weight: var(--base-text-weight-semibold);
20
+ line-height: var(--text-body-lineHeight-medium);
21
+ color: var(--fgColor-default);
22
+ }
23
+ /* optional caption */
24
+ .FormControl-caption {
25
+ margin-bottom: 0;
26
+ font-size: var(--text-caption-size);
27
+ font-weight: var(--text-caption-weight);
28
+ line-height: var(--text-caption-lineHeight);
29
+ color: var(--fgColor-muted);
30
+ }
31
+ /* inline validation message */
32
+ .FormControl-inlineValidation {
33
+ display: flex;
34
+ font-size: var(--text-caption-size);
35
+ font-weight: var(--base-text-weight-semibold);
36
+ line-height: var(--text-caption-lineHeight);
37
+ color: var(--control-danger-fgColor-rest);
38
+ fill: var(--control-danger-fgColor-rest);
39
+ flex-direction: row;
40
+ align-items: flex-start;
41
+ gap: var(--base-size-4);
42
+ }
43
+ .FormControl-inlineValidation p {
44
+ margin-bottom: 0;
45
+ }
46
+ .FormControl-inlineValidation--success {
47
+ color: var(--fgColor-success);
48
+ fill: var(--fgColor-success);
49
+ }
50
+ .FormControl-inlineValidation--visual {
51
+ align-items: center;
52
+ display: flex;
53
+ min-height: var(--base-size-16);
54
+ }
55
+ .FormControl-spacingWrapper {
56
+ display: flex;
57
+ flex-direction: column;
58
+ row-gap: var(--stack-gap-normal);
59
+ }
60
+ .FormControl-horizontalGroup {
61
+ display: flex;
62
+ column-gap: 0.5rem;
63
+ }
64
+ /* shared among all form control components (input, select, textarea, checkbox, radio) */
65
+ /* TextInput structure
66
+ ** ===================
67
+ **
68
+ ** .FormControl
69
+ ** ├─ .FormControl-label
70
+ ** │ ├─ .FormControl-input-wrap
71
+ ** │ │ ├─ .FormControl-input-trailingVisualWrap
72
+ ** │ │ │ ├─ .FormControl-input-trailingVisual
73
+ ** │ │ ├─ .FormControl-input-leadingVisualWrap
74
+ ** │ │ │ ├─ .FormControl-input-leadingVisual
75
+ ** │ │ ├─ .FormControl-input
76
+ ** │ │ ├─ .FormControl-input-trailingAction
77
+ ** ├─ .FormControl-inlineValidation
78
+ ** ├─ .FormControl-caption */
79
+ /* // Select structure
80
+ ** ===================
81
+ **
82
+ ** .FormControl
83
+ ** ├─ .FormControl-label
84
+ ** │ ├─ .FormControl-select-wrap
85
+ ** │ │ ├─ .FormControl-select
86
+ ** ├─ .FormControl-inlineValidation
87
+ ** ├─ .FormControl-caption */
88
+ /* // Textarea structure
89
+ ** ===================
90
+ **
91
+ ** .FormControl
92
+ ** ├─ .FormControl-label
93
+ ** ├─ .FormControl-textarea
94
+ ** ├─ .FormControl-inlineValidation
95
+ ** ├─ .FormControl-caption */
96
+ .FormControl-input,
97
+ .FormControl-select,
98
+ .FormControl-textarea {
99
+ color: var(--fgColor-default);
100
+ background-color: var(--bgColor-default);
101
+ border: var(--borderWidth-thin) solid var(--control-borderColor-rest, var(--color-border-default));
102
+ box-shadow: var(--shadow-inset);
103
+ }
104
+ [disabled]:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
105
+ color: var(--control-fgColor-disabled);
106
+ cursor: not-allowed;
107
+ background-color: var(--control-bgColor-disabled);
108
+ border-color: var(--control-borderColor-disabled);
109
+ box-shadow: none;
110
+ opacity: 1;
111
+ -webkit-text-fill-color: var(--control-fgColor-disabled);
112
+ }
113
+ [invalid='true']:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not(:focus) {
114
+ border-color: var(--control-borderColor-danger);
115
+ }
116
+ [invalid='false']:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not(:focus) {
117
+ border-color: var(--control-borderColor-success);
118
+ }
119
+ :is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type='checkbox'],[type='radio']):focus {
120
+ border-color: var(--focus-outlineColor);
121
+ outline: none;
122
+ box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
123
+
124
+ /* remove fallback :focus if :focus-visible is supported */
125
+ }
126
+ :is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type='checkbox'],[type='radio']):focus:not(:focus-visible) {
127
+ border-color: transparent;
128
+
129
+ border-color: var(--focus-outlineColor);
130
+
131
+ outline: none;
132
+
133
+ box-shadow: inset 0 0 0 1px transparent var(--focus-outlineColor);
134
+ }
135
+ /* default focus state */
136
+ :is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type='checkbox'],[type='radio']):focus-visible {
137
+ border-color: var(--focus-outlineColor);
138
+ outline: none;
139
+ box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
140
+ }
141
+ .FormControl-input,
142
+ .FormControl-select,
143
+ .FormControl-textarea {
144
+
145
+ width: 100%;
146
+ font-size: var(--text-body-size-medium);
147
+ line-height: var(--text-body-lineHeight-medium);
148
+ border-radius: var(--borderRadius-medium);
149
+ transition: 80ms cubic-bezier(0.33, 1, 0.68, 1);
150
+ transition-property: color, background-color, box-shadow, border-color;
151
+ padding-inline: var(--control-medium-paddingInline-condensed);
152
+ padding-block: calc(var(--control-medium-paddingBlock) - var(--borderWidth-thin));
153
+ }
154
+ [disabled]:is(.FormControl-input,.FormControl-select,.FormControl-textarea)::placeholder {
155
+ color: var(--control-fgColor-disabled);
156
+ }
157
+ [readonly]:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
158
+ background-color: var(--control-bgColor-disabled);
159
+ }
160
+ :is(.FormControl-input,.FormControl-select,.FormControl-textarea)::placeholder {
161
+ color: var(--control-fgColor-placeholder);
162
+ opacity: 1;
163
+ }
164
+ /* sizes */
165
+ .FormControl-small:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
166
+ height: var(--control-small-size);
167
+ padding-inline: var(--control-small-paddingInline-normal);
168
+ padding-block: var(--control-small-paddingBlock);
169
+ font-size: var(--text-body-size-small);
170
+ }
171
+ .FormControl-medium:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
172
+ height: var(--control-medium-size);
173
+ }
174
+ .FormControl-large:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
175
+ height: var(--control-large-size);
176
+ padding-inline: var(--control-large-paddingInline-normal);
177
+ padding-block: var(--control-large-paddingBlock);
178
+ }
179
+ /* variants */
180
+ .FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
181
+ background-color: var(--bgColor-muted);
182
+ }
183
+ .FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea):focus-visible,.FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea):focus {
184
+ background-color: var(--bgColor-default);
185
+ }
186
+ .FormControl-monospace:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
187
+ font-family: var(--fontStack-monospace);
188
+ }
189
+ /* validation states */
190
+ .FormControl-error:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
191
+ border-color: var(--control-borderColor-danger);
192
+ }
193
+ .FormControl-success:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
194
+ border-color: var(--control-borderColor-success);
195
+ }
196
+ .FormControl-warning:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
197
+ border-color: var(--control-borderColor-warning);
198
+ }
199
+ .FormControl-toggleSwitchInput {
200
+ display: flex;
201
+ align-items: flex-start;
202
+ gap: var(--base-size-16);
203
+ }
204
+ /* positioning for leading/trailing items for TextInput */
205
+ .FormControl-input-wrap {
206
+ position: relative;
207
+ display: grid;
208
+ }
209
+ .FormControl-input-wrap .FormControl-input-leadingVisualWrap {
210
+ position: absolute;
211
+ top: var(--base-size-8);
212
+ left: var(--base-size-8);
213
+ display: block;
214
+ width: var(--base-size-16);
215
+ height: var(--base-size-16);
216
+ color: var(--fgColor-muted);
217
+ pointer-events: none;
218
+
219
+ /* octicon */
220
+ }
221
+ :is(.FormControl-input-wrap .FormControl-input-leadingVisualWrap) .FormControl-input-leadingVisual {
222
+ display: block;
223
+ -webkit-user-select: none;
224
+ user-select: none;
225
+ }
226
+ .FormControl-input-wrap .FormControl-input-trailingVisualWrap {
227
+ position: absolute;
228
+ top: var(--base-size-8);
229
+ right: var(--base-size-8);
230
+ display: flex;
231
+ height: var(--base-size-16);
232
+ align-items: center;
233
+ gap: var(--base-size-4);
234
+ color: var(--fgColor-muted);
235
+ pointer-events: none;
236
+ }
237
+ :is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap):has(.FormControl-input-trailingVisualText) {
238
+ max-width: 25%;
239
+ padding-left: var(--base-size-8);
240
+ }
241
+ :is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap):has(.FormControl-input-trailingVisualLabel) {
242
+ max-width: 25%;
243
+ padding-left: var(--base-size-8);
244
+ }
245
+ :is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap) .FormControl-input-trailingVisualLabel {
246
+ overflow: hidden;
247
+ text-overflow: ellipsis;
248
+ }
249
+ /* TODO: replace with new Button component */
250
+ .FormControl-input-wrap .FormControl-input-trailingAction {
251
+ position: absolute;
252
+ top: var(--base-size-4);
253
+ right: var(--base-size-4);
254
+ z-index: 4;
255
+ display: grid;
256
+ width: var(--control-xsmall-size);
257
+ height: var(--control-xsmall-size);
258
+ padding: 0;
259
+ color: var(--fgColor-muted);
260
+ cursor: pointer;
261
+ background: transparent;
262
+ border: 0;
263
+ border-radius: var(--borderRadius-small);
264
+ transition: 0.2s cubic-bezier(0.3, 0, 0.5, 1);
265
+ transition-property: color, background-color, border-color;
266
+ align-items: center;
267
+ justify-content: center;
268
+ }
269
+ :is(.FormControl-input-wrap .FormControl-input-trailingAction) svg {
270
+ -webkit-user-select: none;
271
+ user-select: none;
272
+ }
273
+ [disabled]:is(.FormControl-input-wrap .FormControl-input-trailingAction) {
274
+ color: var(--control-fgColor-disabled);
275
+ pointer-events: none;
276
+ }
277
+ :is(.FormControl-input-wrap .FormControl-input-trailingAction):hover {
278
+ background: var(--control-transparent-bgColor-hover);
279
+ }
280
+ :is(.FormControl-input-wrap .FormControl-input-trailingAction):active {
281
+ background: var(--control-transparent-bgColor-active);
282
+ }
283
+ /* show vertical divider line between field and button */
284
+ .FormControl-input-trailingAction--divider:is(.FormControl-input-wrap .FormControl-input-trailingAction)::before {
285
+ position: absolute;
286
+ top: calc((var(--control-xsmall-size) - var(--base-size-16)) / 2);
287
+ left: calc(var(--base-size-4) * -1);
288
+ display: block;
289
+ width: var(--borderWidth-thin);
290
+ height: var(--base-size-16);
291
+ content: '';
292
+ /* stylelint-disable-next-line primer/colors */
293
+ background: var(--borderColor-default);
294
+ }
295
+ :is(:is(.FormControl-input-wrap .FormControl-input-trailingAction)::after) {
296
+ position: absolute;
297
+ top: 50%;
298
+ left: 50%;
299
+ width: 100%;
300
+ height: 100%;
301
+ min-height: var(--control-medium-size) var(--control-medium-size);
302
+ content: "";
303
+ transform: translateX(-50%) translateY(-50%);
304
+ }
305
+ @media (pointer: coarse) {
306
+ :is(.FormControl-input-wrap .FormControl-input-trailingAction)::after {
307
+ min-width: var(--control-minTarget-coarse);
308
+ min-height: var(--control-minTarget-coarse);
309
+ }
310
+ }
311
+ /* if leadingVisual is present */
312
+ /*
313
+ ┌──32px──┬────────────────────┐
314
+ ╎ ┌───┐ ┌────────────────┐ ╎
315
+ ╎ 16px 16px ╎
316
+ ╎ └───┘ └────────────────┘ ╎
317
+ └───────8px───────────────────┘
318
+ */
319
+ .FormControl-input-wrap.FormControl-input-wrap--leadingVisual .FormControl-input {
320
+ padding-inline-start: calc(
321
+ var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap)
322
+ ); /* 32px */
323
+ }
324
+ /* if trailingVisual is present */
325
+ /*
326
+ ┌──────────────────┬──32px──┐
327
+ ╎ ┌──────────────┐ ┌────┐ ╎
328
+ ╎ 24px 24px ╎
329
+ ╎ └──────────────┘ └────┘ ╎
330
+ └──────────────────┴────────┘
331
+ */
332
+ .FormControl-input-wrap.FormControl-input-wrap--trailingVisual .FormControl-input {
333
+ padding-inline-end: calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap));
334
+ }
335
+ .FormControl-input-wrap.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualText) .FormControl-input {
336
+ padding-inline-end: 25%
337
+ }
338
+ .FormControl-input-wrap.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualLabel) .FormControl-input {
339
+ padding-inline-end: 25%
340
+ }
341
+ /*
342
+ ┌──────────────────┬──32px──┐
343
+ ╎ ┌──────────────┐ ┌────┐ ╎
344
+ ╎ 24px 24px ╎
345
+ ╎ └──────────────┘ └────┘ ╎
346
+ └──────────────────┴────────┘
347
+ */
348
+ /* if trailingAction is present */
349
+ .FormControl-input-wrap.FormControl-input-wrap--trailingAction .FormControl-input {
350
+ padding-inline-end: calc(
351
+ var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap)
352
+ ); /* 32px */
353
+ }
354
+ /*
355
+ 32px + 1px border
356
+ ┌──────────────────┬──33px──┐
357
+ ╎ ┌──────────────┐ ┌────┐ ╎
358
+ ╎ 24px 24px ╎
359
+ ╎ └──────────────┘ └────┘ ╎
360
+ └──────────────────┴────────┘
361
+ */
362
+ /* if trailingAction divider is present, add 1px padding to accomodate input field text
363
+ ** can be refactored to has(.FormControl-input-trailingAction--divider) */
364
+ .FormControl-input-wrap.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input {
365
+ padding-inline-end: calc(
366
+ var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap) +
367
+ var(--borderWidth-thin)
368
+ ); /* 33px */
369
+ }
370
+ /* size modifications can be refactored with :has() - FormControl-input-wrap:has(.FormControl-large)
371
+ // sizes */
372
+ .FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-leadingVisualWrap {
373
+ top: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
374
+ left: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
375
+ }
376
+ .FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingVisualWrap {
377
+ top: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
378
+ right: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
379
+ }
380
+ /*
381
+ ┌──────────────────┬──28px──┐
382
+ ╎ ┌──────────────┐ ┌────┐ ╎
383
+ ╎ 20px 20px ╎
384
+ ╎ └──────────────┘ └────┘ ╎
385
+ └──────────────────┴────────┘
386
+ */
387
+ .FormControl-input-wrap.FormControl-input-wrap--small.FormControl-input-wrap--trailingAction .FormControl-input.FormControl-small {
388
+ padding-inline-end: calc(
389
+ var(--control-small-paddingInline-condensed) + var(--base-size-16) + var(--control-small-gap)
390
+ ); /* 28px */
391
+ }
392
+ /*
393
+ 28px + 1px border
394
+ ┌──────────────────┬──29px──┐
395
+ ╎ ┌──────────────┐ ┌────┐ ╎
396
+ ╎ 20px 20px ╎
397
+ ╎ └──────────────┘ └────┘ ╎
398
+ └──────────────────┴────────┘
399
+ */
400
+ .FormControl-input-wrap.FormControl-input-wrap--small.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input.FormControl-small {
401
+ padding-inline-end: calc(
402
+ var(--control-small-paddingInline-condensed) + var(--base-size-16) + var(--control-small-gap) +
403
+ var(--borderWidth-thin)
404
+ ); /* 29px */
405
+ }
406
+ .FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingAction {
407
+ width: calc(var(--control-small-size) - var(--base-size-8));
408
+ height: calc(var(--control-small-size) - var(--base-size-8));
409
+ }
410
+ :is(.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingAction)::before {
411
+ top: calc((var(--control-xsmall-size) - var(--base-size-16)) / 4); /* 2px */
412
+ }
413
+ .FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-leadingVisualWrap {
414
+ top: var(--control-medium-paddingInline-normal);
415
+ left: var(--control-medium-paddingInline-normal);
416
+ }
417
+ .FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingVisualWrap {
418
+ top: var(--control-medium-paddingInline-normal);
419
+ right: var(--control-medium-paddingInline-normal);
420
+ }
421
+ /*
422
+ ┌──36px──┬───12px padding──────┐
423
+ ╎ ┌───┐ ┌────────────────┐ ╎
424
+ ╎ 16px 16px ╎
425
+ ╎ └───┘ └────────────────┘ ╎
426
+ └12px───8px───────────────────┘
427
+ */
428
+ .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--leadingVisual .FormControl-input.FormControl-large {
429
+ padding-inline-start: calc(
430
+ var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap)
431
+ ); /* 36px */
432
+ }
433
+ .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual .FormControl-input {
434
+ padding-inline-end: calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap));
435
+ }
436
+ .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualText) .FormControl-input {
437
+ padding-inline-end: 25%
438
+ }
439
+ .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualLabel) .FormControl-input {
440
+ padding-inline-end: 25%
441
+ }
442
+ .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingText .FormControl-input.FormControl-large {
443
+ padding-inline-end: 25%;
444
+ }
445
+ .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingLabel .FormControl-input.FormControl-large {
446
+ padding-inline-end: 25%;
447
+ }
448
+ /*
449
+ ┌──────────────────┬──36px──┐
450
+ ╎ ┌──────────────┐ ┌────┐ ╎
451
+ ╎ 28px 28px ╎
452
+ ╎ └──────────────┘ └────┘ ╎
453
+ └──────────────────┴────────┘
454
+ */
455
+ .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingAction .FormControl-input.FormControl-large {
456
+ padding-inline-end: calc(
457
+ var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap)
458
+ ); /* 36px */
459
+ }
460
+ /*
461
+ ┌──────────────────┬──37px──┐
462
+ ╎ ┌──────────────┐ ┌────┐ ╎
463
+ ╎ 28px 28px ╎
464
+ ╎ └──────────────┘ └────┘ ╎
465
+ └──────────────────┴────────┘
466
+ */
467
+ .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input.FormControl-large {
468
+ padding-inline-end: calc(
469
+ var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap) +
470
+ var(--borderWidth-thin)
471
+ ); /* 37px */
472
+ }
473
+ .FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingAction {
474
+ top: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
475
+ right: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
476
+ width: var(--control-small-size);
477
+ height: var(--control-small-size);
478
+ }
479
+ :is(.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingAction)::before {
480
+ top: unset;
481
+ height: var(--base-size-20);
482
+ }
483
+ .FormControl-select-wrap {
484
+ display: grid;
485
+ grid-template-columns: minmax(0, auto) var(--base-size-16);
486
+
487
+ /* mask allows for background-color to respect themes */
488
+ }
489
+ .FormControl-select-wrap::after {
490
+ width: var(--base-size-16);
491
+ height: var(--base-size-16);
492
+ padding-right: var(--base-size-4);
493
+ pointer-events: none;
494
+ content: '';
495
+ background-color: var(--bgColor-neutral-emphasis);
496
+ mask: url('');
497
+ mask-size: contain;
498
+ mask-repeat: no-repeat;
499
+ grid-column: 2;
500
+ grid-row: 1;
501
+ place-self: center end;
502
+ }
503
+ /* spans entire grid below mask */
504
+ .FormControl-select-wrap .FormControl-select {
505
+ grid-column: 1/-1;
506
+ grid-row: 1;
507
+ appearance: none;
508
+ padding-right: var(--base-size-20);
509
+ }
510
+ .FormControl-select-wrap[data-multiple]::after {
511
+ content: none;
512
+ }
513
+ .FormControl-select-wrap[data-multiple] .FormControl-select {
514
+ padding-right: var(--base-size-8);
515
+ }
516
+ /* checkbox + radio specific styles */
517
+ /* // Checkbox + Radio structure
518
+ ** ===================
519
+ **
520
+ ** .FormControl-radio-wrap
521
+ ** ├─ .FormControl-radio
522
+ ** ├─ .FormControl-radio-labelWrap
523
+ ** │ ├─ .FormControl-label
524
+ ** │ ├─ .FormControl-caption */
525
+ .FormControl-checkbox-wrap,
526
+ .FormControl-radio-wrap {
527
+ display: inline-grid;
528
+ grid-template-columns: min-content auto;
529
+ gap: var(--base-size-8);
530
+ }
531
+ :is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-checkbox-labelWrap,:is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-radio-labelWrap {
532
+ display: flex;
533
+ flex-direction: column;
534
+ gap: var(--base-size-4);
535
+ }
536
+ :is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-label {
537
+ cursor: pointer;
538
+ }
539
+ .FormControl-radio-group-wrap fieldset {
540
+ padding: 0;
541
+ margin: 0;
542
+ border: 0;
543
+ }
544
+ .FormControl-check-group-wrap fieldset {
545
+ padding: 0;
546
+ margin: 0;
547
+ border: 0;
548
+ }
549
+ /* these selectors are temporary to override base.scss
550
+ ** once Field styles are widely adopted, we can adjust this and the global base styles */
551
+ .FormControl-checkbox {
552
+ color: var(--fgColor-default);
553
+ background-color: var(--bgColor-default);
554
+ border: var(--borderWidth-thin) solid var(--control-borderColor-rest, var(--color-border-default));
555
+ box-shadow: var(--shadow-inset);
556
+ }
557
+ .FormControl-checkbox[disabled] {
558
+ color: var(--control-fgColor-disabled);
559
+ cursor: not-allowed;
560
+ background-color: var(--control-bgColor-disabled);
561
+ border-color: var(--control-borderColor-disabled);
562
+ box-shadow: none;
563
+ opacity: 1;
564
+ -webkit-text-fill-color: var(--control-fgColor-disabled);
565
+ }
566
+ .FormControl-checkbox[invalid='true']:not(:focus) {
567
+ border-color: var(--control-borderColor-danger);
568
+ }
569
+ .FormControl-checkbox[invalid='false']:not(:focus) {
570
+ border-color: var(--control-borderColor-success);
571
+ }
572
+ .FormControl-checkbox:not([type='checkbox'],[type='radio']):focus {
573
+ border-color: var(--focus-outlineColor);
574
+ outline: none;
575
+ box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
576
+
577
+ /* remove fallback :focus if :focus-visible is supported */
578
+ }
579
+ .FormControl-checkbox:not([type='checkbox'],[type='radio']):focus:not(:focus-visible) {
580
+ border-color: transparent;
581
+
582
+ border-color: var(--focus-outlineColor);
583
+
584
+ outline: none;
585
+
586
+ box-shadow: inset 0 0 0 1px transparent var(--focus-outlineColor);
587
+ }
588
+ /* default focus state */
589
+ .FormControl-checkbox:not([type='checkbox'],[type='radio']):focus-visible {
590
+ border-color: var(--focus-outlineColor);
591
+ outline: none;
592
+ box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
593
+ }
594
+ .FormControl-checkbox {
595
+
596
+ position: relative;
597
+ display: grid;
598
+ width: var(--base-size-16);
599
+ height: var(--base-size-16);
600
+ margin: 0;
601
+ margin-top: var(--base-size-2); /* 2px to center align with label (20px line-height) */
602
+ cursor: pointer;
603
+ border-color: var(--control-borderColor-emphasis);
604
+ border-radius: var(--borderRadius-small);
605
+ transition: background-color, border-color 80ms cubic-bezier(0.33, 1, 0.68, 1); /* checked -> unchecked - add 120ms delay to fully see animation-out */
606
+ appearance: none;
607
+ place-content: center;
608
+ }
609
+ .FormControl-checkbox::before {
610
+ width: var(--base-size-16);
611
+ height: var(--base-size-16);
612
+ visibility: hidden;
613
+ content: '';
614
+ /* stylelint-disable-next-line primer/colors */
615
+ background-color: var(--control-checked-fgColor-rest);
616
+ transition: visibility 0s linear 230ms;
617
+ clip-path: inset(var(--base-size-16) 0 0 0);
618
+
619
+ /* octicon checkmark image */
620
+ mask-image: url('');
621
+ mask-size: 75%;
622
+ mask-repeat: no-repeat;
623
+ mask-position: center;
624
+ animation: checkmarkOut 80ms cubic-bezier(0.65, 0, 0.35, 1) forwards; /* slightly snappier animation out */
625
+ }
626
+ /* extend touch target */
627
+ :is(.FormControl-checkbox::after) {
628
+ position: absolute;
629
+ top: 50%;
630
+ left: 50%;
631
+ width: 100%;
632
+ height: 100%;
633
+ min-height: var(--control-medium-size) var(--control-medium-size);
634
+ content: "";
635
+ transform: translateX(-50%) translateY(-50%);
636
+ }
637
+ :is(.FormControl-checkbox[disabled] ~ .FormControl-checkbox-labelWrap) .FormControl-label {
638
+ color: var(--control-fgColor-disabled);
639
+ cursor: not-allowed;
640
+ }
641
+ .FormControl-checkbox:checked {
642
+ background: var(--control-checked-bgColor-rest, var(--color-accent-fg));
643
+ border-color: var(--control-checked-borderColor-rest, var(--color-accent-fg));
644
+ transition: background-color, border-color 80ms cubic-bezier(0.32, 0, 0.67, 0) 0ms; /* unchecked -> checked */
645
+ }
646
+ .FormControl-checkbox:checked::before {
647
+ visibility: visible;
648
+ transition: visibility 0s linear 0s;
649
+ animation: checkmarkIn 80ms cubic-bezier(0.65, 0, 0.35, 1) forwards 80ms;
650
+ }
651
+ .FormControl-checkbox:checked:disabled {
652
+ cursor: not-allowed;
653
+ /* stylelint-disable-next-line primer/colors */
654
+ background-color: var(--control-fgColor-disabled);
655
+ /* stylelint-disable-next-line primer/colors */
656
+ border-color: var(--control-fgColor-disabled);
657
+ opacity: 1;
658
+ }
659
+ .FormControl-checkbox:checked:disabled::before {
660
+ /* stylelint-disable-next-line primer/colors */
661
+ background-color: var(--control-checked-fgColor-rest);
662
+ }
663
+ /* Windows High Contrast mode */
664
+ @media (forced-colors: active) {
665
+ .FormControl-checkbox:checked {
666
+ background-color: canvastext;
667
+ border-color: canvastext;
668
+ }
669
+ }
670
+ .FormControl-checkbox:focus-visible {
671
+ outline: 2px solid var(--focus-outlineColor);
672
+ outline-offset: 2px;
673
+ box-shadow: none;
674
+ }
675
+ .FormControl-checkbox:indeterminate::before {
676
+ mask-image: url('');
677
+ visibility: visible;
678
+ }
679
+ .FormControl-radio {
680
+ color: var(--fgColor-default);
681
+ background-color: var(--bgColor-default);
682
+ border: var(--borderWidth-thin) solid var(--control-borderColor-rest, var(--color-border-default));
683
+ box-shadow: var(--shadow-inset);
684
+ }
685
+ .FormControl-radio[disabled] {
686
+ color: var(--control-fgColor-disabled);
687
+ cursor: not-allowed;
688
+ background-color: var(--control-bgColor-disabled);
689
+ border-color: var(--control-borderColor-disabled);
690
+ box-shadow: none;
691
+ opacity: 1;
692
+ -webkit-text-fill-color: var(--control-fgColor-disabled);
693
+ }
694
+ .FormControl-radio[invalid='true']:not(:focus) {
695
+ border-color: var(--control-borderColor-danger);
696
+ }
697
+ .FormControl-radio[invalid='false']:not(:focus) {
698
+ border-color: var(--control-borderColor-success);
699
+ }
700
+ .FormControl-radio:not([type='checkbox'],[type='radio']):focus {
701
+ border-color: var(--focus-outlineColor);
702
+ outline: none;
703
+ box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
704
+
705
+ /* remove fallback :focus if :focus-visible is supported */
706
+ }
707
+ .FormControl-radio:not([type='checkbox'],[type='radio']):focus:not(:focus-visible) {
708
+ border-color: transparent;
709
+
710
+ border-color: var(--focus-outlineColor);
711
+
712
+ outline: none;
713
+
714
+ box-shadow: inset 0 0 0 1px transparent var(--focus-outlineColor);
715
+ }
716
+ /* default focus state */
717
+ .FormControl-radio:not([type='checkbox'],[type='radio']):focus-visible {
718
+ border-color: var(--focus-outlineColor);
719
+ outline: none;
720
+ box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
721
+ }
722
+ .FormControl-radio {
723
+
724
+ position: relative;
725
+ width: var(--base-size-16);
726
+ height: var(--base-size-16);
727
+ margin: 0;
728
+ margin-top: var(--base-size-2); /* 2px to center align with label (20px line-height) */
729
+ cursor: pointer;
730
+ border-color: var(--control-borderColor-emphasis);
731
+ border-radius: var(--borderRadius-full);
732
+ transition: background-color, border-color 80ms cubic-bezier(0.33, 1, 0.68, 1); /* checked -> unchecked - add 120ms delay to fully see animation-out */
733
+ appearance: none;
734
+ }
735
+ :is(.FormControl-radio::after) {
736
+ position: absolute;
737
+ top: 50%;
738
+ left: 50%;
739
+ width: 100%;
740
+ height: 100%;
741
+ min-height: var(--control-medium-size) var(--control-medium-size);
742
+ content: "";
743
+ transform: translateX(-50%) translateY(-50%);
744
+ }
745
+ :is(.FormControl-radio[disabled] ~ .FormControl-radio-labelWrap) .FormControl-label {
746
+ color: var(--control-fgColor-disabled);
747
+ cursor: not-allowed;
748
+ }
749
+ .FormControl-radio:checked {
750
+ border-color: var(--control-checked-borderColor-rest, var(--color-accent-fg));
751
+ /* stylelint-disable-next-line primer/borders */
752
+ border-width: var(--base-size-4);
753
+ }
754
+ .FormControl-radio[disabled]:checked,.FormControl-radio:checked:disabled {
755
+ cursor: not-allowed;
756
+ /* stylelint-disable-next-line primer/colors */
757
+ border-color: var(--control-fgColor-disabled);
758
+ }
759
+ :is(:is(.FormControl-radio[disabled]:checked,.FormControl-radio:checked:disabled) ~ .FormControl-radio-labelWrap) .FormControl-label {
760
+ color: var(--control-fgColor-disabled);
761
+ cursor: not-allowed;
762
+ }
763
+ .FormControl-radio:focus-visible {
764
+ outline: 2px solid var(--focus-outlineColor);
765
+ outline-offset: 2px;
766
+ box-shadow: none;
767
+ }
768
+ /* Windows High Contrast mode */
769
+ @media (forced-colors: active) {
770
+ .FormControl-radio {
771
+ background-color: canvastext;
772
+ border-color: canvastext;
773
+ }
774
+ }
775
+ @keyframes checkmarkIn {
776
+ from {
777
+ clip-path: inset(var(--base-size-16) 0 0 0);
778
+ }
779
+
780
+ to {
781
+ clip-path: inset(0 0 0 0);
782
+ }
783
+ }
784
+ @keyframes checkmarkOut {
785
+ from {
786
+ clip-path: inset(0 0 0 0);
787
+ }
788
+
789
+ to {
790
+ clip-path: inset(var(--base-size-16) 0 0 0);
791
+ }
792
+ }