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.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. // @ts-nocheck
  2. 'use strict';
  3. const valueParser = require('postcss-value-parser');
  4. const declarationValueIndex = require('../../utils/declarationValueIndex');
  5. const getDeclarationValue = require('../../utils/getDeclarationValue');
  6. const report = require('../../utils/report');
  7. const ruleMessages = require('../../utils/ruleMessages');
  8. const setDeclarationValue = require('../../utils/setDeclarationValue');
  9. const validateOptions = require('../../utils/validateOptions');
  10. const ruleName = 'color-function-notation';
  11. const messages = ruleMessages(ruleName, {
  12. expected: (primary) => `Expected ${primary} color-function notation`,
  13. });
  14. const LEGACY_FUNCS = new Set(['rgba', 'hsla']);
  15. const LEGACY_NOTATION_FUNCS = new Set(['rgb', 'rgba', 'hsl', 'hsla']);
  16. function rule(primary, secondary, context) {
  17. return (root, result) => {
  18. const validOptions = validateOptions(result, ruleName, {
  19. actual: primary,
  20. possible: ['modern', 'legacy'],
  21. });
  22. if (!validOptions) return;
  23. root.walkDecls((decl) => {
  24. let needsFix = false;
  25. const parsedValue = valueParser(getDeclarationValue(decl));
  26. parsedValue.walk((node) => {
  27. const { value, type, sourceIndex, nodes } = node;
  28. if (type !== 'function') return;
  29. if (!LEGACY_NOTATION_FUNCS.has(value.toLowerCase())) return;
  30. if (primary === 'modern' && !hasCommas(node)) return;
  31. if (primary === 'legacy' && hasCommas(node)) return;
  32. if (context.fix && primary === 'modern') {
  33. let commaCount = 0;
  34. // Convert punctuation
  35. node.nodes = nodes.map((childNode) => {
  36. if (isComma(childNode)) {
  37. // Non-alpha commas to space and alpha commas to slashes
  38. if (commaCount < 2) {
  39. childNode.type = 'space';
  40. childNode.value = atLeastOneSpace(childNode.after);
  41. commaCount++;
  42. } else {
  43. childNode.value = '/';
  44. childNode.before = atLeastOneSpace(childNode.before);
  45. childNode.after = atLeastOneSpace(childNode.after);
  46. }
  47. }
  48. return childNode;
  49. });
  50. // Remove trailing 'a' from legacy function name
  51. if (LEGACY_FUNCS.has(node.value.toLowerCase())) {
  52. node.value = node.value.slice(0, -1);
  53. }
  54. needsFix = true;
  55. return;
  56. }
  57. report({
  58. message: messages.expected(primary),
  59. node: decl,
  60. index: declarationValueIndex(decl) + sourceIndex,
  61. result,
  62. ruleName,
  63. });
  64. });
  65. if (needsFix) {
  66. setDeclarationValue(decl, parsedValue.toString());
  67. }
  68. });
  69. };
  70. }
  71. function atLeastOneSpace(whitespace) {
  72. return whitespace !== '' ? whitespace : ' ';
  73. }
  74. function isComma(node) {
  75. return node.type === 'div' && node.value === ',';
  76. }
  77. function hasCommas(node) {
  78. return node.nodes && node.nodes.some((childNode) => isComma(childNode));
  79. }
  80. rule.ruleName = ruleName;
  81. rule.messages = messages;
  82. module.exports = rule;