mirror of
https://github.com/httpie/cli.git
synced 2025-01-19 03:58:30 +01:00
ff6f1887b0
* Refactor tests to use a text-based standard output. (#1318) * Implement new style `--help` (#1316) * Implement man page generation (#1317) * Implement rich progress bars. (#1324) * Man page deployment & isolation. (#1325) * Remove all unsorted usages in the CLI docs * Implement isolated mode for man page generation * Add a CI job for autogenerated files * Distribute man pages through PyPI * Pin the date for man pages. (#1326) * Hide suppressed arguments from --help/man pages (#1329) * Change download spinner to line (#1328) * Regenerate autogenerated files when pushed against to master. (#1339) * Highlight options (#1340) * Additional man page enhancements (#1341) * Group options by the parent category & highlight -o/--o * Display (and underline) the METAVAR on man pages. * Make help message processing more robust (#1342) * Inherit `help` from `short_help` * Don't mirror short_help directly. * Fixup the serialization * Use `pager` and `man` on `--manual` when applicable (#1343) * Run `man $program` on --manual * Page the output of `--manual` for systems that lack man pages * Improvements over progress bars (separate bar, status line, etc.) (#1346) * Redesign the --help layout. * Make our usage of rich compatible with 9.10.0 * Add `HTTPIE_NO_MAN_PAGES` * Make tests also patch os.get_terminal_size * Generate CLI spec from HTTPie & Man Page Hook (#1354) * Generate CLI spec from HTTPie & add man page hook * Use the full command space for the option headers
177 lines
3.9 KiB
Python
177 lines
3.9 KiB
Python
from typing import Dict, Optional
|
|
|
|
AUTO_STYLE = 'auto' # Follows terminal ANSI color styles
|
|
STYLE_PIE = 'pie'
|
|
STYLE_PIE_DARK = 'pie-dark'
|
|
STYLE_PIE_LIGHT = 'pie-light'
|
|
|
|
|
|
COLOR_PALETTE = {
|
|
# Copy the brand palette
|
|
'white': '#F5F5F0',
|
|
'black': '#1C1818',
|
|
'grey': {
|
|
'50': '#F5F5F0',
|
|
'100': '#EDEDEB',
|
|
'200': '#D1D1CF',
|
|
'300': '#B5B5B2',
|
|
'400': '#999999',
|
|
'500': '#7D7D7D',
|
|
'600': '#666663',
|
|
'700': '#4F4D4D',
|
|
'800': '#363636',
|
|
'900': '#1C1818',
|
|
'DEFAULT': '#7D7D7D',
|
|
},
|
|
'aqua': {
|
|
'50': '#E8F0F5',
|
|
'100': '#D6E3ED',
|
|
'200': '#C4D9E5',
|
|
'300': '#B0CCDE',
|
|
'400': '#9EBFD6',
|
|
'500': '#8CB4CD',
|
|
'600': '#7A9EB5',
|
|
'700': '#698799',
|
|
'800': '#597082',
|
|
'900': '#455966',
|
|
'DEFAULT': '#8CB4CD',
|
|
},
|
|
'purple': {
|
|
'50': '#F0E0FC',
|
|
'100': '#E3C7FA',
|
|
'200': '#D9ADF7',
|
|
'300': '#CC96F5',
|
|
'400': '#BF7DF2',
|
|
'500': '#B464F0',
|
|
'600': '#9E54D6',
|
|
'700': '#8745BA',
|
|
'800': '#70389E',
|
|
'900': '#5C2982',
|
|
'DEFAULT': '#B464F0',
|
|
},
|
|
'orange': {
|
|
'50': '#FFEDDB',
|
|
'100': '#FFDEBF',
|
|
'200': '#FFCFA3',
|
|
'300': '#FFBF87',
|
|
'400': '#FFB06B',
|
|
'500': '#FFA24E',
|
|
'600': '#F2913D',
|
|
'700': '#E3822B',
|
|
'800': '#D6701C',
|
|
'900': '#C75E0A',
|
|
'DEFAULT': '#FFA24E',
|
|
},
|
|
'red': {
|
|
'50': '#FFE0DE',
|
|
'100': '#FFC7C4',
|
|
'200': '#FFB0AB',
|
|
'300': '#FF968F',
|
|
'400': '#FF8075',
|
|
'500': '#FF665B',
|
|
'600': '#E34F45',
|
|
'700': '#C7382E',
|
|
'800': '#AD2117',
|
|
'900': '#910A00',
|
|
'DEFAULT': '#FF665B',
|
|
},
|
|
'blue': {
|
|
'50': '#DBE3FA',
|
|
'100': '#BFCFF5',
|
|
'200': '#A1B8F2',
|
|
'300': '#85A3ED',
|
|
'400': '#698FEB',
|
|
'500': '#4B78E6',
|
|
'600': '#426BD1',
|
|
'700': '#3B5EBA',
|
|
'800': '#3354A6',
|
|
'900': '#2B478F',
|
|
'DEFAULT': '#4B78E6',
|
|
},
|
|
'pink': {
|
|
'50': '#FFEBFF',
|
|
'100': '#FCDBFC',
|
|
'200': '#FCCCFC',
|
|
'300': '#FCBAFC',
|
|
'400': '#FAABFA',
|
|
'500': '#FA9BFA',
|
|
'600': '#DE85DE',
|
|
'700': '#C26EC2',
|
|
'800': '#A854A6',
|
|
'900': '#8C3D8A',
|
|
'DEFAULT': '#FA9BFA',
|
|
},
|
|
'green': {
|
|
'50': '#E3F7E8',
|
|
'100': '#CCF2D6',
|
|
'200': '#B5EDC4',
|
|
'300': '#A1E8B0',
|
|
'400': '#8AE09E',
|
|
'500': '#73DC8C',
|
|
'600': '#63C27A',
|
|
'700': '#52AB66',
|
|
'800': '#429154',
|
|
'900': '#307842',
|
|
'DEFAULT': '#73DC8C',
|
|
},
|
|
'yellow': {
|
|
'50': '#F7F7DB',
|
|
'100': '#F2F2BF',
|
|
'200': '#EDEDA6',
|
|
'300': '#E5E88A',
|
|
'400': '#E0E36E',
|
|
'500': '#DBDE52',
|
|
'600': '#CCCC3D',
|
|
'700': '#BABA29',
|
|
'800': '#ABA614',
|
|
'900': '#999400',
|
|
'DEFAULT': '#DBDE52',
|
|
},
|
|
}
|
|
|
|
# Grey is the same no matter shade for the colors
|
|
COLOR_PALETTE['grey'] = {
|
|
shade: COLOR_PALETTE['grey']['500'] for shade in COLOR_PALETTE['grey'].keys()
|
|
}
|
|
|
|
COLOR_PALETTE['primary'] = {
|
|
'700': COLOR_PALETTE['black'],
|
|
'600': 'ansibrightblack',
|
|
'500': COLOR_PALETTE['white'],
|
|
}
|
|
|
|
COLOR_PALETTE['secondary'] = {'700': '#37523C', '600': '#6c6969', '500': '#6c6969'}
|
|
|
|
|
|
SHADE_NAMES = {
|
|
'500': STYLE_PIE_DARK,
|
|
'600': STYLE_PIE,
|
|
'700': STYLE_PIE_LIGHT
|
|
}
|
|
|
|
STYLE_SHADES = {
|
|
style: shade
|
|
for shade, style in SHADE_NAMES.items()
|
|
}
|
|
|
|
SHADES = [
|
|
'50',
|
|
*map(str, range(100, 1000, 100))
|
|
]
|
|
|
|
|
|
def get_color(
|
|
color: str,
|
|
shade: str,
|
|
*,
|
|
palette: Dict[str, Dict[str, str]] = COLOR_PALETTE
|
|
) -> Optional[str]:
|
|
if color not in palette:
|
|
return None
|
|
|
|
color_code = palette[color]
|
|
if isinstance(color_code, dict) and shade in color_code:
|
|
return color_code[shade]
|
|
else:
|
|
return color_code
|