|
1 | 1 | 'use strict';
|
2 | 2 |
|
3 |
| -var shorthandSetter = require('../parsers').shorthandSetter; |
4 |
| -var shorthandGetter = require('../parsers').shorthandGetter; |
5 |
| - |
6 |
| -var shorthand_for = { |
7 |
| - 'background-color': require('./backgroundColor'), |
8 |
| - 'background-image': require('./backgroundImage'), |
9 |
| - 'background-repeat': require('./backgroundRepeat'), |
10 |
| - 'background-attachment': require('./backgroundAttachment'), |
11 |
| - 'background-position': require('./backgroundPosition'), |
| 3 | +const { shorthandGetter, shorthandSetter, splitTokens, ws } = require('../parsers'); |
| 4 | +const { parse: parseBackgroundAttachment } = require('./backgroundAttachment'); |
| 5 | +const { parse: parseBackgroundColor } = require('./backgroundColor'); |
| 6 | +const { parse: parseBackgroundImage } = require('./backgroundImage'); |
| 7 | +const { parse: parseBackgroundPosition } = require('./backgroundPosition'); |
| 8 | +const { parse: parseBackgroundSize } = require('./backgroundSize'); |
| 9 | +const { parse: parseBackgroundRepeat } = require('./backgroundRepeat'); |
| 10 | +const { parse: parseBackgroundOrigin } = require('./backgroundOrigin'); |
| 11 | +const { parse: parseBackgroundClip } = require('./backgroundClip'); |
| 12 | + |
| 13 | +const before = { |
| 14 | + 'background-color': '', |
| 15 | + 'background-image': '', |
| 16 | + 'background-position': '', |
| 17 | +}; |
| 18 | +const after = { |
| 19 | + 'background-size': '', |
| 20 | + 'background-repeat': '', |
| 21 | + 'background-attachment': '', |
| 22 | + 'background-origin': '', |
| 23 | + 'background-clip': '', |
12 | 24 | };
|
| 25 | +const separatorRegExp = new RegExp(`${ws}/${ws}`); |
| 26 | +const shorthandFor = [before, after]; |
| 27 | + |
| 28 | +function shorthandParser(v, shorthandFor) { |
| 29 | + if (v.toLowerCase() === 'inherit') { |
| 30 | + return {}; |
| 31 | + } |
| 32 | + |
| 33 | + const longhands = { ...shorthandFor }; |
| 34 | + if (v === '') { |
| 35 | + return longhands; |
| 36 | + } |
| 37 | + |
| 38 | + let [[argsBefore, argsAfter]] = splitTokens(v, separatorRegExp); |
| 39 | + |
| 40 | + [argsBefore] = splitTokens(argsBefore); |
| 41 | + |
| 42 | + const { length: argsBeforeLength } = argsBefore; |
| 43 | + let positionArg = []; |
| 44 | + let positionArgIndex = 0; |
| 45 | + let i = 0; |
| 46 | + for (; i < argsBeforeLength; i++) { |
| 47 | + const arg = argsBefore[i]; |
| 48 | + const color = parseBackgroundColor(arg); |
| 49 | + if (color) { |
| 50 | + if (longhands['background-color']) { |
| 51 | + return undefined; |
| 52 | + } |
| 53 | + longhands['background-color'] = color; |
| 54 | + continue; |
| 55 | + } |
| 56 | + const image = parseBackgroundImage(arg); |
| 57 | + if (image) { |
| 58 | + if (longhands['background-image']) { |
| 59 | + return undefined; |
| 60 | + } |
| 61 | + longhands['background-image'] = image; |
| 62 | + continue; |
| 63 | + } |
| 64 | + // First or consecutive <position> |
| 65 | + if (positionArg.length === 0 || positionArgIndex - i === -1) { |
| 66 | + positionArgIndex = i; |
| 67 | + positionArg.push(arg); |
| 68 | + continue; |
| 69 | + } |
| 70 | + return undefined; |
| 71 | + } |
| 72 | + if (!(longhands['background-color'] || longhands['background-image'])) { |
| 73 | + return undefined; |
| 74 | + } |
| 75 | + if ((positionArg = positionArg.join(' '))) { |
| 76 | + const position = parseBackgroundPosition(positionArg); |
| 77 | + if (position === undefined) { |
| 78 | + return undefined; |
| 79 | + } |
| 80 | + longhands['background-position'] = position; |
| 81 | + } |
| 82 | + |
| 83 | + if (argsAfter) { |
| 84 | + [argsAfter] = splitTokens(argsAfter); |
| 85 | + |
| 86 | + const { length: argsAfterLength } = argsAfter; |
| 87 | + const sizeBoxArgs = []; |
| 88 | + let sizeBoxArgIndex = 0; |
| 89 | + for (let i = 0; i < argsAfterLength; i++) { |
| 90 | + const arg = argsAfter[i]; |
| 91 | + const repeat = parseBackgroundRepeat(arg); |
| 92 | + if (repeat) { |
| 93 | + if (longhands['background-repeat']) { |
| 94 | + return undefined; |
| 95 | + } |
| 96 | + longhands['background-repeat'] = repeat; |
| 97 | + continue; |
| 98 | + } |
| 99 | + const attachment = parseBackgroundAttachment(arg); |
| 100 | + if (attachment) { |
| 101 | + if (longhands['background-attachment']) { |
| 102 | + return undefined; |
| 103 | + } |
| 104 | + longhands['background-attachment'] = attachment; |
| 105 | + continue; |
| 106 | + } |
| 107 | + // First or consecutive <box|size> |
| 108 | + if (sizeBoxArgs.length === 0 || sizeBoxArgs.length === 2 || sizeBoxArgIndex - i === -1) { |
| 109 | + sizeBoxArgIndex = i; |
| 110 | + sizeBoxArgs.push(arg); |
| 111 | + continue; |
| 112 | + } |
| 113 | + return undefined; |
| 114 | + } |
| 115 | + |
| 116 | + const { length: sizeBoxArgsLength } = sizeBoxArgs; |
| 117 | + if (sizeBoxArgsLength > 4) { |
| 118 | + return undefined; |
| 119 | + } |
| 120 | + if (sizeBoxArgsLength > 0) { |
| 121 | + const [sizeX, sizeY = '', origin = '', clip = ''] = sizeBoxArgs; |
| 122 | + let parsedSize = parseBackgroundSize(`${sizeX}${sizeY ? ` ${sizeY}` : ''}`); |
| 123 | + let parsedOrigin = parseBackgroundOrigin(origin); |
| 124 | + let parsedClip = parseBackgroundClip(clip); |
| 125 | + if (parsedSize !== undefined && parsedOrigin !== undefined && parsedClip !== undefined) { |
| 126 | + longhands['background-size'] = parsedSize; |
| 127 | + longhands['background-origin'] = parsedOrigin; |
| 128 | + longhands['background-clip'] = parsedClip; |
| 129 | + return longhands; |
| 130 | + } |
| 131 | + parsedSize = parseBackgroundSize(`${origin}${clip ? ` ${clip}` : ''}`); |
| 132 | + parsedOrigin = parseBackgroundOrigin(sizeX); |
| 133 | + parsedClip = parseBackgroundOrigin(sizeY); |
| 134 | + if (parsedSize !== undefined && parsedOrigin !== undefined && parsedClip !== undefined) { |
| 135 | + longhands['background-size'] = parsedSize; |
| 136 | + longhands['background-origin'] = parsedOrigin; |
| 137 | + longhands['background-clip'] = parsedClip; |
| 138 | + return longhands; |
| 139 | + } |
| 140 | + parsedSize = parseBackgroundSize(sizeX); |
| 141 | + parsedOrigin = parseBackgroundOrigin(sizeY); |
| 142 | + parsedClip = parseBackgroundOrigin(origin); |
| 143 | + if (parsedSize !== undefined && parsedOrigin !== undefined && parsedClip !== undefined) { |
| 144 | + longhands['background-size'] = parsedSize; |
| 145 | + longhands['background-origin'] = parsedOrigin; |
| 146 | + longhands['background-clip'] = parsedClip; |
| 147 | + return longhands; |
| 148 | + } |
| 149 | + return undefined; |
| 150 | + } |
| 151 | + } |
| 152 | + |
| 153 | + return longhands; |
| 154 | +} |
13 | 155 |
|
14 | 156 | module.exports.definition = {
|
15 |
| - set: shorthandSetter('background', shorthand_for), |
16 |
| - get: shorthandGetter('background', shorthand_for), |
| 157 | + set: shorthandSetter('background', shorthandFor, shorthandParser), |
| 158 | + get: shorthandGetter('background', shorthandFor), |
17 | 159 | enumerable: true,
|
18 | 160 | configurable: true,
|
19 | 161 | };
|
0 commit comments