@jobber/design 0.28.2 → 0.28.3-pre.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/foundation.css +3 -6
- package/package.json +10 -15
- package/buildColors.js +0 -15
- package/buildFoundation.js +0 -15
- package/buildIconStyles.js +0 -44
- package/colors.js +0 -138
- package/foundation_config/postcss-filter-rules/index.js +0 -17
- package/foundation_config/postcss.config.js +0 -58
- package/jobberStyle.js +0 -243
- package/npm-shrinkwrap.json +0 -8594
- package/rollup.config.js +0 -41
- package/src/Borders.mdx +0 -65
- package/src/Colors.mdx +0 -295
- package/src/Elevations.mdx +0 -107
- package/src/Radii.mdx +0 -40
- package/src/ResponsiveBreakpoints.mdx +0 -48
- package/src/Spacing.mdx +0 -121
- package/src/Typography.mdx +0 -191
- package/src/animation.mdx +0 -82
- package/src/borders.css +0 -6
- package/src/colors.css +0 -178
- package/src/elevations.css +0 -12
- package/src/foundation.css +0 -11
- package/src/icons/Colors.css +0 -187
- package/src/icons/Colors.css.d.ts +0 -51
- package/src/icons/Icon.css +0 -102
- package/src/icons/Icon.css.d.ts +0 -37
- package/src/icons/Sizes.css +0 -14
- package/src/icons/Sizes.css.d.ts +0 -7
- package/src/icons/getIcon.test.ts +0 -73
- package/src/icons/getIcon.ts +0 -116
- package/src/icons/iconMap.ts +0 -430
- package/src/icons/iconStyles.d.ts +0 -262
- package/src/icons/iconStyles.ts +0 -269
- package/src/index.ts +0 -10
- package/src/radii.css +0 -6
- package/src/responsiveBreakpoints.css +0 -3
- package/src/shadows.css +0 -13
- package/src/spacing.css +0 -13
- package/src/styles.css +0 -9
- package/src/timings.css +0 -7
- package/src/typography.css +0 -53
- package/tsconfig.json +0 -70
package/foundation.css
CHANGED
|
@@ -180,7 +180,7 @@
|
|
|
180
180
|
|
|
181
181
|
--color-black--rgb: 0, 0, 0;
|
|
182
182
|
--color-black: rgba(var(--color-black--rgb), 1);
|
|
183
|
-
}
|
|
183
|
+
}/* //changed */:root {
|
|
184
184
|
--radius-base: var(--space-smallest);
|
|
185
185
|
--radius-large: var(--space-smaller);
|
|
186
186
|
--radius-larger: var(--space-small);
|
|
@@ -277,14 +277,11 @@
|
|
|
277
277
|
/* 22 */
|
|
278
278
|
}
|
|
279
279
|
}@custom-media --handhelds (width < 640px);@custom-media --medium-screens (width >= 640px);@custom-media --wide-screens (width >= 1024px);body {
|
|
280
|
-
color: rgb(66, 78, 86);
|
|
281
280
|
color: var(--color-text);
|
|
282
|
-
font-family: "Inter", Helvetica, Arial, sans-serif;
|
|
283
281
|
font-family: var(--typography--fontFamily-normal);
|
|
284
|
-
font-size: calc(calc(16px * 1) * 0.875);
|
|
285
282
|
font-size: var(--typography--fontSize-base);
|
|
286
|
-
line-height: 1.5;
|
|
287
283
|
line-height: var(--typography--lineHeight-larger, 1.5);
|
|
288
|
-
background-color: rgba(255, 255, 255, 1);
|
|
289
284
|
background-color: var(--color-surface);
|
|
290
285
|
}
|
|
286
|
+
|
|
287
|
+
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/styles.css","src/borders.css","src/colors.css","src/radii.css","src/spacing.css","src/shadows.css","src/timings.css","src/elevations.css","src/typography.css","src/responsiveBreakpoints.css"],"names":[],"mappings":"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","file":"foundation.css","sourcesContent":["@import url(\"https://fonts.googleapis.com/css2?family=Poppins:wght@700;900&family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\");\n\nbody {\n  color: var(--color-text);\n  font-family: var(--typography--fontFamily-normal);\n  font-size: var(--typography--fontSize-base);\n  line-height: var(--typography--lineHeight-larger, 1.5);\n  background-color: var(--color-surface);\n}\n",":root {\n  --border-base: var(--space-minuscule);\n  --border-thick: var(--space-smallest);\n  --border-thicker: var(--space-smaller);\n  --border-thickest: var(--space-small);\n}\n",":root {\n  /* Jobber Semantic Layer */\n\n  /* Interactive and States */\n  --color-interactive: var(--color-green);\n  --color-interactive--hover: var(--color-green--dark);\n  --color-destructive: var(--color-red);\n  --color-destructive--hover: var(--color-red--dark);\n  --color-interactive--subtle: var(--color-greyBlue);\n  --color-interactive--subtle--hover: var(--color-greyBlue--dark);\n\n  --color-disabled: var(--color-grey);\n  --color-disabled--secondary: var(--color-grey--lighter);\n\n  --color-focus: var(--color-yellow--light);\n\n  /* Status Colours */\n\n  --color-critical: var(--color-red);\n  --color-critical--surface: var(--color-red--lightest);\n  --color-critical--onSurface: var(--color-red--dark);\n\n  --color-warning: var(--color-yellow);\n  --color-warning--surface: var(--color-yellow--lightest);\n  --color-warning--onSurface: var(--color-yellow--dark);\n\n  --color-success: var(--color-green);\n  --color-success--surface: var(--color-green--lightest);\n  --color-success--onSurface: var(--color-green--dark);\n\n  --color-informative: var(--color-lightBlue);\n  --color-informative--surface: var(--color-lightBlue--lightest);\n  --color-informative--onSurface: var(--color-lightBlue--dark);\n\n  --color-inactive: var(--color-blue--light);\n  --color-inactive--surface: var(--color-blue--lightest);\n  --color-inactive--onSurface: var(--color-blue--dark);\n\n  /* Typography */\n  --color-heading: var(--color-blue);\n  --color-text: var(--color-greyBlue--dark);\n  --color-text--secondary: var(--color-greyBlue);\n  --color-text--reverse: var(--color-white);\n  --color-text--reverse--secondary: var(--color-greyBlue--lighter);\n\n  /* Surfaces and Borders */\n  --color-surface: var(--color-white);\n  --color-surface--hover: var(--color-yellow--lightest);\n  --color-surface--active: var(--color-green--lightest);\n  --color-surface--background: var(--color-grey--lightest);\n  --color-surface--reverse: var(--color-blue);\n\n  --color-border: var(--color-grey--lighter);\n  --color-border--section: var(--color-blue);\n\n  --color-overlay: rgba(var(--color-black--rgb), 0.32);\n  --color-overlay--dimmed: rgba(var(--color-white--rgb), 0.6);\n\n  /* Brand */\n  --color-brand: var(--color-green);\n  --color-brand--highlight: rgb(160, 215, 42);\n\n  /* Jobber Workflow Colors */\n  --color-request: var(--color-indigo);\n  --color-quote: var(--color-pink);\n  --color-job: var(--color-yellowGreen);\n  --color-visit: var(--color-green);\n  --color-task: var(--color-navy);\n  --color-event: var(--color-yellow);\n  --color-invoice: var(--color-purple);\n  --color-payments: var(--color-orange);\n\n  --color-client: var(--color-teal);\n\n  /* Jobber Base Palette */\n  --color-blue: rgb(1, 41, 57);\n  --color-blue--light: rgb(77, 105, 116);\n  --color-blue--lighter: rgb(153, 169, 176);\n  --color-blue--lightest: rgb(217, 223, 225);\n  --color-blue--dark: rgb(1, 27, 37);\n\n  --color-green: rgb(125, 176, 14);\n  --color-green--light: rgb(164, 200, 86);\n  --color-green--lighter: rgb(203, 223, 159);\n  --color-green--lightest: rgb(236, 243, 219);\n  --color-green--dark: rgb(81, 114, 9);\n\n  --color-lime: rgb(153, 193, 70);\n  --color-lime--light: rgb(184, 212, 126);\n  --color-lime--lighter: rgb(214, 230, 181);\n  --color-lime--lightest: rgb(240, 246, 227);\n  --color-lime--dark: rgb(99, 125, 46);\n\n  --color-yellowGreen: rgb(187, 197, 32);\n  --color-yellowGreen--light: rgb(207, 214, 99);\n  --color-yellowGreen--lighter: rgb(228, 232, 166);\n  --color-yellowGreen--lightest: rgb(245, 246, 222);\n  --color-yellowGreen--dark: rgb(122, 128, 21);\n\n  --color-yellow: rgb(221, 195, 15);\n  --color-yellow--light: rgb(231, 213, 87);\n  --color-yellow--lighter: rgb(241, 231, 159);\n  --color-yellow--lightest: rgb(250, 246, 219);\n  --color-yellow--dark: rgb(144, 127, 10);\n\n  --color-red: rgb(201, 66, 33);\n  --color-red--light: rgb(233, 141, 119);\n  --color-red--lighter: rgb(255, 206, 194);\n  --color-red--lightest: rgb(255, 226, 219);\n  --color-red--dark: rgb(128, 25, 0);\n\n  --color-grey: rgb(181, 181, 181);\n  --color-grey--light: rgb(203, 203, 203);\n  --color-grey--lighter: rgb(225, 225, 225);\n  --color-grey--lightest: rgb(244, 244, 244);\n  --color-grey--dark: rgb(118, 118, 118);\n\n  --color-greyBlue--rgb: 101, 120, 132;\n  --color-greyBlue: rgba(var(--color-greyBlue--rgb), 1);\n  --color-greyBlue--light: rgb(147, 161, 169);\n  --color-greyBlue--lighter: rgb(193, 201, 206);\n  --color-greyBlue--lightest: rgb(232, 235, 237);\n  --color-greyBlue--dark: rgb(66, 78, 86);\n\n  --color-lightBlue: rgb(60, 162, 224);\n  --color-lightBlue--light: rgb(119, 190, 233);\n  --color-lightBlue--lighter: rgb(177, 218, 243);\n  --color-lightBlue--lightest: rgb(226, 241, 250);\n  --color-lightBlue--dark: rgb(39, 105, 146);\n\n  --color-purple: rgb(136, 112, 196);\n  --color-purple--light: rgb(172, 155, 214);\n  --color-purple--lighter: rgb(207, 198, 231);\n  --color-purple--lightest: rgb(237, 234, 246);\n  --color-purple--dark: rgb(88, 73, 127);\n\n  --color-pink: rgb(179, 96, 150);\n  --color-pink--light: rgb(202, 144, 182);\n  --color-pink--lighter: rgb(225, 191, 213);\n  --color-pink--lightest: rgb(244, 231, 239);\n  --color-pink--dark: rgb(116, 62, 98);\n\n  --color-teal: rgb(62, 173, 146);\n  --color-teal--light: rgb(120, 198, 179);\n  --color-teal--lighter: rgb(178, 222, 211);\n  --color-teal--lightest: rgb(226, 243, 239);\n  --color-teal--dark: rgb(40, 112, 95);\n\n  --color-orange: rgb(243, 150, 36);\n  --color-orange--light: rgb(247, 182, 102);\n  --color-orange--lighter: rgb(250, 213, 167);\n  --color-orange--lightest: rgb(253, 239, 222);\n  --color-orange--dark: rgb(158, 98, 23);\n\n  --color-brown: rgb(130, 107, 70);\n  --color-brown--light: rgb(168, 151, 126);\n  --color-brown--lighter: rgb(205, 196, 181);\n  --color-brown--lightest: rgb(236, 233, 227);\n  --color-brown--dark: rgb(85, 70, 46);\n\n  --color-navy: rgb(75, 106, 150);\n  --color-navy--light: rgb(129, 151, 182);\n  --color-navy--lighter: rgb(183, 195, 213);\n  --color-navy--lightest: rgb(228, 233, 239);\n  --color-navy--dark: rgb(49, 69, 98);\n\n  --color-indigo: rgb(85, 106, 203);\n  --color-indigo--light: rgb(136, 151, 219);\n  --color-indigo--lighter: rgb(187, 195, 234);\n  --color-indigo--lightest: rgb(230, 233, 247);\n  --color-indigo--dark: rgb(55, 69, 132);\n\n  --color-white--rgb: 255, 255, 255;\n  --color-white: rgba(var(--color-white--rgb), 1);\n\n  --color-black--rgb: 0, 0, 0;\n  --color-black: rgba(var(--color-black--rgb), 1);\n}\n","/* //changed */\n:root {\n  --radius-base: var(--space-smallest);\n  --radius-large: var(--space-smaller);\n  --radius-larger: var(--space-small);\n  --radius-circle: 100%;\n}\n",":root {\n  --base-unit: 16px;\n\n  --space-minuscule: calc(var(--base-unit) / 16);\n  --space-smallest: calc(var(--base-unit) / 8);\n  --space-smaller: calc(var(--base-unit) / 4);\n  --space-small: calc(var(--base-unit) / 2);\n  --space-base: calc(var(--base-unit) * 1);\n  --space-large: calc(var(--base-unit) * 1.5);\n  --space-larger: calc(var(--base-unit) * 2);\n  --space-largest: calc(var(--base-unit) * 3);\n  --space-extravagant: calc(var(--base-unit) * 4);\n}\n",":root {\n  --shadow-low: 0px var(--space-minuscule) var(--space-smallest)\n      rgba(0, 0, 0, 0.25),\n    0px 0px var(--space-smallest) rgba(0, 0, 0, 0.1);\n  --shadow-base: 0px var(--space-minuscule) var(--space-smaller) 0px\n      rgba(0, 0, 0, 0.1),\n    0px var(--space-smaller) 12px 0px rgba(0, 0, 0, 0.05);\n  --shadow-high: 0px var(--space-base) var(--space-base) 0px\n      rgba(0, 0, 0, 0.075),\n    0px 0px var(--space-small) 0px rgba(0, 0, 0, 0.05);\n  --shadow-focus: 0px 0px var(--space-smaller) var(--space-smallest)\n    var(--color-focus);\n}\n",":root {\n  --timing-quick: 100ms;\n  --timing-base: 200ms;\n  --timing-slow: 300ms;\n  --timing-slower: 400ms;\n  --timing-slowest: 500ms;\n}\n",":root {\n  --elevation-base: 1;\n  --elevation-menu: 6;\n  --elevation-datepicker: 6;\n  /**\n   * Modal has this much z-index to overcome docz z-index. This can be lowered\n   * once we create our own docz theme\n   */\n  --elevation-modal: 1001;\n  --elevation-tooltip: 1002;\n  --elevation-toast: 1003;\n}\n",":root {\n  --typography--letterSpacing-base: 0;\n  --typography--letterSpacing-loose: calc(var(--base-unit) / 40);\n\n  --typography--fontFamily-normal: \"Inter\", Helvetica, Arial, sans-serif;\n  --typography--fontFamily-display: \"Jobber Pro\", \"Poppins\", Helvetica, Arial,\n    sans-serif;\n\n  --typography--fontSize-extravagant: calc(\n    var(--typography--fontSize-large) * 3\n  );\n  /* 48 */\n  --typography--fontSize-jumbo: calc(var(--typography--fontSize-large) * 2.25);\n  /* 36 */\n  --typography--fontSize-largest: calc(var(--typography--fontSize-large) * 1.5);\n  /* 24 */\n  --typography--fontSize-larger: calc(var(--typography--fontSize-large) * 1.25);\n  /* 20 */\n  --typography--fontSize-large: calc(var(--base-unit) * 1);\n  /* 16 */\n  --typography--fontSize-base: calc(var(--typography--fontSize-large) * 0.875);\n  /* 14 */\n  --typography--fontSize-small: calc(var(--typography--fontSize-large) * 0.75);\n  /* 12 */\n  --typography--fontSize-smaller: calc(\n    var(--typography--fontSize-large) * 0.625\n  );\n  /* 10 */\n\n  --typography--lineHeight-large: 1.34;\n  --typography--lineHeight-base: 1.25;\n  --typography--lineHeight-tight: 1.2;\n  --typography--lineHeight-tighter: 1.143;\n  --typography--lineHeight-tightest: 1.12;\n  --typography--lineHeight-miniscule: 1.08;\n}\n\n@media (--handhelds) {\n  :root {\n    --typography--fontSize-extravagant: calc(\n      var(--typography--fontSize-large) * 2.5\n    );\n    /* 40 */\n    --typography--fontSize-jumbo: calc(\n      var(--typography--fontSize-large) * 1.75\n    );\n    /* 28 */\n    --typography--fontSize-largest: calc(\n      var(--typography--fontSize-large) * 1.375\n    );\n    /* 22 */\n  }\n}\n","@custom-media --handhelds (width < 640px);\n@custom-media --medium-screens (width >= 640px);\n@custom-media --wide-screens (width >= 1024px);\n"]} */
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@jobber/design",
|
|
3
|
-
"version": "0.28.2",
|
|
3
|
+
"version": "0.28.3-pre.2+a045d54b",
|
|
4
4
|
"description": "Design foundation for the Jobber Atlantis Design System",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -9,36 +9,31 @@
|
|
|
9
9
|
"dist/*",
|
|
10
10
|
"*.css",
|
|
11
11
|
"foundation.*",
|
|
12
|
-
"icons/*"
|
|
13
|
-
"src/*",
|
|
14
|
-
"foundation_config/*",
|
|
15
|
-
"tsconfig.json",
|
|
16
|
-
"*.js"
|
|
12
|
+
"icons/*"
|
|
17
13
|
],
|
|
18
14
|
"scripts": {
|
|
19
15
|
"build": "npm run build:css && npm run build:css:icons && npm run build:colors && npm run build:cssTypes && npm run build:foundation && npm run build:iconCssStyle && npm run build:rollup",
|
|
20
16
|
"build:rollup": "rollup --config",
|
|
21
|
-
"build:css": "postcss src/foundation.css --
|
|
17
|
+
"build:css": "postcss src/foundation.css --output foundation.css --use postcss-import",
|
|
22
18
|
"build:css:icons": "postcss src/icons/*.css --dir icons/ --use postcss-import",
|
|
23
19
|
"build:ts": "tsc --project .",
|
|
24
20
|
"build:cssTypes": "tcm src/icons",
|
|
25
21
|
"build:colors": "node buildColors.js",
|
|
26
22
|
"build:foundation": "node buildFoundation.js && node jobberStyle.js && npm run build:foundationTypes && npm run build:addTypeLinterExceptions && npm run build:addFoundationLinterExceptions && npm run build:removeTempFiles",
|
|
27
|
-
"build:foundationTypes": "tsc --declaration --emitDeclarationOnly --allowJs foundation.js --outDir .
|
|
23
|
+
"build:foundationTypes": "tsc --declaration --emitDeclarationOnly --allowJs foundation.js --outDir .",
|
|
28
24
|
"build:addTypeLinterExceptions": "(printf '/* tslint:disable */\n/* eslint-disable */\n/* This file is automatically generated and should not be edited. */\n'; cat foundation.d.ts) > foundation.d.ts.temp",
|
|
29
25
|
"build:addFoundationLinterExceptions": "(printf '/* tslint:disable */\n/* eslint-disable */\n/* This file is automatically generated and should not be edited. */\n'; cat foundation.js) > foundation.js.temp",
|
|
30
26
|
"build:removeTempFiles": "rm -f src/foundation.js && mv foundation.d.ts.temp foundation.d.ts && mv foundation.js.temp foundation.js",
|
|
31
27
|
"build:iconCssStyle": "node buildIconStyles.js && npm run build:iconCssStyleTypes",
|
|
32
|
-
"build:iconCssStyleTypes": "tsc --declaration --emitDeclarationOnly --allowJs src/icons/iconStyles.ts --outDir ./src/icons
|
|
33
|
-
"clean": "rm -rf dist/* icons/* colors.js foundation.* iconStyles.* tsconfig.tsbuildinfo
|
|
28
|
+
"build:iconCssStyleTypes": "tsc --declaration --emitDeclarationOnly --allowJs src/icons/iconStyles.ts --outDir ./src/icons",
|
|
29
|
+
"clean": "rm -rf dist/* icons/* colors.js foundation.* iconStyles.* tsconfig.tsbuildinfo",
|
|
34
30
|
"prepare": "npm run clean && npm run build",
|
|
35
|
-
"postinstall": "npm run prepare",
|
|
36
31
|
"ci:typescript-compile": "npm run build:ts"
|
|
37
32
|
},
|
|
38
|
-
"optionalDependencies": {
|
|
39
|
-
"@jobber/fonts": "^1.0.0"
|
|
40
|
-
},
|
|
41
33
|
"dependencies": {
|
|
34
|
+
"classnames": "^2.2.6"
|
|
35
|
+
},
|
|
36
|
+
"devDependencies": {
|
|
42
37
|
"@types/classnames": "^2.2.10",
|
|
43
38
|
"autoprefixer": "^9.5.1",
|
|
44
39
|
"classnames": "^2.2.6",
|
|
@@ -61,5 +56,5 @@
|
|
|
61
56
|
"typed-css-modules": "^0.7.0",
|
|
62
57
|
"typescript": "^3.8.3"
|
|
63
58
|
},
|
|
64
|
-
"gitHead": "
|
|
59
|
+
"gitHead": "a045d54b3697c071d721d0bbbcfc306810ca642c"
|
|
65
60
|
}
|
package/buildColors.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
/* eslint-env node */
|
|
2
|
-
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
3
|
-
const fs = require("fs");
|
|
4
|
-
const postcss = require("postcss");
|
|
5
|
-
const postcssCustomProperties = require("postcss-custom-properties");
|
|
6
|
-
|
|
7
|
-
const colors = fs.readFileSync("src/colors.css");
|
|
8
|
-
|
|
9
|
-
postcss([
|
|
10
|
-
postcssCustomProperties({
|
|
11
|
-
exportTo: ["colors.js"],
|
|
12
|
-
}),
|
|
13
|
-
])
|
|
14
|
-
.process(colors, { from: undefined })
|
|
15
|
-
.then();
|
package/buildFoundation.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
/* eslint-env node */
|
|
2
|
-
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
3
|
-
const fs = require("fs");
|
|
4
|
-
const postcss = require("postcss");
|
|
5
|
-
const postcssCustomProperties = require("postcss-custom-properties");
|
|
6
|
-
|
|
7
|
-
const foundation = fs.readFileSync("./foundation.css");
|
|
8
|
-
|
|
9
|
-
postcss([
|
|
10
|
-
postcssCustomProperties({
|
|
11
|
-
exportTo: ["src/foundation.js"],
|
|
12
|
-
}),
|
|
13
|
-
])
|
|
14
|
-
.process(foundation, { from: undefined })
|
|
15
|
-
.then();
|
package/buildIconStyles.js
DELETED
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
/* eslint-env node */
|
|
2
|
-
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
3
|
-
|
|
4
|
-
const fs = require("fs");
|
|
5
|
-
const path = require("path");
|
|
6
|
-
const postcss = require("postcss");
|
|
7
|
-
const postcssCustomProperties = require("postcss-custom-properties");
|
|
8
|
-
const postcssCalc = require("postcss-calc");
|
|
9
|
-
const transform = require("css-to-react-native-transform").default;
|
|
10
|
-
|
|
11
|
-
const icon = fs.readFileSync("src/icons/Icon.css");
|
|
12
|
-
const size = fs.readFileSync("src/icons/Sizes.css");
|
|
13
|
-
const color = fs.readFileSync("src/icons/Colors.css");
|
|
14
|
-
|
|
15
|
-
const allCss = [icon, size, color].join("\n");
|
|
16
|
-
|
|
17
|
-
postcss([
|
|
18
|
-
postcssCustomProperties({
|
|
19
|
-
preserve: false,
|
|
20
|
-
importFrom: ["foundation.css"],
|
|
21
|
-
}),
|
|
22
|
-
postcssCalc(),
|
|
23
|
-
])
|
|
24
|
-
.process(allCss, { from: undefined })
|
|
25
|
-
.then(function (result) {
|
|
26
|
-
const calculated = transform(result.css);
|
|
27
|
-
const jsonContent =
|
|
28
|
-
"/* This file is automatically generated by buildIconStyle.js and should not be edited. */\n" +
|
|
29
|
-
"export const iconStyles = " +
|
|
30
|
-
JSON.stringify(calculated, undefined, 2);
|
|
31
|
-
|
|
32
|
-
fs.writeFile(
|
|
33
|
-
path.join(__dirname, "src/icons/iconStyles.ts"),
|
|
34
|
-
jsonContent,
|
|
35
|
-
"utf8",
|
|
36
|
-
function (err) {
|
|
37
|
-
if (err) {
|
|
38
|
-
console.log("An error occurred while writing JSON object to File.");
|
|
39
|
-
return console.log(err);
|
|
40
|
-
}
|
|
41
|
-
console.log("JSON file has been saved.");
|
|
42
|
-
},
|
|
43
|
-
);
|
|
44
|
-
});
|
package/colors.js
DELETED
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
module.exports = {
|
|
2
|
-
customProperties: {
|
|
3
|
-
'--color-interactive': 'var(--color-green)',
|
|
4
|
-
'--color-interactive--hover': 'var(--color-green--dark)',
|
|
5
|
-
'--color-destructive': 'var(--color-red)',
|
|
6
|
-
'--color-destructive--hover': 'var(--color-red--dark)',
|
|
7
|
-
'--color-interactive--subtle': 'var(--color-greyBlue)',
|
|
8
|
-
'--color-interactive--subtle--hover': 'var(--color-greyBlue--dark)',
|
|
9
|
-
'--color-disabled': 'var(--color-grey)',
|
|
10
|
-
'--color-disabled--secondary': 'var(--color-grey--lighter)',
|
|
11
|
-
'--color-focus': 'var(--color-yellow--light)',
|
|
12
|
-
'--color-critical': 'var(--color-red)',
|
|
13
|
-
'--color-critical--surface': 'var(--color-red--lightest)',
|
|
14
|
-
'--color-critical--onSurface': 'var(--color-red--dark)',
|
|
15
|
-
'--color-warning': 'var(--color-yellow)',
|
|
16
|
-
'--color-warning--surface': 'var(--color-yellow--lightest)',
|
|
17
|
-
'--color-warning--onSurface': 'var(--color-yellow--dark)',
|
|
18
|
-
'--color-success': 'var(--color-green)',
|
|
19
|
-
'--color-success--surface': 'var(--color-green--lightest)',
|
|
20
|
-
'--color-success--onSurface': 'var(--color-green--dark)',
|
|
21
|
-
'--color-informative': 'var(--color-lightBlue)',
|
|
22
|
-
'--color-informative--surface': 'var(--color-lightBlue--lightest)',
|
|
23
|
-
'--color-informative--onSurface': 'var(--color-lightBlue--dark)',
|
|
24
|
-
'--color-inactive': 'var(--color-blue--light)',
|
|
25
|
-
'--color-inactive--surface': 'var(--color-blue--lightest)',
|
|
26
|
-
'--color-inactive--onSurface': 'var(--color-blue--dark)',
|
|
27
|
-
'--color-heading': 'var(--color-blue)',
|
|
28
|
-
'--color-text': 'var(--color-greyBlue--dark)',
|
|
29
|
-
'--color-text--secondary': 'var(--color-greyBlue)',
|
|
30
|
-
'--color-text--reverse': 'var(--color-white)',
|
|
31
|
-
'--color-text--reverse--secondary': 'var(--color-greyBlue--lighter)',
|
|
32
|
-
'--color-surface': 'var(--color-white)',
|
|
33
|
-
'--color-surface--hover': 'var(--color-yellow--lightest)',
|
|
34
|
-
'--color-surface--active': 'var(--color-green--lightest)',
|
|
35
|
-
'--color-surface--background': 'var(--color-grey--lightest)',
|
|
36
|
-
'--color-surface--reverse': 'var(--color-blue)',
|
|
37
|
-
'--color-border': 'var(--color-grey--lighter)',
|
|
38
|
-
'--color-border--section': 'var(--color-blue)',
|
|
39
|
-
'--color-overlay': 'rgba(var(--color-black--rgb), 0.32)',
|
|
40
|
-
'--color-overlay--dimmed': 'rgba(var(--color-white--rgb), 0.6)',
|
|
41
|
-
'--color-brand': 'var(--color-green)',
|
|
42
|
-
'--color-brand--highlight': 'rgb(160, 215, 42)',
|
|
43
|
-
'--color-request': 'var(--color-indigo)',
|
|
44
|
-
'--color-quote': 'var(--color-pink)',
|
|
45
|
-
'--color-job': 'var(--color-yellowGreen)',
|
|
46
|
-
'--color-visit': 'var(--color-green)',
|
|
47
|
-
'--color-task': 'var(--color-navy)',
|
|
48
|
-
'--color-event': 'var(--color-yellow)',
|
|
49
|
-
'--color-invoice': 'var(--color-purple)',
|
|
50
|
-
'--color-payments': 'var(--color-orange)',
|
|
51
|
-
'--color-client': 'var(--color-teal)',
|
|
52
|
-
'--color-blue': 'rgb(1, 41, 57)',
|
|
53
|
-
'--color-blue--light': 'rgb(77, 105, 116)',
|
|
54
|
-
'--color-blue--lighter': 'rgb(153, 169, 176)',
|
|
55
|
-
'--color-blue--lightest': 'rgb(217, 223, 225)',
|
|
56
|
-
'--color-blue--dark': 'rgb(1, 27, 37)',
|
|
57
|
-
'--color-green': 'rgb(125, 176, 14)',
|
|
58
|
-
'--color-green--light': 'rgb(164, 200, 86)',
|
|
59
|
-
'--color-green--lighter': 'rgb(203, 223, 159)',
|
|
60
|
-
'--color-green--lightest': 'rgb(236, 243, 219)',
|
|
61
|
-
'--color-green--dark': 'rgb(81, 114, 9)',
|
|
62
|
-
'--color-lime': 'rgb(153, 193, 70)',
|
|
63
|
-
'--color-lime--light': 'rgb(184, 212, 126)',
|
|
64
|
-
'--color-lime--lighter': 'rgb(214, 230, 181)',
|
|
65
|
-
'--color-lime--lightest': 'rgb(240, 246, 227)',
|
|
66
|
-
'--color-lime--dark': 'rgb(99, 125, 46)',
|
|
67
|
-
'--color-yellowGreen': 'rgb(187, 197, 32)',
|
|
68
|
-
'--color-yellowGreen--light': 'rgb(207, 214, 99)',
|
|
69
|
-
'--color-yellowGreen--lighter': 'rgb(228, 232, 166)',
|
|
70
|
-
'--color-yellowGreen--lightest': 'rgb(245, 246, 222)',
|
|
71
|
-
'--color-yellowGreen--dark': 'rgb(122, 128, 21)',
|
|
72
|
-
'--color-yellow': 'rgb(221, 195, 15)',
|
|
73
|
-
'--color-yellow--light': 'rgb(231, 213, 87)',
|
|
74
|
-
'--color-yellow--lighter': 'rgb(241, 231, 159)',
|
|
75
|
-
'--color-yellow--lightest': 'rgb(250, 246, 219)',
|
|
76
|
-
'--color-yellow--dark': 'rgb(144, 127, 10)',
|
|
77
|
-
'--color-red': 'rgb(201, 66, 33)',
|
|
78
|
-
'--color-red--light': 'rgb(233, 141, 119)',
|
|
79
|
-
'--color-red--lighter': 'rgb(255, 206, 194)',
|
|
80
|
-
'--color-red--lightest': 'rgb(255, 226, 219)',
|
|
81
|
-
'--color-red--dark': 'rgb(128, 25, 0)',
|
|
82
|
-
'--color-grey': 'rgb(181, 181, 181)',
|
|
83
|
-
'--color-grey--light': 'rgb(203, 203, 203)',
|
|
84
|
-
'--color-grey--lighter': 'rgb(225, 225, 225)',
|
|
85
|
-
'--color-grey--lightest': 'rgb(244, 244, 244)',
|
|
86
|
-
'--color-grey--dark': 'rgb(118, 118, 118)',
|
|
87
|
-
'--color-greyBlue--rgb': '101, 120, 132',
|
|
88
|
-
'--color-greyBlue': 'rgba(var(--color-greyBlue--rgb), 1)',
|
|
89
|
-
'--color-greyBlue--light': 'rgb(147, 161, 169)',
|
|
90
|
-
'--color-greyBlue--lighter': 'rgb(193, 201, 206)',
|
|
91
|
-
'--color-greyBlue--lightest': 'rgb(232, 235, 237)',
|
|
92
|
-
'--color-greyBlue--dark': 'rgb(66, 78, 86)',
|
|
93
|
-
'--color-lightBlue': 'rgb(60, 162, 224)',
|
|
94
|
-
'--color-lightBlue--light': 'rgb(119, 190, 233)',
|
|
95
|
-
'--color-lightBlue--lighter': 'rgb(177, 218, 243)',
|
|
96
|
-
'--color-lightBlue--lightest': 'rgb(226, 241, 250)',
|
|
97
|
-
'--color-lightBlue--dark': 'rgb(39, 105, 146)',
|
|
98
|
-
'--color-purple': 'rgb(136, 112, 196)',
|
|
99
|
-
'--color-purple--light': 'rgb(172, 155, 214)',
|
|
100
|
-
'--color-purple--lighter': 'rgb(207, 198, 231)',
|
|
101
|
-
'--color-purple--lightest': 'rgb(237, 234, 246)',
|
|
102
|
-
'--color-purple--dark': 'rgb(88, 73, 127)',
|
|
103
|
-
'--color-pink': 'rgb(179, 96, 150)',
|
|
104
|
-
'--color-pink--light': 'rgb(202, 144, 182)',
|
|
105
|
-
'--color-pink--lighter': 'rgb(225, 191, 213)',
|
|
106
|
-
'--color-pink--lightest': 'rgb(244, 231, 239)',
|
|
107
|
-
'--color-pink--dark': 'rgb(116, 62, 98)',
|
|
108
|
-
'--color-teal': 'rgb(62, 173, 146)',
|
|
109
|
-
'--color-teal--light': 'rgb(120, 198, 179)',
|
|
110
|
-
'--color-teal--lighter': 'rgb(178, 222, 211)',
|
|
111
|
-
'--color-teal--lightest': 'rgb(226, 243, 239)',
|
|
112
|
-
'--color-teal--dark': 'rgb(40, 112, 95)',
|
|
113
|
-
'--color-orange': 'rgb(243, 150, 36)',
|
|
114
|
-
'--color-orange--light': 'rgb(247, 182, 102)',
|
|
115
|
-
'--color-orange--lighter': 'rgb(250, 213, 167)',
|
|
116
|
-
'--color-orange--lightest': 'rgb(253, 239, 222)',
|
|
117
|
-
'--color-orange--dark': 'rgb(158, 98, 23)',
|
|
118
|
-
'--color-brown': 'rgb(130, 107, 70)',
|
|
119
|
-
'--color-brown--light': 'rgb(168, 151, 126)',
|
|
120
|
-
'--color-brown--lighter': 'rgb(205, 196, 181)',
|
|
121
|
-
'--color-brown--lightest': 'rgb(236, 233, 227)',
|
|
122
|
-
'--color-brown--dark': 'rgb(85, 70, 46)',
|
|
123
|
-
'--color-navy': 'rgb(75, 106, 150)',
|
|
124
|
-
'--color-navy--light': 'rgb(129, 151, 182)',
|
|
125
|
-
'--color-navy--lighter': 'rgb(183, 195, 213)',
|
|
126
|
-
'--color-navy--lightest': 'rgb(228, 233, 239)',
|
|
127
|
-
'--color-navy--dark': 'rgb(49, 69, 98)',
|
|
128
|
-
'--color-indigo': 'rgb(85, 106, 203)',
|
|
129
|
-
'--color-indigo--light': 'rgb(136, 151, 219)',
|
|
130
|
-
'--color-indigo--lighter': 'rgb(187, 195, 234)',
|
|
131
|
-
'--color-indigo--lightest': 'rgb(230, 233, 247)',
|
|
132
|
-
'--color-indigo--dark': 'rgb(55, 69, 132)',
|
|
133
|
-
'--color-white--rgb': '255, 255, 255',
|
|
134
|
-
'--color-white': 'rgba(var(--color-white--rgb), 1)',
|
|
135
|
-
'--color-black--rgb': '0, 0, 0',
|
|
136
|
-
'--color-black': 'rgba(var(--color-black--rgb), 1)'
|
|
137
|
-
}
|
|
138
|
-
};
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
/* eslint-env node */
|
|
2
|
-
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
3
|
-
|
|
4
|
-
const postcss = require("postcss");
|
|
5
|
-
|
|
6
|
-
module.exports = postcss.plugin(
|
|
7
|
-
"postcss-filter-rules",
|
|
8
|
-
(opts = { ruleFilters: [] }) => {
|
|
9
|
-
// Work with options here
|
|
10
|
-
|
|
11
|
-
return root => {
|
|
12
|
-
root.nodes.forEach(rule => {
|
|
13
|
-
opts.ruleFilters.forEach(filter => filter(rule));
|
|
14
|
-
});
|
|
15
|
-
};
|
|
16
|
-
},
|
|
17
|
-
);
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
2
|
-
/* eslint-env node */
|
|
3
|
-
|
|
4
|
-
const postcssCustomProperties = require("postcss-custom-properties");
|
|
5
|
-
const postcssImport = require("postcss-import");
|
|
6
|
-
const postcssCopy = require("postcss-copy");
|
|
7
|
-
const removeRule = require("./postcss-filter-rules");
|
|
8
|
-
|
|
9
|
-
let maintainPath;
|
|
10
|
-
let hasJobberFonts = false;
|
|
11
|
-
try {
|
|
12
|
-
({ maintainPath } = require("@jobber/fonts"));
|
|
13
|
-
hasJobberFonts = true;
|
|
14
|
-
} catch (e) {
|
|
15
|
-
hasJobberFonts = false;
|
|
16
|
-
}
|
|
17
|
-
function removeFontImport(rule) {
|
|
18
|
-
if (rule.params?.includes("@jobber/fonts")) {
|
|
19
|
-
if (!hasJobberFonts) {
|
|
20
|
-
console.warn("remove rule in foundation config", { hasJobberFonts });
|
|
21
|
-
rule.remove();
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
const postcssCopyInstance = postcssCopy({
|
|
26
|
-
dest: "./dist",
|
|
27
|
-
basePath: ["./src", "./node_modules"],
|
|
28
|
-
preservePath: true,
|
|
29
|
-
template(fileMeta) {
|
|
30
|
-
return fileMeta.filename;
|
|
31
|
-
},
|
|
32
|
-
});
|
|
33
|
-
const postcssImportInstance = postcssImport({
|
|
34
|
-
basedir: ["./src", "./node_modules"],
|
|
35
|
-
filter: path => {
|
|
36
|
-
if (path.includes("@jobber/fonts")) {
|
|
37
|
-
console.warn("include fonts, import, foundation config", {
|
|
38
|
-
hasJobberFonts,
|
|
39
|
-
});
|
|
40
|
-
return hasJobberFonts;
|
|
41
|
-
} else {
|
|
42
|
-
return true;
|
|
43
|
-
}
|
|
44
|
-
},
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
module.exports = {
|
|
48
|
-
plugins: [
|
|
49
|
-
removeRule({ ruleFilters: [removeFontImport] }),
|
|
50
|
-
postcssImportInstance,
|
|
51
|
-
hasJobberFonts && postcssCopyInstance,
|
|
52
|
-
hasJobberFonts &&
|
|
53
|
-
maintainPath({ pathToFind: "dist/fonts", pathToSet: "./dist/fonts" }),
|
|
54
|
-
postcssCustomProperties({
|
|
55
|
-
exportTo: ["src/foundation.js"],
|
|
56
|
-
}),
|
|
57
|
-
],
|
|
58
|
-
};
|
package/jobberStyle.js
DELETED
|
@@ -1,243 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
2
|
-
const fs = require("fs");
|
|
3
|
-
// eslint-disable-next-line import/no-internal-modules
|
|
4
|
-
const customPropertiesObject = require("./src/foundation.js");
|
|
5
|
-
|
|
6
|
-
const regexExpressions = {
|
|
7
|
-
cssVars: /var\((.*)\)/,
|
|
8
|
-
calculations: /calc\((.*)\)/,
|
|
9
|
-
rgbVars: /rgb\(var\((.*)\)\)/,
|
|
10
|
-
rgbaVars: /rgba\(var\((.*)\),?(.*)\)/,
|
|
11
|
-
removeAllNonNumerals: /[^0-9.+\-/*]/gi,
|
|
12
|
-
extractAllVarGroups: /var\(.*?\)/g,
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
const customProperties = customPropertiesObject.customProperties;
|
|
16
|
-
|
|
17
|
-
const resolvedCssVars = getResolvedCSSVars(customProperties);
|
|
18
|
-
|
|
19
|
-
const jsonContent =
|
|
20
|
-
"export const JobberStyle = " + JSON.stringify(resolvedCssVars, undefined, 2);
|
|
21
|
-
|
|
22
|
-
fs.writeFile("./foundation.js", jsonContent, "utf8", function (err) {
|
|
23
|
-
if (err) {
|
|
24
|
-
console.log("An error occured while writing JSON object to File.");
|
|
25
|
-
return console.log(err);
|
|
26
|
-
}
|
|
27
|
-
console.log("JSON file has been saved.");
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
const scssColors = getResolvedSCSSVariables(resolvedCssVars);
|
|
31
|
-
|
|
32
|
-
fs.writeFile(
|
|
33
|
-
"./foundation.scss",
|
|
34
|
-
scssColors.join("\n"),
|
|
35
|
-
"utf-8",
|
|
36
|
-
function (err) {
|
|
37
|
-
if (err) {
|
|
38
|
-
console.log("An error occured while writing SCSS to File.");
|
|
39
|
-
return console.log(err);
|
|
40
|
-
}
|
|
41
|
-
console.log("SCSS file has been saved.");
|
|
42
|
-
},
|
|
43
|
-
);
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* Recursively resolve css custom properties.
|
|
47
|
-
*
|
|
48
|
-
* eg:
|
|
49
|
-
* ```
|
|
50
|
-
* jobberStyle(`
|
|
51
|
-
* "--base": "5px",
|
|
52
|
-
* "--foo": "calc(var(--base) * 2),
|
|
53
|
-
* `);
|
|
54
|
-
* ```
|
|
55
|
-
* =>
|
|
56
|
-
* ```
|
|
57
|
-
* {
|
|
58
|
-
* "--base": "5",
|
|
59
|
-
* "--foo": "10",
|
|
60
|
-
* }
|
|
61
|
-
* ```
|
|
62
|
-
*/
|
|
63
|
-
|
|
64
|
-
function jobberStyle(styling) {
|
|
65
|
-
const styleValue = customProperties[styling];
|
|
66
|
-
|
|
67
|
-
//varRegexResult returns --base-unit from var(--base-unit)
|
|
68
|
-
const varRegexResult = regexExpressions.cssVars.exec(styleValue);
|
|
69
|
-
//rgbVarRegexResult returns --base-unit from rgb(var(--base-unit))
|
|
70
|
-
const rgbVarRegexResult = regexExpressions.rgbVars.exec(styleValue);
|
|
71
|
-
//rgbaVarRegexResult returns --base-unit and alpha (if exists) from rgba(var(--base-unit), alpha)
|
|
72
|
-
const rgbaVarRegexResult = regexExpressions.rgbaVars.exec(styleValue);
|
|
73
|
-
|
|
74
|
-
//calcRegexResult returns var(--base-unit) / 16 from calc(var(--base-unit) / 16)
|
|
75
|
-
const calcRegexResult = regexExpressions.calculations.exec(styleValue);
|
|
76
|
-
if (calcRegexResult) {
|
|
77
|
-
return handleCalc(calcRegexResult);
|
|
78
|
-
} else if (rgbVarRegexResult) {
|
|
79
|
-
return jobberStyle(rgbVarRegexResult[1]);
|
|
80
|
-
} else if (rgbaVarRegexResult) {
|
|
81
|
-
return handleRbga(rgbaVarRegexResult);
|
|
82
|
-
} else if (varRegexResult) {
|
|
83
|
-
return jobberStyle(varRegexResult[1]);
|
|
84
|
-
} else {
|
|
85
|
-
return isSpacingValue(styleValue) ? parseFloat(styleValue) : styleValue;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
function handleCalc(calcRegexResult) {
|
|
90
|
-
const finalExpression = handleExpressionsInCalc(calcRegexResult);
|
|
91
|
-
// eslint-disable-next-line no-new-func
|
|
92
|
-
const calculatedValue = new Function(
|
|
93
|
-
"return " +
|
|
94
|
-
finalExpression.replace(regexExpressions.removeAllNonNumerals, ""),
|
|
95
|
-
)();
|
|
96
|
-
return isSpacingValue(calculatedValue)
|
|
97
|
-
? parseFloat(calculatedValue)
|
|
98
|
-
: calculatedValue;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
function handleRbga(rgbaVarRegexResult) {
|
|
102
|
-
let resolved = "rgba(" + jobberStyle(rgbaVarRegexResult[1]);
|
|
103
|
-
if (rgbaVarRegexResult[2]) {
|
|
104
|
-
resolved += "," + rgbaVarRegexResult[2];
|
|
105
|
-
}
|
|
106
|
-
resolved += ")";
|
|
107
|
-
|
|
108
|
-
return resolved;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
function handleExpressionsInCalc(calcRegexResult) {
|
|
112
|
-
const calcExtract = calcRegexResult[1];
|
|
113
|
-
const varGroups = calcExtract.match(regexExpressions.extractAllVarGroups);
|
|
114
|
-
let finalExpression = calcExtract;
|
|
115
|
-
varGroups &&
|
|
116
|
-
varGroups.forEach(group => {
|
|
117
|
-
const cssVariableRegexResult = regexExpressions.cssVars.exec(group);
|
|
118
|
-
if (cssVariableRegexResult) {
|
|
119
|
-
finalExpression = resolveCssVarsInExpression({
|
|
120
|
-
group,
|
|
121
|
-
cssVariableRegexResult,
|
|
122
|
-
finalExpression,
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
});
|
|
126
|
-
return finalExpression;
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
function resolveCssVarsInExpression({
|
|
130
|
-
group,
|
|
131
|
-
cssVariableRegexResult,
|
|
132
|
-
finalExpression,
|
|
133
|
-
}) {
|
|
134
|
-
const cssVariable = cssVariableRegexResult[1];
|
|
135
|
-
const realValue = jobberStyle(cssVariable);
|
|
136
|
-
const unresolvedCssVariable = group;
|
|
137
|
-
return finalExpression.replace(unresolvedCssVariable, realValue);
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
function isSpacingValue(value) {
|
|
141
|
-
return !!String(value).match(
|
|
142
|
-
/(^\d+(px|%|rem|em|ex|ch|vw|vh|vmin|vmax)$)|(^\d+$)/,
|
|
143
|
-
);
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
function getResolvedCSSVars(cssProperties) {
|
|
147
|
-
const allKeys = Object.keys(cssProperties);
|
|
148
|
-
return allKeys.reduce((acc, key) => {
|
|
149
|
-
const newKey = key.replace("--", "");
|
|
150
|
-
acc[newKey] = jobberStyle(key);
|
|
151
|
-
return acc;
|
|
152
|
-
}, {});
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
function getResolvedSCSSVariables(cssProperties) {
|
|
156
|
-
const allKeys = Object.keys(cssProperties);
|
|
157
|
-
|
|
158
|
-
return allKeys.reduce((acc, cssVar) => {
|
|
159
|
-
const propertyValue = getPropertyValue(cssVar);
|
|
160
|
-
|
|
161
|
-
if (propertyValue) {
|
|
162
|
-
return [...acc, `$${cssVar}: ${propertyValue};`];
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
return acc;
|
|
166
|
-
}, []);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
function resolveShadow(shadowValue) {
|
|
170
|
-
const splitValue = shadowValue.split(" ").filter(n => n);
|
|
171
|
-
|
|
172
|
-
return splitValue
|
|
173
|
-
.map(value => {
|
|
174
|
-
const varRegexResult = regexExpressions.cssVars.exec(value);
|
|
175
|
-
|
|
176
|
-
if (varRegexResult) {
|
|
177
|
-
const result = jobberStyle(varRegexResult[1]);
|
|
178
|
-
const suffix = typeof result === "string" ? "" : "px";
|
|
179
|
-
|
|
180
|
-
return `${result}${suffix}`;
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
return value;
|
|
184
|
-
})
|
|
185
|
-
.join(" ");
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
function getVariableType(cssVar) {
|
|
189
|
-
const includesInArray = v => cssVar.includes(v);
|
|
190
|
-
|
|
191
|
-
const isSizeVariables = ["border", "radius"].some(includesInArray);
|
|
192
|
-
const isSimpleVariables = [
|
|
193
|
-
"color",
|
|
194
|
-
"timing",
|
|
195
|
-
"elevation",
|
|
196
|
-
"lineHeight",
|
|
197
|
-
"fontFamily",
|
|
198
|
-
"letterSpacing-base",
|
|
199
|
-
].some(includesInArray);
|
|
200
|
-
const isCalcVariables = ["space", "letterSpacing-loose", "fontSize"].some(
|
|
201
|
-
includesInArray,
|
|
202
|
-
);
|
|
203
|
-
const isShadowVariable = cssVar.includes("shadow");
|
|
204
|
-
|
|
205
|
-
if (isSimpleVariables) return "simple";
|
|
206
|
-
if (isSizeVariables) return "size";
|
|
207
|
-
if (isCalcVariables) return "calc";
|
|
208
|
-
if (isShadowVariable) return "shadow";
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
function getPropertyValue(cssVar) {
|
|
212
|
-
const customPropertyValue = customProperties["--" + cssVar];
|
|
213
|
-
const variableType = getVariableType(cssVar);
|
|
214
|
-
|
|
215
|
-
switch (variableType) {
|
|
216
|
-
case "simple":
|
|
217
|
-
return `${resolvedCssVars[cssVar]}`;
|
|
218
|
-
case "calc": {
|
|
219
|
-
const calcRegexResult = regexExpressions.calculations.exec(
|
|
220
|
-
removeNewLines(customPropertyValue),
|
|
221
|
-
);
|
|
222
|
-
|
|
223
|
-
return `${handleCalc(calcRegexResult)}px`;
|
|
224
|
-
}
|
|
225
|
-
case "size": {
|
|
226
|
-
const suffix = customPropertyValue.includes("%") ? "%" : "px";
|
|
227
|
-
return `${resolvedCssVars[cssVar]}${suffix}`;
|
|
228
|
-
}
|
|
229
|
-
case "shadow":
|
|
230
|
-
return `${resolveShadow(customPropertyValue)}`;
|
|
231
|
-
default:
|
|
232
|
-
return "";
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
/**
|
|
237
|
-
*
|
|
238
|
-
* Removes all types of line breaks from the text
|
|
239
|
-
* Reference: https://stackoverflow.com/a/10805198
|
|
240
|
-
*/
|
|
241
|
-
function removeNewLines(text) {
|
|
242
|
-
return text.replace(/(\r\n|\n|\r)/gm, "");
|
|
243
|
-
}
|