UNPKG

@instructure/ui-themeable

Version:

A UI component library made by Instructure Inc.

115 lines (101 loc) 3.45 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.mirrorShorthandEdges = mirrorShorthandEdges; exports.mirrorShorthandCorners = mirrorShorthandCorners; /* * The MIT License (MIT) * * Copyright (c) 2015 - present Instructure, Inc. * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ /** * --- * category: utilities/themes * --- * @module mirrorShorthand */ /** * Mirror shorthand CSS properties for bidirectional text * * Given a string representing a CSS shorthand for edges, * swaps the values such that 4 value syntax is RTL instead * of LTR. * * See the following for further reference: * https://developer.mozilla.org/en-US/docs/Web/CSS/Shorthand_properties * * @param {String} values - space delimited string values representing a CSS shorthand * @returns {String} a space delimited CSS shorthand string converted to RTL */ function mirrorShorthandEdges(values) { if (typeof values !== 'string') { return; } var valuesArr = values.split(' '); if (valuesArr.length === 4) { // swap the 2nd and 4th values ; var _ref = [valuesArr[3], valuesArr[1]]; valuesArr[1] = _ref[0]; valuesArr[3] = _ref[1]; } return valuesArr.join(' '); } /** * Convert shorthand CSS properties for corners to rtl * * Given a string representing a CSS shorthand for corners, * swaps the values such that 2,3 and 4 value syntax is rtl * instead of ltr. * * See the following for further reference: * https://developer.mozilla.org/en-US/docs/Web/CSS/Shorthand_properties * * @param {String} values - space delimited string values representing a CSS shorthand * @returns {String} a space delimited CSS shorthand string converted to RTL */ function mirrorShorthandCorners(values) { if (typeof values !== 'string') { return; } var valuesArr = values.split(' '); if (valuesArr.length === 2) { // swap the 1st and 2nd values ; var _ref2 = [valuesArr[1], valuesArr[0]]; valuesArr[0] = _ref2[0]; valuesArr[1] = _ref2[1]; } if (valuesArr.length === 3) { // convert 3 value syntax to 4 value syntax valuesArr.push(valuesArr[1]); } if (valuesArr.length === 4) { ; var _ref3 = [valuesArr[1], valuesArr[0], valuesArr[3], valuesArr[2]]; valuesArr[0] = _ref3[0]; valuesArr[1] = _ref3[1]; valuesArr[2] = _ref3[2]; valuesArr[3] = _ref3[3]; } return valuesArr.join(' '); }