mirror of
https://github.com/Redocly/redoc.git
synced 2024-12-24 15:46:20 +03:00
118 lines
3.1 KiB
JavaScript
118 lines
3.1 KiB
JavaScript
'use strict';
|
|
|
|
import {Pipe} from '@angular/core';
|
|
import {isString, stringify, isBlank} from '@angular/core/src/facade/lang';
|
|
import {BaseException} from '@angular/core/src/facade/exceptions';
|
|
import {JsonPointer} from './JsonPointer';
|
|
|
|
import Prism from '../../prismjs-bundle';
|
|
|
|
import 'prismjs/themes/prism-dark.css!css';
|
|
import 'hint.css/hint.base.css!css';
|
|
|
|
import marked from 'marked';
|
|
|
|
// in gfm mode marked doesn't parse #Heading (without space after #) as heading
|
|
// https://github.com/chjj/marked/issues/642
|
|
marked.Lexer.rules.gfm.heading = marked.Lexer.rules.normal.heading;
|
|
marked.Lexer.rules.tables.heading = marked.Lexer.rules.normal.heading;
|
|
|
|
marked.setOptions({
|
|
renderer: new marked.Renderer(),
|
|
gfm: true,
|
|
tables: true,
|
|
breaks: false,
|
|
pedantic: false,
|
|
smartLists: true,
|
|
smartypants: false
|
|
});
|
|
|
|
class InvalidPipeArgumentException extends BaseException {
|
|
constructor(type, value) {
|
|
super(`Invalid argument '${value}' for pipe '${stringify(type)}'`);
|
|
}
|
|
}
|
|
|
|
@Pipe({ name: 'keys' })
|
|
export class KeysPipe {
|
|
transform(value) {
|
|
if (isBlank(value)) return value;
|
|
if (typeof value !== 'object') {
|
|
throw new InvalidPipeArgumentException(ValuesPipe, value);
|
|
}
|
|
return Object.keys(value);
|
|
}
|
|
}
|
|
|
|
@Pipe({ name: 'values' })
|
|
export class ValuesPipe {
|
|
transform(value) {
|
|
if (isBlank(value)) return value;
|
|
if (typeof value !== 'object') {
|
|
throw new InvalidPipeArgumentException(ValuesPipe, value);
|
|
}
|
|
return Object.keys(value).map(key => value[key]);
|
|
}
|
|
}
|
|
|
|
@Pipe({ name: 'jsonPointerEscape' })
|
|
export class JsonPointerEscapePipe {
|
|
transform(value) {
|
|
if (isBlank(value)) return value;
|
|
if (!isString(value)) {
|
|
throw new InvalidPipeArgumentException(JsonPointerEscapePipe, value);
|
|
}
|
|
return JsonPointer.escape(value);
|
|
}
|
|
}
|
|
|
|
@Pipe({ name: 'marked' })
|
|
export class MarkedPipe {
|
|
transform(value) {
|
|
if (isBlank(value)) return value;
|
|
if (!isString(value)) {
|
|
throw new InvalidPipeArgumentException(JsonPointerEscapePipe, value);
|
|
}
|
|
return `<span class="redoc-markdown-block">${marked(value)}</span>`;
|
|
}
|
|
}
|
|
|
|
const langMap = {
|
|
'c++': 'cpp',
|
|
'c#': 'csharp',
|
|
'objective-c': 'objectivec',
|
|
'shell': 'bash',
|
|
'viml': 'vim'
|
|
};
|
|
|
|
@Pipe({ name: 'prism' })
|
|
export class PrismPipe {
|
|
transform(value, args) {
|
|
if (isBlank(args) || args.length === 0) {
|
|
throw new BaseException('Prism pipe requires one argument');
|
|
}
|
|
if (isBlank(value)) return value;
|
|
if (!isString(value)) {
|
|
throw new InvalidPipeArgumentException(JsonPointerEscapePipe, value);
|
|
}
|
|
let lang = args[0].toString().trim().toLowerCase();
|
|
if (langMap[lang]) lang = langMap[lang];
|
|
|
|
let grammar = Prism.languages[lang];
|
|
//fallback to clike
|
|
if (!grammar) grammar = Prism.languages.clike;
|
|
return Prism.highlight(value, grammar);
|
|
}
|
|
}
|
|
|
|
@Pipe({ name: 'encodeURIComponent' })
|
|
export class EncodeURIComponentPipe {
|
|
transform(value) {
|
|
if (isBlank(value)) return value;
|
|
if (!isString(value)) {
|
|
throw new InvalidPipeArgumentException(EncodeURIComponentPipe, value);
|
|
}
|
|
return encodeURIComponent(value);
|
|
}
|
|
}
|