UNPKG

@cisstech/nge

Version:

NG Essentials is a collection of libraries for Angular developers.

17 lines 9.56 kB
import { InjectionToken } from '@angular/core'; /** Custom renderers components */ export const NGE_DOC_RENDERERS = new InjectionToken('NGE_DOC_RENDERERS'); export const isNgeDocSettings = (v) => !!v && typeof v === 'object' && !Array.isArray(v) && !!v.meta && !!v.pages; export const extractNgeDocSettings = (v) => { let settings = []; if (isNgeDocSettings(v)) { settings.push(v); } else if (typeof v === 'object') { settings.push(...Object.values(v) .map((v) => extractNgeDocSettings(v)) .flat()); } return settings; }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nge-doc.js","sourceRoot":"","sources":["../../../../../projects/nge/doc/src/nge-doc.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAkB,MAAM,eAAe,CAAA;AA0J9D,kCAAkC;AAClC,MAAM,CAAC,MAAM,iBAAiB,GAAG,IAAI,cAAc,CAAkB,mBAAmB,CAAC,CAAA;AAEzF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,CAAM,EAAuB,EAAE,CAC9D,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;AAE5E,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,CAAM,EAAoB,EAAE;IAChE,IAAI,QAAQ,GAAqB,EAAE,CAAA;IAEnC,IAAI,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC;QACxB,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAClB,CAAC;SAAM,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;QACjC,QAAQ,CAAC,IAAI,CACX,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;aAChB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;aACpC,IAAI,EAAE,CACV,CAAA;IACH,CAAC;IAED,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA","sourcesContent":["import { InjectionToken, Injector, Type } from '@angular/core'\n\nexport declare type StaticPage = NgeDocLink\nexport declare type DynamicPage = (\n  injector: Injector\n) => NgeDocLink | Promise<NgeDocLink> | NgeDocLink[] | Promise<NgeDocLink[]>\n\nexport declare type StaticMeta = NgeDocMeta\nexport declare type DynamicMeta = (injector: Injector) => NgeDocMeta | Promise<NgeDocMeta>\n\nexport declare type NgeDocRenderer = string | Promise<string> | (() => Type<any> | Promise<Type<any>>)\n\nexport declare type NgeDocRenderers = {\n  /** Markdown renderer. */\n  markdown: {\n    /**\n     * Reference to a component that can render markdown content.\n     *\n     * The component should expose a `file` property to render a markdown from an url\n     * and a `data` property to render markdown from a string.\n     */\n    component: () => Type<any> | Promise<Type<any>>\n    /** Inputs objects to pass to the component instance. */\n    inputs?: Record<string, any> | ((injector: Injector) => Record<string, any> | Promise<Record<string, any>>)\n  }\n}\n\nexport declare type NgeDocLinkActionHandler = string | ((injector: Injector) => void | Promise<void>)\n\n/** Documentation site config. */\nexport interface NgeDocSettings {\n  /** Metadata informations about a documentation site. */\n  meta: StaticMeta | DynamicMeta\n  /** Pages of the documentation site. */\n  pages: (StaticPage | DynamicPage)[]\n}\n\n/** Metadata informations about a documentation site. */\nexport interface NgeDocMeta {\n  /** Name of the documentation site. */\n  name: string\n  /** Root url of the documentation site. (absolute url starting with `/`)  */\n  root: string\n  /** Url to the logo to the documentation logo. */\n  logo?: string\n  /** Optional back url (use of Angular [routerLink]) */\n  backUrl?: string\n\n  /** Optional url for the back button icon */\n  backIconUrl?: string\n\n  /** Optional back href */\n  backUrlHref?: string\n\n  /** Optional informations about a github repository linked to the site */\n  repo?: {\n    /** Url of the repository */\n    url: string\n    /** Name of the repository. */\n    name: string\n  }\n  /** social links to show insides the footer */\n  links?: {\n    href: string\n    icon: string\n  }[]\n}\n\nexport interface NgeDocLinAction {\n  /** Url to an icon to render. */\n  icon?: string\n  /** Title of the action. */\n  title?: string\n  /** Action tooltip */\n  tooltip?: string\n  /** Action handler. (A string value here means that the action is an url to open in a new tab) */\n  run: NgeDocLinkActionHandler\n}\n\n/**\n * Representation of a link in the documentation navigation.\n */\nexport interface NgeDocLink {\n  /** Url to display in the browser navigation bar. */\n  href: string\n  /** Title of the link */\n  title: string\n  /**\n   * Content to render once the link is displayed.\n   *\n   * - A one line string value means that the renderer is an url to a markdown file to render.\n   *\n   * Remarks:\n   * Not required if `children` is defined.\n   *\n   * Example:\n   *\n   * `renderer: assets/my-file.md`\n   *\n   * - A multiline string value means that the renderer is a markdown string to render.\n   *\n   * Example:\n   *\n   * `renderer: \"# My Title \\n my paragraph \\n ....\"\n   *\n   * - A reference to a Component type means that the renderer is a dynamic component to render.\n   *\n   *  Example:\n   *\n   *  `renderer: () => MyComponent` // direct reference to a component\n   *\n   *  `renderer: () => import(....).then(m => m.MyComponent)` // reference to a lazy loaded component.\n   *\n   * - A reference to a Module type means that the renderer is a dynamic component to render.\n   *\n   *  `renderer: () => MyModule` // direct reference to a module\n   *\n   *  `renderer: () => import(....).then(m => m.MyModule)` // reference to a lazy loaded module.\n   *\n   * The difference between referencing a module and referencing a component is the following:\n   *  - If you reference a module the dependencies (CommonModule, SharedModule...) of the component\n   *    that you want to render will be resolved.\n   *  - If you reference a component the dependencies will not be loaded.\n   *\n   * If you choose to reference a module, the module must contains a public field `component` that indicates\n   * the component that you want to render.\n   */\n  renderer?: NgeDocRenderer\n  /** Sub links */\n  children?: NgeDocLink[]\n  /** A value indicating whether the link is expanded or not. */\n  expanded?: boolean\n  /** Inputs to pass to the dynamic renderered component if `renderer` is a dynamic component. */\n  inputs?: Record<string, any>\n  /** Optional icon */\n  icon?: string\n  /** Custom actions */\n  actions?: NgeDocLinAction[]\n}\n\n/** Representation of the documentation state. */\nexport interface NgeDocState {\n  /**  Metadata informations about the documentation. */\n  meta: NgeDocMeta\n  /** Root links of the site. */\n  links: NgeDocLink[]\n  /** Current active link. */\n  currLink?: NgeDocLink\n  /** Previous link of the current link. */\n  prevLink?: NgeDocLink\n  /** Next link of the current link. */\n  nextLink?: NgeDocLink\n}\n\n/** Custom renderers components */\nexport const NGE_DOC_RENDERERS = new InjectionToken<NgeDocRenderers>('NGE_DOC_RENDERERS')\n\nexport const isNgeDocSettings = (v: any): v is NgeDocSettings =>\n  !!v && typeof v === 'object' && !Array.isArray(v) && !!v.meta && !!v.pages\n\nexport const extractNgeDocSettings = (v: any): NgeDocSettings[] => {\n  let settings: NgeDocSettings[] = []\n\n  if (isNgeDocSettings(v)) {\n    settings.push(v)\n  } else if (typeof v === 'object') {\n    settings.push(\n      ...Object.values(v)\n        .map((v) => extractNgeDocSettings(v))\n        .flat()\n    )\n  }\n\n  return settings\n}\n"]}