Software zum Installieren eines Smart-Mirror Frameworks , zum Nutzen von hochschulrelevanten Informationen, auf einem Raspberry-Pi.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

index.js 2.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. // @ts-nocheck
  2. 'use strict';
  3. const isContextFunctionalPseudoClass = require('../../utils/isContextFunctionalPseudoClass');
  4. const isNonNegativeInteger = require('../../utils/isNonNegativeInteger');
  5. const isStandardSyntaxRule = require('../../utils/isStandardSyntaxRule');
  6. const parseSelector = require('../../utils/parseSelector');
  7. const report = require('../../utils/report');
  8. const resolvedNestedSelector = require('postcss-resolve-nested-selector');
  9. const ruleMessages = require('../../utils/ruleMessages');
  10. const validateOptions = require('../../utils/validateOptions');
  11. const ruleName = 'selector-max-class';
  12. const messages = ruleMessages(ruleName, {
  13. expected: (selector, max) =>
  14. `Expected "${selector}" to have no more than ${max} ${max === 1 ? 'class' : 'classes'}`,
  15. });
  16. function rule(max) {
  17. return (root, result) => {
  18. const validOptions = validateOptions(result, ruleName, {
  19. actual: max,
  20. possible: isNonNegativeInteger,
  21. });
  22. if (!validOptions) {
  23. return;
  24. }
  25. function checkSelector(selectorNode, ruleNode) {
  26. const count = selectorNode.reduce((total, childNode) => {
  27. // Only traverse inside actual selectors and context functional pseudo-classes
  28. if (childNode.type === 'selector' || isContextFunctionalPseudoClass(childNode)) {
  29. checkSelector(childNode, ruleNode);
  30. }
  31. return (total += childNode.type === 'class' ? 1 : 0);
  32. }, 0);
  33. if (selectorNode.type !== 'root' && selectorNode.type !== 'pseudo' && count > max) {
  34. report({
  35. ruleName,
  36. result,
  37. node: ruleNode,
  38. message: messages.expected(selectorNode, max),
  39. word: selectorNode,
  40. });
  41. }
  42. }
  43. root.walkRules((ruleNode) => {
  44. if (!isStandardSyntaxRule(ruleNode)) {
  45. return;
  46. }
  47. ruleNode.selectors.forEach((selector) => {
  48. resolvedNestedSelector(selector, ruleNode).forEach((resolvedSelector) => {
  49. parseSelector(resolvedSelector, result, ruleNode, (container) =>
  50. checkSelector(container, ruleNode),
  51. );
  52. });
  53. });
  54. });
  55. };
  56. }
  57. rule.ruleName = ruleName;
  58. rule.messages = messages;
  59. module.exports = rule;