UNPKG

11.6 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6exports.getTemplateLocals = getTemplateLocals;
7
8var _keywords = require("./keywords");
9
10var _tokenizerEventHandlers = require("./parser/tokenizer-event-handlers");
11
12var _traverse = _interopRequireDefault(require("./traversal/traverse"));
13
14function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
16/**
17 * Gets the correct Token from the Node based on it's type
18 */
19function tokensFromType(node, scopedTokens, options) {
20 if (node.type === 'PathExpression') {
21 if (node.head.type === 'AtHead' || node.head.type === 'ThisHead') {
22 return;
23 }
24
25 var possbleToken = node.head.name;
26
27 if (scopedTokens.indexOf(possbleToken) === -1) {
28 return possbleToken;
29 }
30 } else if (node.type === 'ElementNode') {
31 var tag = node.tag;
32
33 var _char = tag.charAt(0);
34
35 if (_char === ':' || _char === '@') {
36 return;
37 }
38
39 if (!options.includeHtmlElements && tag.indexOf('.') === -1 && tag.toLowerCase() === tag) {
40 return;
41 }
42
43 if (tag.substr(0, 5) === 'this.') {
44 return;
45 }
46
47 if (scopedTokens.indexOf(tag) !== -1) {
48 return;
49 }
50
51 return tag;
52 }
53}
54/**
55 * Adds tokens to the tokensSet based on their node.type
56 */
57
58
59function addTokens(tokensSet, node, scopedTokens, options) {
60 var maybeTokens = tokensFromType(node, scopedTokens, options);
61 (Array.isArray(maybeTokens) ? maybeTokens : [maybeTokens]).forEach(function (maybeToken) {
62 if (maybeToken !== undefined && maybeToken[0] !== '@') {
63 tokensSet.add(maybeToken.split('.')[0]);
64 }
65 });
66}
67/**
68 * Parses and traverses a given handlebars html template to extract all template locals
69 * referenced that could possible come from the praent scope. Can exclude known keywords
70 * optionally.
71 */
72
73
74function getTemplateLocals(html, options) {
75 if (options === void 0) {
76 options = {
77 includeHtmlElements: false,
78 includeKeywords: false
79 };
80 }
81
82 var ast = (0, _tokenizerEventHandlers.preprocess)(html);
83 var tokensSet = new Set();
84 var scopedTokens = [];
85 (0, _traverse.default)(ast, {
86 Block: {
87 enter: function enter(_ref) {
88 var blockParams = _ref.blockParams;
89 blockParams.forEach(function (param) {
90 scopedTokens.push(param);
91 });
92 },
93 exit: function exit(_ref2) {
94 var blockParams = _ref2.blockParams;
95 blockParams.forEach(function () {
96 scopedTokens.pop();
97 });
98 }
99 },
100 ElementNode: {
101 enter: function enter(node) {
102 node.blockParams.forEach(function (param) {
103 scopedTokens.push(param);
104 });
105 addTokens(tokensSet, node, scopedTokens, options);
106 },
107 exit: function exit(_ref3) {
108 var blockParams = _ref3.blockParams;
109 blockParams.forEach(function () {
110 scopedTokens.pop();
111 });
112 }
113 },
114 PathExpression: function PathExpression(node) {
115 addTokens(tokensSet, node, scopedTokens, options);
116 }
117 });
118 var tokens = [];
119 tokensSet.forEach(function (s) {
120 return tokens.push(s);
121 });
122
123 if (!(options === null || options === void 0 ? void 0 : options.includeKeywords)) {
124 tokens = tokens.filter(function (token) {
125 return !(0, _keywords.isKeyword)(token);
126 });
127 }
128
129 return tokens;
130}
131//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/syntax/lib/get-template-locals.ts"],"names":[],"mappings":"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","sourcesContent":["import { isKeyword } from './keywords';\nimport { preprocess } from './parser/tokenizer-event-handlers';\nimport traverse from './traversal/traverse';\nimport * as ASTv1 from './v1/api';\n\ninterface GetTemplateLocalsOptions {\n  includeKeywords?: boolean;\n  includeHtmlElements?: boolean;\n}\n\n/**\n * Gets the correct Token from the Node based on it's type\n */\nfunction tokensFromType(\n  node: ASTv1.Node,\n  scopedTokens: string[],\n  options: GetTemplateLocalsOptions\n): string | void {\n  if (node.type === 'PathExpression') {\n    if (node.head.type === 'AtHead' || node.head.type === 'ThisHead') {\n      return;\n    }\n\n    const possbleToken = node.head.name;\n\n    if (scopedTokens.indexOf(possbleToken) === -1) {\n      return possbleToken;\n    }\n  } else if (node.type === 'ElementNode') {\n    const { tag } = node;\n\n    const char = tag.charAt(0);\n\n    if (char === ':' || char === '@') {\n      return;\n    }\n\n    if (!options.includeHtmlElements && tag.indexOf('.') === -1 && tag.toLowerCase() === tag) {\n      return;\n    }\n\n    if (tag.substr(0, 5) === 'this.') {\n      return;\n    }\n\n    if (scopedTokens.indexOf(tag) !== -1) {\n      return;\n    }\n\n    return tag;\n  }\n}\n\n/**\n * Adds tokens to the tokensSet based on their node.type\n */\nfunction addTokens(\n  tokensSet: Set<string>,\n  node: ASTv1.Node,\n  scopedTokens: string[],\n  options: GetTemplateLocalsOptions\n) {\n  const maybeTokens = tokensFromType(node, scopedTokens, options);\n\n  (Array.isArray(maybeTokens) ? maybeTokens : [maybeTokens]).forEach((maybeToken) => {\n    if (maybeToken !== undefined && maybeToken[0] !== '@') {\n      tokensSet.add(maybeToken.split('.')[0]);\n    }\n  });\n}\n\n/**\n * Parses and traverses a given handlebars html template to extract all template locals\n * referenced that could possible come from the praent scope. Can exclude known keywords\n * optionally.\n */\nexport function getTemplateLocals(\n  html: string,\n  options: GetTemplateLocalsOptions = {\n    includeHtmlElements: false,\n    includeKeywords: false,\n  }\n): string[] {\n  const ast = preprocess(html);\n  const tokensSet = new Set<string>();\n  const scopedTokens: string[] = [];\n\n  traverse(ast, {\n    Block: {\n      enter({ blockParams }) {\n        blockParams.forEach((param) => {\n          scopedTokens.push(param);\n        });\n      },\n\n      exit({ blockParams }) {\n        blockParams.forEach(() => {\n          scopedTokens.pop();\n        });\n      },\n    },\n\n    ElementNode: {\n      enter(node) {\n        node.blockParams.forEach((param) => {\n          scopedTokens.push(param);\n        });\n        addTokens(tokensSet, node, scopedTokens, options);\n      },\n\n      exit({ blockParams }) {\n        blockParams.forEach(() => {\n          scopedTokens.pop();\n        });\n      },\n    },\n\n    PathExpression(node) {\n      addTokens(tokensSet, node, scopedTokens, options);\n    },\n  });\n\n  let tokens: string[] = [];\n\n  tokensSet.forEach((s) => tokens.push(s));\n\n  if (!options?.includeKeywords) {\n    tokens = tokens.filter((token) => !isKeyword(token));\n  }\n\n  return tokens;\n}\n"],"sourceRoot":""}
\No newline at end of file