index.d.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. declare function pathToRegexp (path: pathToRegexp.Path, options?: pathToRegexp.RegExpOptions & pathToRegexp.ParseOptions): pathToRegexp.PathRegExp;
  2. declare function pathToRegexp (path: pathToRegexp.Path, keys?: pathToRegexp.Key[], options?: pathToRegexp.RegExpOptions & pathToRegexp.ParseOptions): pathToRegexp.PathRegExp;
  3. declare namespace pathToRegexp {
  4. export interface PathRegExp extends RegExp {
  5. // An array to be populated with the keys found in the path.
  6. keys: Key[];
  7. }
  8. export interface RegExpOptions {
  9. /**
  10. * When `true` the route will be case sensitive. (default: `false`)
  11. */
  12. sensitive?: boolean;
  13. /**
  14. * When `false` the trailing slash is optional. (default: `false`)
  15. */
  16. strict?: boolean;
  17. /**
  18. * When `false` the path will match at the beginning. (default: `true`)
  19. */
  20. end?: boolean;
  21. /**
  22. * Sets the final character for non-ending optimistic matches. (default: `/`)
  23. */
  24. delimiter?: string;
  25. }
  26. export interface ParseOptions {
  27. /**
  28. * Set the default delimiter for repeat parameters. (default: `'/'`)
  29. */
  30. delimiter?: string;
  31. }
  32. export interface TokensToFunctionOptions {
  33. /**
  34. * When `true` the regexp will be case sensitive. (default: `false`)
  35. */
  36. sensitive?: boolean;
  37. }
  38. /**
  39. * Parse an Express-style path into an array of tokens.
  40. */
  41. export function parse (path: string, options?: ParseOptions): Token[];
  42. /**
  43. * Transforming an Express-style path into a valid path.
  44. */
  45. export function compile (path: string, options?: ParseOptions & TokensToFunctionOptions): PathFunction;
  46. /**
  47. * Transform an array of tokens into a path generator function.
  48. */
  49. export function tokensToFunction (tokens: Token[], options?: TokensToFunctionOptions): PathFunction;
  50. /**
  51. * Transform an array of tokens into a matching regular expression.
  52. */
  53. export function tokensToRegExp (tokens: Token[], options?: RegExpOptions): PathRegExp;
  54. export function tokensToRegExp (tokens: Token[], keys?: Key[], options?: RegExpOptions): PathRegExp;
  55. export interface Key {
  56. name: string | number;
  57. prefix: string;
  58. delimiter: string;
  59. optional: boolean;
  60. repeat: boolean;
  61. pattern: string;
  62. partial: boolean;
  63. asterisk: boolean;
  64. }
  65. interface PathFunctionOptions {
  66. pretty?: boolean;
  67. }
  68. export type Token = string | Key;
  69. export type Path = string | RegExp | Array<string | RegExp>;
  70. export type PathFunction = (data?: Object, options?: PathFunctionOptions) => string;
  71. }
  72. export = pathToRegexp;