@symbo.ls/atoms 2.11.206 → 2.11.212

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/Collection.js CHANGED
@@ -1,7 +1,7 @@
1
1
  'use strict'
2
2
 
3
3
  import { isState, getChildStateInKey } from '@domql/state'
4
- import { isString, isNot, isArray, isObject, isObjectLike, diff, deepClone } from '@domql/utils'
4
+ import { isString, isNot, isArray, isObject, isObjectLike, diff, deepClone, deepContains } from '@domql/utils'
5
5
 
6
6
  export const Collection = {
7
7
  define: {
@@ -46,15 +46,22 @@ export const Collection = {
46
46
  }
47
47
  }
48
48
 
49
- const obj = { tag: 'fragment' }
49
+ const obj = {
50
+ tag: 'fragment',
51
+ props: {
52
+ childProps: el.props.childProps
53
+ }
54
+ }
50
55
 
51
56
  for (const key in param) {
52
57
  const value = param[key]
53
58
  obj[key] = { state: isObjectLike(value) ? value : { value } }
54
59
  }
55
60
 
56
- el.removeContent()
57
- el.content = obj
61
+ if (!deepContains(obj, el.content)) {
62
+ el.removeContent()
63
+ el.content = obj
64
+ }
58
65
 
59
66
  return obj
60
67
  },
@@ -69,14 +76,22 @@ export const Collection = {
69
76
  if (isState(param)) param = param.parse()
70
77
  if (isNot(param)('array', 'object')) return
71
78
 
72
- const obj = { tag: 'fragment' }
79
+ const obj = {
80
+ tag: 'fragment',
81
+ props: {
82
+ childProps: el.props.childProps
83
+ }
84
+ }
85
+
73
86
  for (const key in param) {
74
87
  const value = param[key]
75
88
  obj[key] = { props: isObjectLike(value) ? value : { value } }
76
89
  }
77
90
 
78
- el.removeContent()
79
- el.content = obj
91
+ if (!deepContains(obj, el.content)) {
92
+ el.removeContent()
93
+ el.content = obj
94
+ }
80
95
 
81
96
  // const set = () => {
82
97
  // el.set(obj, { preventDefineUpdate: '$setPropsCollection' })
package/Img.js CHANGED
@@ -3,12 +3,6 @@
3
3
  export const Img = {
4
4
  tag: 'img',
5
5
 
6
- props: {
7
- src: '',
8
- alt: '',
9
- title: ''
10
- },
11
-
12
6
  attr: {
13
7
  src: ({ props }) => props.src,
14
8
  alt: ({ props }) => props.alt,
package/Media.js CHANGED
@@ -22,6 +22,9 @@ export const keySetters = {
22
22
  $: (key, props, result, element, isSubtree) => applyCaseProps(
23
23
  key, props, isSubtree ? result : (result && result.case), element
24
24
  ),
25
+ '-': (key, props, result, element, isSubtree) => applyVariableProps(
26
+ key, props, isSubtree ? result : (result && result.variable), element
27
+ ),
25
28
  '.': (key, props, result, element, isSubtree) => applyConditionalCaseProps(
26
29
  key, props, isSubtree ? result : (result && result.case), element
27
30
  ),
@@ -110,6 +113,11 @@ const applyCaseProps = (key, props, result, element) => {
110
113
  return merge(result, convertPropsToClass(props, result, element))
111
114
  }
112
115
 
116
+ const applyVariableProps = (key, props, result, element) => {
117
+ result[key] = props
118
+ return result
119
+ }
120
+
113
121
  const applyConditionalCaseProps = (key, props, result, element) => {
114
122
  const caseKey = key.slice(1)
115
123
  const isPropTrue = element.props[caseKey] || element.state[caseKey]
@@ -131,7 +139,8 @@ const beforeClassAssign = (element, s) => {
131
139
  const CLASS_NAMES = {
132
140
  media: {},
133
141
  selector: {},
134
- case: {}
142
+ case: {},
143
+ variable: {}
135
144
  }
136
145
 
137
146
  if (!context) return
package/Theme.js CHANGED
@@ -10,6 +10,7 @@ import {
10
10
  } from '@symbo.ls/scratch'
11
11
 
12
12
  import { depth } from './Shape/style'
13
+ import { isUndefined } from '@domql/utils'
13
14
 
14
15
  export const getSystemTheme = ({ context, state }) => {
15
16
  const rootState = state && state.__root
@@ -29,7 +30,7 @@ export const Theme = {
29
30
  },
30
31
 
31
32
  class: {
32
- depth: ({ props, deps }) => props.depth && deps.depth[props.depth],
33
+ depth: ({ props, deps }) => !isUndefined(props.depth) && deps.depth[props.depth],
33
34
 
34
35
  theme: (element) => {
35
36
  const { props, deps } = element
@@ -74,70 +75,70 @@ export const Theme = {
74
75
  backgroundImage: deps.transformBackgroundImage(props.backgroundImage, globalTheme)
75
76
  })
76
77
  },
77
- backgroundSize: ({ props }) => props.backgroundSize
78
+ backgroundSize: ({ props }) => !isUndefined(props.backgroundSize)
78
79
  ? ({
79
80
  backgroundSize: props.backgroundSize
80
81
  })
81
82
  : null,
82
- backgroundPosition: ({ props }) => props.backgroundPosition
83
+ backgroundPosition: ({ props }) => !isUndefined(props.backgroundPosition)
83
84
  ? ({
84
85
  backgroundPosition: props.backgroundPosition
85
86
  })
86
87
  : null,
87
88
 
88
- textStroke: ({ props, deps }) => props.textStroke
89
+ textStroke: ({ props, deps }) => !isUndefined(props.textStroke)
89
90
  ? ({
90
91
  WebkitTextStroke: deps.transformTextStroke(props.textStroke)
91
92
  })
92
93
  : null,
93
94
 
94
- outline: ({ props, deps }) => props.outline && ({
95
+ outline: ({ props, deps }) => !isUndefined(props.outline) && ({
95
96
  outline: deps.transformBorder(props.outline)
96
97
  }),
97
98
 
98
- border: ({ props, deps }) => props.border && ({
99
+ border: ({ props, deps }) => !isUndefined(props.border) && ({
99
100
  border: deps.transformBorder(props.border)
100
101
  }),
101
- borderColor: ({ props, deps }) => props.borderColor && ({
102
+ borderColor: ({ props, deps }) => !isUndefined(props.borderColor) && ({
102
103
  borderColor: deps.getMediaColor(props.borderColor)
103
104
  }),
104
- borderStyle: ({ props }) => props.borderStyle && ({
105
+ borderStyle: ({ props }) => !isUndefined(props.borderStyle) && ({
105
106
  borderStyle: props.borderStyle
106
107
  }),
107
108
 
108
- borderLeft: ({ props, deps }) => props.borderLeft && ({
109
+ borderLeft: ({ props, deps }) => !isUndefined(props.borderLeft) && ({
109
110
  borderLeft: deps.transformBorder(props.borderLeft)
110
111
  }),
111
- borderTop: ({ props, deps }) => props.borderTop && ({
112
+ borderTop: ({ props, deps }) => !isUndefined(props.borderTop) && ({
112
113
  borderTop: deps.transformBorder(props.borderTop)
113
114
  }),
114
- borderRight: ({ props, deps }) => props.borderRight && ({
115
+ borderRight: ({ props, deps }) => !isUndefined(props.borderRight) && ({
115
116
  borderRight: deps.transformBorder(props.borderRight)
116
117
  }),
117
- borderBottom: ({ props, deps }) => props.borderBottom && ({
118
+ borderBottom: ({ props, deps }) => !isUndefined(props.borderBottom) && ({
118
119
  borderBottom: deps.transformBorder(props.borderBottom)
119
120
  }),
120
121
 
121
- boxShadow: ({ props, deps }) => props.boxShadow && ({
122
+ boxShadow: ({ props, deps }) => !isUndefined(props.boxShadow) && ({
122
123
  boxShadow: deps.transformShadow(props.boxShadow)
123
124
  }),
124
125
 
125
- textShadow: ({ props, deps }) => props.textShadow && ({
126
+ textShadow: ({ props, deps }) => !isUndefined(props.textShadow) && ({
126
127
  textShadow: deps.transformShadow(props.textShadow)
127
128
  }),
128
129
 
129
- opacity: ({ props }) => props.opacity && ({
130
+ opacity: ({ props }) => !isUndefined(props.opacity) && ({
130
131
  opacity: props.opacity
131
132
  }),
132
- visibility: ({ props }) => props.visibility && ({
133
+ visibility: ({ props }) => !isUndefined(props.visibility) && ({
133
134
  visibility: props.visibility
134
135
  }),
135
136
 
136
- columnRule: ({ props, deps }) => props.columnRule && ({
137
+ columnRule: ({ props, deps }) => !isUndefined(props.columnRule) && ({
137
138
  columnRule: deps.transformBorder(props.columnRule)
138
139
  }),
139
140
 
140
- appearance: ({ props }) => props.appearance && ({
141
+ appearance: ({ props }) => !isUndefined(props.appearance) && ({
141
142
  appearance: props.appearance
142
143
  })
143
144
  }
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@symbo.ls/atoms",
3
- "version": "2.11.206",
3
+ "version": "2.11.212",
4
4
  "main": "index.js",
5
5
  "license": "MIT",
6
- "gitHead": "ab27f765b859e8922934fee257f5d1921fbf4f5d",
6
+ "gitHead": "12914eac8527ac1df36183098bbf3dfcfaa2e027",
7
7
  "dependencies": {
8
8
  "@domql/state": "latest",
9
9
  "@domql/utils": "latest",