@instructure/ui-themeable
Version:
A UI component library made by Instructure Inc.
115 lines (101 loc) • 3.45 kB
JavaScript
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(' ');
}
;