@symbo.ls/scratch 0.7.8 → 0.7.10

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/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@symbo.ls/scratch",
3
3
  "description": "Φ / CSS framework and methodology.",
4
4
  "author": "symbo.ls",
5
- "version": "0.7.8",
5
+ "version": "0.7.10",
6
6
  "files": [
7
7
  "src"
8
8
  ],
@@ -11,6 +11,8 @@
11
11
  "main": "src/index.js",
12
12
  "publishConfig": {},
13
13
  "dependencies": {
14
+ "@domql/utils": "latest",
15
+ "@symbo.ls/utils": "latest",
14
16
  "color-contrast-checker": "^1.5.0"
15
17
  },
16
18
  "scripts": {
@@ -20,18 +22,18 @@
20
22
  "bump": "npx np"
21
23
  },
22
24
  "devDependencies": {
25
+ "@babel/core": "^7.11.5",
23
26
  "@babel/preset-env": "^7.18.9",
27
+ "@emotion/css": "^11.5.0",
28
+ "babel-eslint": "^10.0.3",
24
29
  "babel-jest": "^27.0.2",
25
30
  "babel-preset-env": "^1.7.0",
26
31
  "coveralls": "^3.0.5",
32
+ "eslint": "^6.1.0",
27
33
  "eslint-plugin-jest": "^24.1.0",
28
34
  "jest": "^27.0.6",
29
35
  "nodemon": "^2.0.6",
30
36
  "np": "^7.2.0",
31
- "@babel/core": "^7.11.5",
32
- "@emotion/css": "^11.5.0",
33
- "babel-eslint": "^10.0.3",
34
- "eslint": "^6.1.0",
35
37
  "parcel-bundler": "^1.12.3",
36
38
  "parcel-plugin-svg-sprite": "^1.4.1",
37
39
  "standard": "^13.1.0"
package/src/set.js CHANGED
@@ -16,7 +16,7 @@ import {
16
16
 
17
17
  import { isFunction } from './utils'
18
18
 
19
- const ENV = process.env.NODE_ENV
19
+ const ENV = process.env.NODE_ENV // eslint-disable-line no-unused-vars
20
20
 
21
21
  const setCases = (val, key) => {
22
22
  if (isFunction(val)) return val()
@@ -35,11 +35,11 @@ export const applyReset = (reset = {}) => {
35
35
 
36
36
  ...getTheme('document'),
37
37
 
38
- fontSize: CONFIG.TYPOGRAPHY.base / CONFIG.TYPOGRAPHY.browserDefault + CONFIG.UNIT.default,
39
-
40
- ...CONFIG.TYPOGRAPHY.styles
38
+ fontSize: CONFIG.TYPOGRAPHY.base / CONFIG.TYPOGRAPHY.browserDefault + CONFIG.UNIT.default
41
39
  },
42
40
 
41
+ ...CONFIG.TYPOGRAPHY.styles,
42
+
43
43
  // form elements
44
44
  fieldset: {
45
45
  border: 0,
@@ -49,8 +49,13 @@ export const applyHeadings = (props) => {
49
49
  const HEADINGS = findHeadings(props)
50
50
  const { styles } = props
51
51
  for (const k in HEADINGS) {
52
- styles[`h${parseInt(k) + 1}`] = {
53
- fontSize: CONFIG.useVariable ? `var(${HEADINGS[k].variable})` : `${HEADINGS[k].scaling}${unit}`
52
+ const headerName = `h${parseInt(k) + 1}`
53
+ const headerStyle = styles[headerName]
54
+ styles[headerName] = {
55
+ fontSize: CONFIG.useVariable ? `var(${HEADINGS[k].variable})` : `${HEADINGS[k].scaling}${unit}`,
56
+ margin: headerStyle?.margin || 0,
57
+ lineHeight: headerStyle?.lineHeight || props.lineHeight,
58
+ fontWeight: headerStyle?.fontWeight || 900 - (k * 100)
54
59
  }
55
60
  }
56
61
  }
@@ -1,5 +1,6 @@
1
1
  'use strict'
2
2
 
3
+ import { toDashCase } from '@symbo.ls/utils'
3
4
  import { UNIT } from '../defaultConfig'
4
5
  import { CONFIG } from '../factory'
5
6
  import { isString } from './object'
@@ -47,10 +48,6 @@ const setSequenceValue = (props, sequenceProps) => {
47
48
  sequenceProps.vars[variable] = scaling + sequenceProps.unit
48
49
  }
49
50
 
50
- const dashize = val => val
51
- .replace(/[A-Z]/g, (match, offset) => (offset > 0 ? '-' : '') + match.toLowerCase())
52
- .replace('.', '-')
53
-
54
51
  export const generateSubSequence = (props, sequenceProps) => {
55
52
  const { key, base, value, ratio, variable, index } = props
56
53
 
@@ -125,7 +122,7 @@ export const getSequenceValue = (value = 'A', sequenceProps) => {
125
122
  return `var(${value})`
126
123
  }
127
124
 
128
- const prefix = `--${dashize(sequenceProps.type.replace('.', '-'))}-`
125
+ const prefix = `--${toDashCase(sequenceProps.type.replace('.', '-'))}-`
129
126
 
130
127
  const startsWithDashOrLetterRegex = /^-?[a-zA-Z]/i
131
128
  const startsWithDashOrLetter = startsWithDashOrLetterRegex.test(value)
@@ -149,6 +146,14 @@ export const getSequenceValue = (value = 'A', sequenceProps) => {
149
146
  absValue = absValue.split('-')[0]
150
147
  }
151
148
 
149
+ if (absValue.includes('+')) {
150
+ const args = absValue.split('+')
151
+ const varValue = v => `var(${prefix}${v}${mediaName})`
152
+ const [first, second] = args
153
+ const joint = `${varValue(first)} + ${varValue(second)}`
154
+ return isNegative ? `calc((${joint}) * -1)` : `calc(${joint})`
155
+ }
156
+
152
157
  // if subsequence is not set but value is applied
153
158
  if (!sequence[absValue] && absValue.length === 2) {
154
159
  if (CONFIG.verbose) console.warn(absValue, '- value is not found because `subSequence` is set to false')