@sanity/color-input 2.30.2-shopify.0 → 3.0.0-studio-v3.1
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/README.md +61 -6
- package/lib/cjs/index.js +606 -0
- package/lib/cjs/index.js.map +1 -0
- package/lib/esm/index.js +594 -0
- package/lib/esm/index.js.map +1 -0
- package/lib/types/index.d.ts +84 -0
- package/lib/types/index.d.ts.map +1 -0
- package/package.json +65 -20
- package/sanity.json +2 -26
- package/src/ColorInput.tsx +110 -0
- package/src/ColorPicker.tsx +139 -0
- package/src/ColorPickerFields.tsx +144 -0
- package/src/index.ts +16 -0
- package/src/schemas/color.tsx +79 -0
- package/src/schemas/hslaColor.ts +11 -0
- package/src/schemas/hsvaColor.ts +11 -0
- package/src/schemas/rgbaColor.ts +11 -0
- package/v2-incompatible.js +11 -0
- package/lib/ColorInput.js +0 -144
- package/lib/ColorPicker.js +0 -159
- package/lib/ColorPickerFields.js +0 -138
- package/lib/schemas/color.js +0 -81
- package/lib/schemas/hslaColor.js +0 -29
- package/lib/schemas/hsvaColor.js +0 -29
- package/lib/schemas/rgbaColor.js +0 -29
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import React from 'react'
|
|
2
|
+
import {ColorInput} from '../ColorInput'
|
|
3
|
+
|
|
4
|
+
const round = (val: number = 1) => Math.round(val * 100)
|
|
5
|
+
|
|
6
|
+
export const color = {
|
|
7
|
+
name: 'color',
|
|
8
|
+
type: 'object',
|
|
9
|
+
title: 'Color',
|
|
10
|
+
components: {input: ColorInput},
|
|
11
|
+
fields: [
|
|
12
|
+
{
|
|
13
|
+
title: 'Hex',
|
|
14
|
+
name: 'hex',
|
|
15
|
+
type: 'string',
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
title: 'Alpha',
|
|
19
|
+
name: 'alpha',
|
|
20
|
+
type: 'number',
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
title: 'Hue Saturation Lightness',
|
|
24
|
+
name: 'hsl',
|
|
25
|
+
type: 'hslaColor',
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
title: 'Hue Saturation Value',
|
|
29
|
+
name: 'hsv',
|
|
30
|
+
type: 'hsvaColor',
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
title: 'Red Green Blue (rgb)',
|
|
34
|
+
name: 'rgb',
|
|
35
|
+
type: 'rgbaColor',
|
|
36
|
+
},
|
|
37
|
+
],
|
|
38
|
+
preview: {
|
|
39
|
+
select: {
|
|
40
|
+
title: 'hex',
|
|
41
|
+
alpha: 'alpha',
|
|
42
|
+
hex: 'hex',
|
|
43
|
+
hsl: 'hsl',
|
|
44
|
+
},
|
|
45
|
+
prepare({
|
|
46
|
+
title,
|
|
47
|
+
hex,
|
|
48
|
+
hsl,
|
|
49
|
+
alpha,
|
|
50
|
+
}: {
|
|
51
|
+
title?: string
|
|
52
|
+
alpha?: number
|
|
53
|
+
hex?: string
|
|
54
|
+
hsl?: {h: number; s: number; l: number}
|
|
55
|
+
}) {
|
|
56
|
+
let subtitle = hex || 'No color set'
|
|
57
|
+
if (hsl) {
|
|
58
|
+
subtitle = `H:${round(hsl.h)} S:${round(hsl.s)} L:${round(hsl.l)} A:${round(alpha)}`
|
|
59
|
+
}
|
|
60
|
+
return {
|
|
61
|
+
title: title,
|
|
62
|
+
subtitle: subtitle,
|
|
63
|
+
media: () => (
|
|
64
|
+
<div
|
|
65
|
+
style={{
|
|
66
|
+
backgroundColor: hex ?? '#000',
|
|
67
|
+
opacity: alpha ?? 1,
|
|
68
|
+
position: 'absolute',
|
|
69
|
+
height: '100%',
|
|
70
|
+
width: '100%',
|
|
71
|
+
top: '0',
|
|
72
|
+
left: '0',
|
|
73
|
+
}}
|
|
74
|
+
/>
|
|
75
|
+
),
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
},
|
|
79
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const hslaColor = {
|
|
2
|
+
title: 'Hue Saturation Lightness',
|
|
3
|
+
name: 'hslaColor',
|
|
4
|
+
type: 'object',
|
|
5
|
+
fields: [
|
|
6
|
+
{name: 'h', type: 'number', title: 'Hue'},
|
|
7
|
+
{name: 's', type: 'number', title: 'Saturation'},
|
|
8
|
+
{name: 'l', type: 'number', title: 'Lightness'},
|
|
9
|
+
{name: 'a', type: 'number', title: 'Alpha'},
|
|
10
|
+
],
|
|
11
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const hsvaColor = {
|
|
2
|
+
title: 'Hue Saturation Value',
|
|
3
|
+
name: 'hsvaColor',
|
|
4
|
+
type: 'object',
|
|
5
|
+
fields: [
|
|
6
|
+
{name: 'h', type: 'number', title: 'Hue'},
|
|
7
|
+
{name: 's', type: 'number', title: 'Saturation'},
|
|
8
|
+
{name: 'v', type: 'number', title: 'Value'},
|
|
9
|
+
{name: 'a', type: 'number', title: 'Alpha'},
|
|
10
|
+
],
|
|
11
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const rgbaColor = {
|
|
2
|
+
title: 'Red Green Blue (rgb)',
|
|
3
|
+
name: 'rgbaColor',
|
|
4
|
+
type: 'object',
|
|
5
|
+
fields: [
|
|
6
|
+
{name: 'r', type: 'number', title: 'Red'},
|
|
7
|
+
{name: 'g', type: 'number', title: 'Green'},
|
|
8
|
+
{name: 'b', type: 'number', title: 'Blue'},
|
|
9
|
+
{name: 'a', type: 'number', title: 'Alpha'},
|
|
10
|
+
],
|
|
11
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
const {showIncompatiblePluginDialog} = require('@sanity/incompatible-plugin')
|
|
2
|
+
const {name, version, sanityExchangeUrl} = require('./package.json')
|
|
3
|
+
|
|
4
|
+
export default showIncompatiblePluginDialog({
|
|
5
|
+
name: name,
|
|
6
|
+
versions: {
|
|
7
|
+
v3: version,
|
|
8
|
+
v2: '^2.30.0',
|
|
9
|
+
},
|
|
10
|
+
sanityExchangeUrl,
|
|
11
|
+
})
|
package/lib/ColorInput.js
DELETED
|
@@ -1,144 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
|
|
8
|
-
var _debounce2 = _interopRequireDefault(require("lodash/debounce"));
|
|
9
|
-
|
|
10
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
-
|
|
12
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
13
|
-
|
|
14
|
-
var _formBuilder = require("part:@sanity/form-builder");
|
|
15
|
-
|
|
16
|
-
var _ui = require("@sanity/ui");
|
|
17
|
-
|
|
18
|
-
var _icons = require("@sanity/icons");
|
|
19
|
-
|
|
20
|
-
var _components = require("@sanity/base/components");
|
|
21
|
-
|
|
22
|
-
var _ColorPicker = _interopRequireDefault(require("./ColorPicker"));
|
|
23
|
-
|
|
24
|
-
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
25
|
-
|
|
26
|
-
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
27
|
-
|
|
28
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
29
|
-
|
|
30
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
31
|
-
|
|
32
|
-
var set = _formBuilder.patches.set,
|
|
33
|
-
unset = _formBuilder.patches.unset,
|
|
34
|
-
setIfMissing = _formBuilder.patches.setIfMissing;
|
|
35
|
-
var DEFAULT_COLOR = {
|
|
36
|
-
hex: '#24a3e3',
|
|
37
|
-
hsl: {
|
|
38
|
-
h: 200,
|
|
39
|
-
s: 0.7732,
|
|
40
|
-
l: 0.5156,
|
|
41
|
-
a: 1
|
|
42
|
-
},
|
|
43
|
-
hsv: {
|
|
44
|
-
h: 200,
|
|
45
|
-
s: 0.8414,
|
|
46
|
-
v: 0.8901,
|
|
47
|
-
a: 1
|
|
48
|
-
},
|
|
49
|
-
rgb: {
|
|
50
|
-
r: 46,
|
|
51
|
-
g: 163,
|
|
52
|
-
b: 227,
|
|
53
|
-
a: 1
|
|
54
|
-
},
|
|
55
|
-
source: 'hex'
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
class ColorInput extends _react.PureComponent {
|
|
59
|
-
constructor() {
|
|
60
|
-
super(...arguments);
|
|
61
|
-
|
|
62
|
-
_defineProperty(this, "focusRef", /*#__PURE__*/_react.default.createRef());
|
|
63
|
-
|
|
64
|
-
_defineProperty(this, "emitSetColor", nextColor => {
|
|
65
|
-
var _this$props = this.props,
|
|
66
|
-
onChange = _this$props.onChange,
|
|
67
|
-
type = _this$props.type;
|
|
68
|
-
var fieldPatches = type.fields.filter(field => field.name in nextColor).map(field => {
|
|
69
|
-
var nextFieldValue = nextColor[field.name];
|
|
70
|
-
var isObject = field.type.jsonType === 'object';
|
|
71
|
-
return set(isObject ? Object.assign({
|
|
72
|
-
_type: field.type.name
|
|
73
|
-
}, nextFieldValue) : nextFieldValue, [field.name]);
|
|
74
|
-
});
|
|
75
|
-
onChange(_formBuilder.PatchEvent.from([setIfMissing({
|
|
76
|
-
_type: type.name
|
|
77
|
-
}), set(type.name, ['_type']), set(nextColor.rgb.a, ['alpha']), ...fieldPatches]));
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
_defineProperty(this, "handleColorChange", (0, _debounce2.default)(this.emitSetColor, 100));
|
|
81
|
-
|
|
82
|
-
_defineProperty(this, "handleCreateColor", () => {
|
|
83
|
-
this.emitSetColor(DEFAULT_COLOR);
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
_defineProperty(this, "handleUnset", () => {
|
|
87
|
-
this.props.onChange(_formBuilder.PatchEvent.from(unset()));
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
focus() {
|
|
92
|
-
// todo: make the ColorPicker component support .focus()
|
|
93
|
-
if (this.focusRef.current && this.focusRef.current.focus) {
|
|
94
|
-
this.focusRef.current.focus();
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
render() {
|
|
99
|
-
var _this$props2 = this.props,
|
|
100
|
-
type = _this$props2.type,
|
|
101
|
-
readOnly = _this$props2.readOnly,
|
|
102
|
-
value = _this$props2.value,
|
|
103
|
-
level = _this$props2.level;
|
|
104
|
-
return /*#__PURE__*/_react.default.createElement(_components.FormField, {
|
|
105
|
-
title: type.title,
|
|
106
|
-
description: type.description,
|
|
107
|
-
level: level
|
|
108
|
-
}, value ? /*#__PURE__*/_react.default.createElement(_ColorPicker.default, {
|
|
109
|
-
ref: this.focusRef,
|
|
110
|
-
color: value.hsl || value.hex,
|
|
111
|
-
readOnly: readOnly || type.readOnly,
|
|
112
|
-
onChange: this.handleColorChange,
|
|
113
|
-
disableAlpha: type.options && type.options.disableAlpha,
|
|
114
|
-
onUnset: this.handleUnset
|
|
115
|
-
}) : /*#__PURE__*/_react.default.createElement(_ui.Button, {
|
|
116
|
-
icon: _icons.AddIcon,
|
|
117
|
-
mode: "ghost",
|
|
118
|
-
text: "Create color",
|
|
119
|
-
ref: this.focusRef,
|
|
120
|
-
disabled: Boolean(readOnly),
|
|
121
|
-
onClick: this.handleCreateColor
|
|
122
|
-
}));
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
exports.default = ColorInput;
|
|
128
|
-
|
|
129
|
-
_defineProperty(ColorInput, "propTypes", {
|
|
130
|
-
type: _propTypes.default.shape({
|
|
131
|
-
name: _propTypes.default.string,
|
|
132
|
-
title: _propTypes.default.string,
|
|
133
|
-
description: _propTypes.default.string,
|
|
134
|
-
fields: _propTypes.default.arrayOf(_propTypes.default.shape({
|
|
135
|
-
name: _propTypes.default.string.isRequired
|
|
136
|
-
}))
|
|
137
|
-
}).isRequired,
|
|
138
|
-
onChange: _propTypes.default.func.isRequired,
|
|
139
|
-
readOnly: _propTypes.default.bool,
|
|
140
|
-
value: _propTypes.default.shape({
|
|
141
|
-
hex: _propTypes.default.string,
|
|
142
|
-
alpha: _propTypes.default.number
|
|
143
|
-
})
|
|
144
|
-
});
|
package/lib/ColorPicker.js
DELETED
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
|
|
10
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
11
|
-
|
|
12
|
-
var _common = require("react-color/lib/components/common");
|
|
13
|
-
|
|
14
|
-
var _ui = require("@sanity/ui");
|
|
15
|
-
|
|
16
|
-
var _icons = require("@sanity/icons");
|
|
17
|
-
|
|
18
|
-
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
19
|
-
|
|
20
|
-
var _ColorPickerFields = require("./ColorPickerFields");
|
|
21
|
-
|
|
22
|
-
var _templateObject, _templateObject2;
|
|
23
|
-
|
|
24
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
25
|
-
|
|
26
|
-
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
27
|
-
|
|
28
|
-
var ColorBox = (0, _styledComponents.default)(_ui.Box)(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n"])));
|
|
29
|
-
var ReadOnlyContainer = (0, _styledComponents.default)(_ui.Flex)(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n margin-top: 6rem;\n background-color: var(--card-bg-color);\n position: relative;\n width: 100%;\n"])));
|
|
30
|
-
|
|
31
|
-
var ColorPicker = _ref => {
|
|
32
|
-
var width = _ref.width,
|
|
33
|
-
rgb = _ref.rgb,
|
|
34
|
-
hex = _ref.hex,
|
|
35
|
-
hsv = _ref.hsv,
|
|
36
|
-
hsl = _ref.hsl,
|
|
37
|
-
onChange = _ref.onChange,
|
|
38
|
-
onUnset = _ref.onUnset,
|
|
39
|
-
disableAlpha = _ref.disableAlpha,
|
|
40
|
-
renderers = _ref.renderers,
|
|
41
|
-
readOnly = _ref.readOnly;
|
|
42
|
-
return /*#__PURE__*/_react.default.createElement("div", {
|
|
43
|
-
style: {
|
|
44
|
-
width
|
|
45
|
-
}
|
|
46
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Card, {
|
|
47
|
-
padding: 1,
|
|
48
|
-
border: true,
|
|
49
|
-
radius: 1
|
|
50
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Stack, {
|
|
51
|
-
space: 2
|
|
52
|
-
}, !readOnly && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_ui.Card, {
|
|
53
|
-
overflow: "hidden",
|
|
54
|
-
style: {
|
|
55
|
-
position: 'relative',
|
|
56
|
-
height: '5em'
|
|
57
|
-
}
|
|
58
|
-
}, /*#__PURE__*/_react.default.createElement(_common.Saturation, {
|
|
59
|
-
is: "Saturation",
|
|
60
|
-
onChange: onChange,
|
|
61
|
-
hsl: hsl,
|
|
62
|
-
hsv: hsv
|
|
63
|
-
})), /*#__PURE__*/_react.default.createElement(_ui.Card, {
|
|
64
|
-
shadow: 1,
|
|
65
|
-
radius: 3,
|
|
66
|
-
overflow: "hidden",
|
|
67
|
-
style: {
|
|
68
|
-
position: 'relative',
|
|
69
|
-
height: '10px'
|
|
70
|
-
}
|
|
71
|
-
}, /*#__PURE__*/_react.default.createElement(_common.Hue, {
|
|
72
|
-
is: "Hue",
|
|
73
|
-
hsl: hsl,
|
|
74
|
-
onChange: !readOnly && onChange
|
|
75
|
-
})), !disableAlpha && /*#__PURE__*/_react.default.createElement(_ui.Card, {
|
|
76
|
-
shadow: 1,
|
|
77
|
-
radius: 3,
|
|
78
|
-
overflow: "hidden",
|
|
79
|
-
style: {
|
|
80
|
-
position: 'relative',
|
|
81
|
-
height: '10px'
|
|
82
|
-
}
|
|
83
|
-
}, /*#__PURE__*/_react.default.createElement(_common.Alpha, {
|
|
84
|
-
is: "Alpha",
|
|
85
|
-
rgb: rgb,
|
|
86
|
-
hsl: hsl,
|
|
87
|
-
renderers: renderers,
|
|
88
|
-
onChange: onChange
|
|
89
|
-
}))), /*#__PURE__*/_react.default.createElement(_ui.Flex, null, /*#__PURE__*/_react.default.createElement(_ui.Card, {
|
|
90
|
-
flex: 1,
|
|
91
|
-
radius: 2,
|
|
92
|
-
overflow: "hidden",
|
|
93
|
-
style: {
|
|
94
|
-
position: 'relative',
|
|
95
|
-
minWidth: '4em'
|
|
96
|
-
}
|
|
97
|
-
}, /*#__PURE__*/_react.default.createElement(_common.Checkboard, null), /*#__PURE__*/_react.default.createElement(ColorBox, {
|
|
98
|
-
style: {
|
|
99
|
-
backgroundColor: "rgba(".concat(rgb.r, ",").concat(rgb.g, ",").concat(rgb.b, ",").concat(rgb.a, ")")
|
|
100
|
-
}
|
|
101
|
-
}), readOnly && /*#__PURE__*/_react.default.createElement(ReadOnlyContainer, {
|
|
102
|
-
padding: 2,
|
|
103
|
-
paddingBottom: 1,
|
|
104
|
-
sizing: "border",
|
|
105
|
-
justify: "space-between"
|
|
106
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Stack, {
|
|
107
|
-
space: 3,
|
|
108
|
-
marginTop: 1
|
|
109
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Text, {
|
|
110
|
-
size: 3,
|
|
111
|
-
weight: "bold"
|
|
112
|
-
}, hex), /*#__PURE__*/_react.default.createElement(_ui.Inline, {
|
|
113
|
-
space: 3
|
|
114
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Text, {
|
|
115
|
-
size: 1
|
|
116
|
-
}, /*#__PURE__*/_react.default.createElement("strong", null, "RGB: "), rgb.r, " ", rgb.g, " ", rgb.b), /*#__PURE__*/_react.default.createElement(_ui.Text, {
|
|
117
|
-
size: 1
|
|
118
|
-
}, /*#__PURE__*/_react.default.createElement("strong", null, "HSL: "), " ", Math.round(hsl.h), " ", Math.round(hsl.s), "%", ' ', Math.round(hsl.l)))))), !readOnly && /*#__PURE__*/_react.default.createElement(_ui.Flex, {
|
|
119
|
-
align: "flex-start",
|
|
120
|
-
marginLeft: 2
|
|
121
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Box, {
|
|
122
|
-
style: {
|
|
123
|
-
width: 200
|
|
124
|
-
}
|
|
125
|
-
}, /*#__PURE__*/_react.default.createElement(_ColorPickerFields.ColorPickerFields, {
|
|
126
|
-
rgb: rgb,
|
|
127
|
-
hsl: hsl,
|
|
128
|
-
hex: hex,
|
|
129
|
-
onChange: onChange,
|
|
130
|
-
disableAlpha: disableAlpha
|
|
131
|
-
})), /*#__PURE__*/_react.default.createElement(_ui.Box, {
|
|
132
|
-
marginLeft: 2
|
|
133
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Button, {
|
|
134
|
-
onClick: onUnset,
|
|
135
|
-
title: "Delete color",
|
|
136
|
-
icon: _icons.TrashIcon,
|
|
137
|
-
tone: "critical"
|
|
138
|
-
})))))));
|
|
139
|
-
};
|
|
140
|
-
|
|
141
|
-
ColorPicker.propTypes = {
|
|
142
|
-
width: _propTypes.default.string,
|
|
143
|
-
hex: _propTypes.default.string,
|
|
144
|
-
hsl: _propTypes.default.object,
|
|
145
|
-
hsv: _propTypes.default.object,
|
|
146
|
-
rgb: _propTypes.default.object,
|
|
147
|
-
onChange: _propTypes.default.func,
|
|
148
|
-
disableAlpha: _propTypes.default.bool,
|
|
149
|
-
readOnly: _propTypes.default.bool,
|
|
150
|
-
renderers: _propTypes.default.func,
|
|
151
|
-
onUnset: _propTypes.default.func
|
|
152
|
-
};
|
|
153
|
-
ColorPicker.defaultProps = {
|
|
154
|
-
disableAlpha: false
|
|
155
|
-
};
|
|
156
|
-
|
|
157
|
-
var _default = (0, _common.ColorWrap)(ColorPicker);
|
|
158
|
-
|
|
159
|
-
exports.default = _default;
|
package/lib/ColorPickerFields.js
DELETED
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = exports.ColorPickerFields = void 0;
|
|
7
|
-
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
|
|
10
|
-
var color = _interopRequireWildcard(require("react-color/lib/helpers/color"));
|
|
11
|
-
|
|
12
|
-
var _common = require("react-color/lib/components/common");
|
|
13
|
-
|
|
14
|
-
var _ui = require("@sanity/ui");
|
|
15
|
-
|
|
16
|
-
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
17
|
-
|
|
18
|
-
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
19
|
-
|
|
20
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
21
|
-
|
|
22
|
-
var ColorPickerFields = _ref => {
|
|
23
|
-
var onChange = _ref.onChange,
|
|
24
|
-
rgb = _ref.rgb,
|
|
25
|
-
hsl = _ref.hsl,
|
|
26
|
-
hex = _ref.hex,
|
|
27
|
-
disableAlpha = _ref.disableAlpha;
|
|
28
|
-
|
|
29
|
-
var _useTheme = (0, _ui.useTheme)(),
|
|
30
|
-
sanity = _useTheme.sanity;
|
|
31
|
-
|
|
32
|
-
var inputStyles = {
|
|
33
|
-
input: {
|
|
34
|
-
width: '80%',
|
|
35
|
-
padding: '4px 10% 3px',
|
|
36
|
-
border: 'none',
|
|
37
|
-
boxShadow: "inset 0 0 0 1px ".concat(sanity.color.input.default.enabled.border),
|
|
38
|
-
color: sanity.color.input.default.enabled.fg,
|
|
39
|
-
backgroundColor: sanity.color.input.default.enabled.bg,
|
|
40
|
-
fontSize: sanity.fonts.text.sizes[0].fontSize,
|
|
41
|
-
textAlign: 'center'
|
|
42
|
-
},
|
|
43
|
-
label: {
|
|
44
|
-
display: 'block',
|
|
45
|
-
textAlign: 'center',
|
|
46
|
-
fontSize: sanity.fonts.label.sizes[0].fontSize,
|
|
47
|
-
color: sanity.color.base.fg,
|
|
48
|
-
paddingTop: '3px',
|
|
49
|
-
paddingBottom: '4px',
|
|
50
|
-
textTransform: 'capitalize'
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
var handleChange = (data, e) => {
|
|
55
|
-
if (data.hex && color.isValidHex(data.hex)) {
|
|
56
|
-
onChange({
|
|
57
|
-
hex: data.hex,
|
|
58
|
-
source: 'hex'
|
|
59
|
-
}, e);
|
|
60
|
-
} else if (data.r || data.g || data.b) {
|
|
61
|
-
onChange({
|
|
62
|
-
r: data.r || rgb.r,
|
|
63
|
-
g: data.g || rgb.g,
|
|
64
|
-
b: data.b || rgb.b,
|
|
65
|
-
a: rgb.a,
|
|
66
|
-
source: 'rgb'
|
|
67
|
-
}, e);
|
|
68
|
-
} else if (data.a) {
|
|
69
|
-
if (data.a < 0) {
|
|
70
|
-
data.a = 0;
|
|
71
|
-
} else if (data.a > 100) {
|
|
72
|
-
data.a = 100;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
data.a /= 100;
|
|
76
|
-
onChange({
|
|
77
|
-
h: hsl.h,
|
|
78
|
-
s: hsl.s,
|
|
79
|
-
l: hsl.l,
|
|
80
|
-
a: data.a,
|
|
81
|
-
source: 'rgb'
|
|
82
|
-
}, e);
|
|
83
|
-
}
|
|
84
|
-
};
|
|
85
|
-
|
|
86
|
-
return /*#__PURE__*/_react.default.createElement(_ui.Flex, null, /*#__PURE__*/_react.default.createElement(_ui.Box, {
|
|
87
|
-
flex: 2,
|
|
88
|
-
marginRight: 1
|
|
89
|
-
}, /*#__PURE__*/_react.default.createElement(_common.EditableInput, {
|
|
90
|
-
style: inputStyles,
|
|
91
|
-
label: "hex",
|
|
92
|
-
value: hex.replace('#', ''),
|
|
93
|
-
onChange: handleChange
|
|
94
|
-
})), /*#__PURE__*/_react.default.createElement(_ui.Box, {
|
|
95
|
-
flex: 1,
|
|
96
|
-
marginRight: 1
|
|
97
|
-
}, /*#__PURE__*/_react.default.createElement(_common.EditableInput, {
|
|
98
|
-
style: inputStyles,
|
|
99
|
-
label: "r",
|
|
100
|
-
value: rgb.r,
|
|
101
|
-
onChange: handleChange,
|
|
102
|
-
dragLabel: "true",
|
|
103
|
-
dragMax: "255"
|
|
104
|
-
})), /*#__PURE__*/_react.default.createElement(_ui.Box, {
|
|
105
|
-
flex: 1,
|
|
106
|
-
marginRight: 1
|
|
107
|
-
}, /*#__PURE__*/_react.default.createElement(_common.EditableInput, {
|
|
108
|
-
style: inputStyles,
|
|
109
|
-
label: "g",
|
|
110
|
-
value: rgb.g,
|
|
111
|
-
onChange: handleChange,
|
|
112
|
-
dragLabel: "true",
|
|
113
|
-
dragMax: "255"
|
|
114
|
-
})), /*#__PURE__*/_react.default.createElement(_ui.Box, {
|
|
115
|
-
flex: 1,
|
|
116
|
-
marginRight: 1
|
|
117
|
-
}, /*#__PURE__*/_react.default.createElement(_common.EditableInput, {
|
|
118
|
-
style: inputStyles,
|
|
119
|
-
label: "b",
|
|
120
|
-
value: rgb.b,
|
|
121
|
-
onChange: handleChange,
|
|
122
|
-
dragLabel: "true",
|
|
123
|
-
dragMax: "255"
|
|
124
|
-
})), !disableAlpha && /*#__PURE__*/_react.default.createElement(_ui.Box, {
|
|
125
|
-
flex: 1
|
|
126
|
-
}, /*#__PURE__*/_react.default.createElement(_common.EditableInput, {
|
|
127
|
-
style: inputStyles,
|
|
128
|
-
label: "a",
|
|
129
|
-
value: Math.round(rgb.a * 100),
|
|
130
|
-
onChange: handleChange,
|
|
131
|
-
dragLabel: "true",
|
|
132
|
-
dragMax: "100"
|
|
133
|
-
})));
|
|
134
|
-
};
|
|
135
|
-
|
|
136
|
-
exports.ColorPickerFields = ColorPickerFields;
|
|
137
|
-
var _default = ColorPickerFields;
|
|
138
|
-
exports.default = _default;
|
package/lib/schemas/color.js
DELETED
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
|
|
10
|
-
var _ColorInput = _interopRequireDefault(require("../ColorInput"));
|
|
11
|
-
|
|
12
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
|
-
/* eslint-disable react/display-name */
|
|
15
|
-
var round = val => Math.round(val * 100);
|
|
16
|
-
|
|
17
|
-
var _default = {
|
|
18
|
-
name: 'color',
|
|
19
|
-
type: 'object',
|
|
20
|
-
title: 'Color',
|
|
21
|
-
inputComponent: _ColorInput.default,
|
|
22
|
-
fields: [{
|
|
23
|
-
title: 'Hex',
|
|
24
|
-
name: 'hex',
|
|
25
|
-
type: 'string'
|
|
26
|
-
}, {
|
|
27
|
-
title: 'Alpha',
|
|
28
|
-
name: 'alpha',
|
|
29
|
-
type: 'number'
|
|
30
|
-
}, {
|
|
31
|
-
title: 'Hue Saturation Lightness',
|
|
32
|
-
name: 'hsl',
|
|
33
|
-
type: 'hslaColor'
|
|
34
|
-
}, {
|
|
35
|
-
title: 'Hue Saturation Value',
|
|
36
|
-
name: 'hsv',
|
|
37
|
-
type: 'hsvaColor'
|
|
38
|
-
}, {
|
|
39
|
-
title: 'Red Green Blue (rgb)',
|
|
40
|
-
name: 'rgb',
|
|
41
|
-
type: 'rgbaColor'
|
|
42
|
-
}],
|
|
43
|
-
preview: {
|
|
44
|
-
select: {
|
|
45
|
-
title: 'hex',
|
|
46
|
-
alpha: 'alpha',
|
|
47
|
-
hex: 'hex',
|
|
48
|
-
hsl: 'hsl'
|
|
49
|
-
},
|
|
50
|
-
|
|
51
|
-
prepare(_ref) {
|
|
52
|
-
var title = _ref.title,
|
|
53
|
-
hex = _ref.hex,
|
|
54
|
-
hsl = _ref.hsl,
|
|
55
|
-
alpha = _ref.alpha;
|
|
56
|
-
var subtitle = hex || 'No color set';
|
|
57
|
-
|
|
58
|
-
if (hsl) {
|
|
59
|
-
subtitle = "H:".concat(round(hsl.l), " S:").concat(round(hsl.l), " L:").concat(round(hsl.l), " A:").concat(round(alpha));
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
return {
|
|
63
|
-
title: title,
|
|
64
|
-
subtitle: subtitle,
|
|
65
|
-
media: () => /*#__PURE__*/_react.default.createElement("div", {
|
|
66
|
-
style: {
|
|
67
|
-
backgroundColor: hex || '#000',
|
|
68
|
-
opacity: alpha || 1,
|
|
69
|
-
position: 'absolute',
|
|
70
|
-
height: '100%',
|
|
71
|
-
width: '100%',
|
|
72
|
-
top: '0',
|
|
73
|
-
left: '0'
|
|
74
|
-
}
|
|
75
|
-
})
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
}
|
|
80
|
-
};
|
|
81
|
-
exports.default = _default;
|
package/lib/schemas/hslaColor.js
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _default = {
|
|
8
|
-
title: 'Hue Saturation Lightness',
|
|
9
|
-
name: 'hslaColor',
|
|
10
|
-
type: 'object',
|
|
11
|
-
fields: [{
|
|
12
|
-
name: 'h',
|
|
13
|
-
type: 'number',
|
|
14
|
-
title: 'Hue'
|
|
15
|
-
}, {
|
|
16
|
-
name: 's',
|
|
17
|
-
type: 'number',
|
|
18
|
-
title: 'Saturation'
|
|
19
|
-
}, {
|
|
20
|
-
name: 'l',
|
|
21
|
-
type: 'number',
|
|
22
|
-
title: 'Lightness'
|
|
23
|
-
}, {
|
|
24
|
-
name: 'a',
|
|
25
|
-
type: 'number',
|
|
26
|
-
title: 'Alpha'
|
|
27
|
-
}]
|
|
28
|
-
};
|
|
29
|
-
exports.default = _default;
|