backgroundPosition.js 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. 'use strict';
  2. var parsers = require('../parsers');
  3. var valid_keywords = ['top', 'center', 'bottom', 'left', 'right'];
  4. var parse = function parse(v) {
  5. if (v === '' || v === null) {
  6. return undefined;
  7. }
  8. var parts = v.split(/\s+/);
  9. if (parts.length > 2 || parts.length < 1) {
  10. return undefined;
  11. }
  12. var types = [];
  13. parts.forEach(function (part, index) {
  14. types[index] = parsers.valueType(part);
  15. });
  16. if (parts.length === 1) {
  17. if (types[0] === parsers.TYPES.LENGTH || types[0] === parsers.TYPES.PERCENT) {
  18. return v;
  19. }
  20. if (types[0] === parsers.TYPES.KEYWORD) {
  21. if (valid_keywords.indexOf(v.toLowerCase()) !== -1 || v.toLowerCase() === 'inherit') {
  22. return v;
  23. }
  24. }
  25. return undefined;
  26. }
  27. if ((types[0] === parsers.TYPES.LENGTH || types[0] === parsers.TYPES.PERCENT) &&
  28. (types[1] === parsers.TYPES.LENGTH || types[1] === parsers.TYPES.PERCENT)) {
  29. return v;
  30. }
  31. if (types[0] !== parsers.TYPES.KEYWORD || types[1] !== parsers.TYPES.KEYWORD) {
  32. return undefined;
  33. }
  34. if (valid_keywords.indexOf(parts[0]) !== -1 && valid_keywords.indexOf(parts[1]) !== -1) {
  35. return v;
  36. }
  37. return undefined;
  38. };
  39. module.exports.isValid = function isValid(v) {
  40. return parse(v) !== undefined;
  41. };
  42. module.exports.definition = {
  43. set: function (v) {
  44. this._setProperty('background-position', parse(v));
  45. },
  46. get: function () {
  47. return this.getPropertyValue('background-position');
  48. },
  49. enumerable: true,
  50. configurable: true
  51. };