@elliemae/ds-classnames 3.26.1-rc.1 → 3.27.0-next.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/dist/cjs/index.js +2 -11
- package/dist/cjs/index.js.map +2 -2
- package/dist/esm/index.js +1 -7
- package/dist/esm/index.js.map +3 -3
- package/dist/types/index.d.ts +1 -2
- package/package.json +8 -45
- package/dist/cjs/aggregatedClasses.js +0 -87
- package/dist/cjs/aggregatedClasses.js.map +0 -7
- package/dist/cjs/aggregatedClasses.md +0 -323
- package/dist/cjs/classNameManager.js +0 -84
- package/dist/cjs/classNameManager.js.map +0 -7
- package/dist/cjs/converPropsToFormModifiers.js +0 -59
- package/dist/cjs/converPropsToFormModifiers.js.map +0 -7
- package/dist/cjs/convertPropToFeedBackModifiers.js +0 -61
- package/dist/cjs/convertPropToFeedBackModifiers.js.map +0 -7
- package/dist/cjs/convertPropsToColorModifiers.js +0 -59
- package/dist/cjs/convertPropsToColorModifiers.js.map +0 -7
- package/dist/cjs/convertPropsToLayoutModifiers.js +0 -61
- package/dist/cjs/convertPropsToLayoutModifiers.js.map +0 -7
- package/dist/cjs/convertPropsToSizeModifiers.js +0 -78
- package/dist/cjs/convertPropsToSizeModifiers.js.map +0 -7
- package/dist/cjs/convertPropsToTextModifiers.js +0 -59
- package/dist/cjs/convertPropsToTextModifiers.js.map +0 -7
- package/dist/cjs/dimsum.config.js +0 -38
- package/dist/cjs/dimsum.config.js.map +0 -7
- package/dist/cjs/validateNativeProps.js +0 -430
- package/dist/cjs/validateNativeProps.js.map +0 -7
- package/dist/esm/aggregatedClasses.js +0 -60
- package/dist/esm/aggregatedClasses.js.map +0 -7
- package/dist/esm/aggregatedClasses.md +0 -323
- package/dist/esm/classNameManager.js +0 -54
- package/dist/esm/classNameManager.js.map +0 -7
- package/dist/esm/converPropsToFormModifiers.js +0 -29
- package/dist/esm/converPropsToFormModifiers.js.map +0 -7
- package/dist/esm/convertPropToFeedBackModifiers.js +0 -31
- package/dist/esm/convertPropToFeedBackModifiers.js.map +0 -7
- package/dist/esm/convertPropsToColorModifiers.js +0 -29
- package/dist/esm/convertPropsToColorModifiers.js.map +0 -7
- package/dist/esm/convertPropsToLayoutModifiers.js +0 -31
- package/dist/esm/convertPropsToLayoutModifiers.js.map +0 -7
- package/dist/esm/convertPropsToSizeModifiers.js +0 -48
- package/dist/esm/convertPropsToSizeModifiers.js.map +0 -7
- package/dist/esm/convertPropsToTextModifiers.js +0 -29
- package/dist/esm/convertPropsToTextModifiers.js.map +0 -7
- package/dist/esm/dimsum.config.js +0 -8
- package/dist/esm/dimsum.config.js.map +0 -7
- package/dist/esm/validateNativeProps.js +0 -400
- package/dist/esm/validateNativeProps.js.map +0 -7
- package/dist/types/aggregatedClasses.d.ts +0 -11
- package/dist/types/classNameManager.d.ts +0 -28
- package/dist/types/converPropsToFormModifiers.d.ts +0 -15
- package/dist/types/convertPropToFeedBackModifiers.d.ts +0 -17
- package/dist/types/convertPropsToColorModifiers.d.ts +0 -11
- package/dist/types/convertPropsToLayoutModifiers.d.ts +0 -17
- package/dist/types/convertPropsToSizeModifiers.d.ts +0 -25
- package/dist/types/convertPropsToTextModifiers.d.ts +0 -15
- package/dist/types/dimsum.config.d.ts +0 -4
- package/dist/types/validateNativeProps.d.ts +0 -265
package/dist/cjs/index.js
CHANGED
|
@@ -5,10 +5,6 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
|
5
5
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
6
|
var __getProtoOf = Object.getPrototypeOf;
|
|
7
7
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
8
|
var __copyProps = (to, from, except, desc) => {
|
|
13
9
|
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
10
|
for (let key of __getOwnPropNames(from))
|
|
@@ -17,6 +13,7 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
17
13
|
}
|
|
18
14
|
return to;
|
|
19
15
|
};
|
|
16
|
+
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
20
17
|
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
18
|
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
19
|
// file that has been converted to a CommonJS file using a Babel-
|
|
@@ -27,13 +24,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
27
24
|
));
|
|
28
25
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
26
|
var src_exports = {};
|
|
30
|
-
__export(src_exports, {
|
|
31
|
-
aggregatedClasses: () => import_aggregatedClasses.default,
|
|
32
|
-
convertPropToCssClassName: () => import_classNameManager.default,
|
|
33
|
-
cssPrefix: () => import_classNameManager.cssPrefix
|
|
34
|
-
});
|
|
35
27
|
module.exports = __toCommonJS(src_exports);
|
|
36
28
|
var React = __toESM(require("react"));
|
|
37
|
-
|
|
38
|
-
var import_aggregatedClasses = __toESM(require("./aggregatedClasses.js"));
|
|
29
|
+
__reExport(src_exports, require("@elliemae/ds-legacy-classnames"), module.exports);
|
|
39
30
|
//# sourceMappingURL=index.js.map
|
package/dist/cjs/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/index.tsx", "../../../../../scripts/build/transpile/react-shim.js"],
|
|
4
|
-
"sourcesContent": ["export
|
|
5
|
-
"mappings": "
|
|
4
|
+
"sourcesContent": ["export * from '@elliemae/ds-legacy-classnames';\n", "import * as React from 'react';\nexport { React };\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;ACAA,YAAuB;ADAvB,wBAAc,2CAAd;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/dist/esm/index.js
CHANGED
|
@@ -1,9 +1,3 @@
|
|
|
1
1
|
import * as React from "react";
|
|
2
|
-
|
|
3
|
-
import { default as default3 } from "./aggregatedClasses.js";
|
|
4
|
-
export {
|
|
5
|
-
default3 as aggregatedClasses,
|
|
6
|
-
default2 as convertPropToCssClassName,
|
|
7
|
-
cssPrefix
|
|
8
|
-
};
|
|
2
|
+
export * from "@elliemae/ds-legacy-classnames";
|
|
9
3
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../src/index.tsx"],
|
|
4
|
-
"sourcesContent": ["import * as React from 'react';\nexport { React };\n", "export
|
|
5
|
-
"mappings": "AAAA,YAAY,WAAW;ACAvB,
|
|
6
|
-
"names": [
|
|
4
|
+
"sourcesContent": ["import * as React from 'react';\nexport { React };\n", "export * from '@elliemae/ds-legacy-classnames';\n"],
|
|
5
|
+
"mappings": "AAAA,YAAY,WAAW;ACAvB,cAAc;",
|
|
6
|
+
"names": []
|
|
7
7
|
}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -1,2 +1 @@
|
|
|
1
|
-
export
|
|
2
|
-
export { default as aggregatedClasses } from './aggregatedClasses.js';
|
|
1
|
+
export * from '@elliemae/ds-legacy-classnames';
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@elliemae/ds-classnames",
|
|
3
|
-
"version": "3.
|
|
3
|
+
"version": "3.27.0-next.2",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"description": "ICE MT - Dimsum Library - Aggregated classNames to component",
|
|
6
6
|
"files": [
|
|
@@ -13,42 +13,6 @@
|
|
|
13
13
|
".": {
|
|
14
14
|
"import": "./dist/esm/index.js",
|
|
15
15
|
"require": "./dist/cjs/index.js"
|
|
16
|
-
},
|
|
17
|
-
"./validateNativeProps": {
|
|
18
|
-
"import": "./dist/esm/validateNativeProps.js",
|
|
19
|
-
"require": "./dist/cjs/validateNativeProps.js"
|
|
20
|
-
},
|
|
21
|
-
"./convertPropToFeedBackModifiers": {
|
|
22
|
-
"import": "./dist/esm/convertPropToFeedBackModifiers.js",
|
|
23
|
-
"require": "./dist/cjs/convertPropToFeedBackModifiers.js"
|
|
24
|
-
},
|
|
25
|
-
"./convertPropsToTextModifiers": {
|
|
26
|
-
"import": "./dist/esm/convertPropsToTextModifiers.js",
|
|
27
|
-
"require": "./dist/cjs/convertPropsToTextModifiers.js"
|
|
28
|
-
},
|
|
29
|
-
"./convertPropsToSizeModifiers": {
|
|
30
|
-
"import": "./dist/esm/convertPropsToSizeModifiers.js",
|
|
31
|
-
"require": "./dist/cjs/convertPropsToSizeModifiers.js"
|
|
32
|
-
},
|
|
33
|
-
"./convertPropsToLayoutModifiers": {
|
|
34
|
-
"import": "./dist/esm/convertPropsToLayoutModifiers.js",
|
|
35
|
-
"require": "./dist/cjs/convertPropsToLayoutModifiers.js"
|
|
36
|
-
},
|
|
37
|
-
"./convertPropsToColorModifiers": {
|
|
38
|
-
"import": "./dist/esm/convertPropsToColorModifiers.js",
|
|
39
|
-
"require": "./dist/cjs/convertPropsToColorModifiers.js"
|
|
40
|
-
},
|
|
41
|
-
"./converPropsToFormModifiers": {
|
|
42
|
-
"import": "./dist/esm/converPropsToFormModifiers.js",
|
|
43
|
-
"require": "./dist/cjs/converPropsToFormModifiers.js"
|
|
44
|
-
},
|
|
45
|
-
"./classNameManager": {
|
|
46
|
-
"import": "./dist/esm/classNameManager.js",
|
|
47
|
-
"require": "./dist/cjs/classNameManager.js"
|
|
48
|
-
},
|
|
49
|
-
"./aggregatedClasses": {
|
|
50
|
-
"import": "./dist/esm/aggregatedClasses.js",
|
|
51
|
-
"require": "./dist/cjs/aggregatedClasses.js"
|
|
52
16
|
}
|
|
53
17
|
},
|
|
54
18
|
"sideEffects": [
|
|
@@ -71,13 +35,12 @@
|
|
|
71
35
|
"indent": 4
|
|
72
36
|
},
|
|
73
37
|
"dependencies": {
|
|
74
|
-
"
|
|
75
|
-
"@elliemae/ds-utilities": "3.26.1-rc.1"
|
|
38
|
+
"@elliemae/ds-legacy-classnames": "1.0.1"
|
|
76
39
|
},
|
|
77
40
|
"devDependencies": {
|
|
78
41
|
"@elliemae/pui-cli": "~9.0.0-next.31",
|
|
79
42
|
"styled-components": "~5.3.9",
|
|
80
|
-
"@elliemae/ds-monorepo-devops": "3.
|
|
43
|
+
"@elliemae/ds-monorepo-devops": "3.27.0-next.2"
|
|
81
44
|
},
|
|
82
45
|
"publishConfig": {
|
|
83
46
|
"access": "public",
|
|
@@ -89,14 +52,14 @@
|
|
|
89
52
|
"react-dom": "^17.0.2"
|
|
90
53
|
},
|
|
91
54
|
"scripts": {
|
|
92
|
-
"test": "
|
|
93
|
-
"lint": "
|
|
94
|
-
"eslint:fix": "
|
|
95
|
-
"dts": "
|
|
55
|
+
"test": "exit 0 | echo",
|
|
56
|
+
"lint": "exit 0 | echo",
|
|
57
|
+
"eslint:fix": "exit 0 | echo",
|
|
58
|
+
"dts": "exit 0 | echo",
|
|
96
59
|
"build": "cross-env NODE_ENV=production node ../../../scripts/build/build.mjs",
|
|
97
60
|
"dev:build": "pnpm --filter {.}... build",
|
|
98
61
|
"dev:install": "pnpm --filter {.}... i --no-lockfile && pnpm run dev:build",
|
|
99
|
-
"checkDeps": "
|
|
62
|
+
"checkDeps": "exit 0 | echo",
|
|
100
63
|
"dev": "cross-env NODE_ENV=development node ../../../scripts/build/build.mjs --watch"
|
|
101
64
|
}
|
|
102
65
|
}
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var aggregatedClasses_exports = {};
|
|
30
|
-
__export(aggregatedClasses_exports, {
|
|
31
|
-
cssPrefix: () => cssPrefix,
|
|
32
|
-
default: () => aggregatedClasses_default
|
|
33
|
-
});
|
|
34
|
-
module.exports = __toCommonJS(aggregatedClasses_exports);
|
|
35
|
-
var React = __toESM(require("react"));
|
|
36
|
-
var import_react = __toESM(require("react"));
|
|
37
|
-
var import_obj_str = __toESM(require("obj-str"));
|
|
38
|
-
var import_classNameManager = require("./classNameManager.js");
|
|
39
|
-
var import_dimsum_config = require("./dimsum.config.js");
|
|
40
|
-
var import_validateNativeProps = require("./validateNativeProps.js");
|
|
41
|
-
const cssPrefix = import_dimsum_config.dimsumConfig.classNamePrefix;
|
|
42
|
-
const generateClassNameWithModifier = (block, element, modifier) => `${cssPrefix}-${block}${element ? `__${element}` : ""}--${modifier}`;
|
|
43
|
-
const appendBlockAndPrefixToObj = (obj, block, element) => obj ? Object.keys(obj).reduce(
|
|
44
|
-
(acc, key) => ({
|
|
45
|
-
...acc,
|
|
46
|
-
[`${generateClassNameWithModifier(block, element, key)}`]: obj[key]
|
|
47
|
-
}),
|
|
48
|
-
{}
|
|
49
|
-
) : [];
|
|
50
|
-
const aggregatedClasses = (type, props) => (block, element, additionalModifiers, options = {}) => import_react.default.forwardRef(({ innerRef, children, classProps, useComponent, className, as, ...rest }, ref) => {
|
|
51
|
-
let otherModifiers = appendBlockAndPrefixToObj(additionalModifiers, block, element);
|
|
52
|
-
if (typeof additionalModifiers === "function")
|
|
53
|
-
otherModifiers = appendBlockAndPrefixToObj(
|
|
54
|
-
additionalModifiers({ ...rest, ...classProps, className }),
|
|
55
|
-
block,
|
|
56
|
-
element
|
|
57
|
-
);
|
|
58
|
-
const otherModifiersStr = (0, import_obj_str.default)(otherModifiers);
|
|
59
|
-
const { prefix, propsToRemoveFromFinalElement = [] } = options;
|
|
60
|
-
const { cssClassName: classNames } = (0, import_classNameManager.convertPropToCssClassName)(
|
|
61
|
-
block,
|
|
62
|
-
null,
|
|
63
|
-
{ ...classProps },
|
|
64
|
-
{ prefix, element }
|
|
65
|
-
);
|
|
66
|
-
const cleanedPropsPassedDown = { ...props, ...rest };
|
|
67
|
-
propsToRemoveFromFinalElement.forEach((propKey) => {
|
|
68
|
-
delete cleanedPropsPassedDown[propKey];
|
|
69
|
-
});
|
|
70
|
-
if ((0, import_validateNativeProps.isNativeHTMLElement)(block)) {
|
|
71
|
-
Object.keys(cleanedPropsPassedDown).forEach((key) => {
|
|
72
|
-
if (!(0, import_validateNativeProps.isValidNativeAttribute)(key))
|
|
73
|
-
delete cleanedPropsPassedDown[key];
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
return import_react.default.createElement(
|
|
77
|
-
as || type,
|
|
78
|
-
{
|
|
79
|
-
ref: innerRef || ref,
|
|
80
|
-
className: [classNames, otherModifiersStr, className].join(" "),
|
|
81
|
-
...cleanedPropsPassedDown
|
|
82
|
-
},
|
|
83
|
-
children
|
|
84
|
-
);
|
|
85
|
-
});
|
|
86
|
-
var aggregatedClasses_default = aggregatedClasses;
|
|
87
|
-
//# sourceMappingURL=aggregatedClasses.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/aggregatedClasses.tsx", "../../../../../scripts/build/transpile/react-shim.js"],
|
|
4
|
-
"sourcesContent": ["/* eslint-disable @typescript-eslint/no-unsafe-assignment */\n/* eslint-disable prettier/prettier */\n/* eslint-disable max-params */\n/* eslint-disable react/prop-types */\nimport React from 'react';\nimport cx from 'obj-str';\nimport { convertPropToCssClassName } from './classNameManager.js';\nimport { dimsumConfig } from './dimsum.config.js';\nimport {\n isValidNativeAttribute,\n isNativeHTMLElement,\n} from './validateNativeProps.js';\n\nexport const cssPrefix = dimsumConfig.classNamePrefix;\n\ntype AggregatedClassesT<T = unknown> = (\n type: any,\n props?: any,\n) => (\n block: string,\n element?: string | null,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n additionalModifiers?: { [key: string]: unknown } | ((arg: any) => { [key: string]: unknown }),\n options?: { [key: string]: unknown },\n) => React.ForwardRefExoticComponent<React.RefAttributes<T>>;\n\nconst generateClassNameWithModifier = (block, element, modifier) =>\n `${cssPrefix}-${block}${element ? `__${element}` : ''}--${modifier}`;\n\nconst appendBlockAndPrefixToObj = (obj, block, element) =>\n obj\n ? Object.keys(obj).reduce(\n (acc, key) => ({\n ...acc,\n [`${generateClassNameWithModifier(block, element, key)}`]: obj[key],\n }),\n {},\n )\n : [];\n\nconst aggregatedClasses: AggregatedClassesT=\n (type, props) =>\n (block, element, additionalModifiers, options = {}) =>\n React.forwardRef(({ innerRef, children, classProps, useComponent, className, as, ...rest }, ref) => {\n // get the additional classNames either from a function or an object\n let otherModifiers = appendBlockAndPrefixToObj(additionalModifiers, block, element);\n if (typeof additionalModifiers === 'function')\n otherModifiers = appendBlockAndPrefixToObj(\n additionalModifiers({ ...rest, ...classProps, className }),\n block,\n element,\n );\n\n const otherModifiersStr = cx(otherModifiers);\n const { prefix, propsToRemoveFromFinalElement = [] } = options;\n const { cssClassName: classNames } = convertPropToCssClassName(\n block,\n null,\n { ...classProps },\n { prefix, element },\n );\n const cleanedPropsPassedDown = { ...props, ...rest };\n propsToRemoveFromFinalElement.forEach((propKey) => {\n delete cleanedPropsPassedDown[propKey];\n });\n\n if (isNativeHTMLElement(block)) {\n Object.keys(cleanedPropsPassedDown).forEach((key) => {\n if (!isValidNativeAttribute(key)) delete cleanedPropsPassedDown[key];\n });\n }\n\n return React.createElement(\n as || type,\n {\n ref: innerRef || ref,\n className: [classNames, otherModifiersStr, className].join(' '),\n ...cleanedPropsPassedDown,\n },\n children,\n );\n });\n\nexport default aggregatedClasses;\n", "import * as React from 'react';\nexport { React };\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADIvB,mBAAkB;AAClB,qBAAe;AACf,8BAA0C;AAC1C,2BAA6B;AAC7B,iCAGO;AAEA,MAAM,YAAY,kCAAa;AAatC,MAAM,gCAAgC,CAAC,OAAO,SAAS,aACrD,GAAG,aAAa,QAAQ,UAAU,KAAK,YAAY,OAAO;AAE5D,MAAM,4BAA4B,CAAC,KAAK,OAAO,YAC7C,MACI,OAAO,KAAK,GAAG,EAAE;AAAA,EACjB,CAAC,KAAK,SAAS;AAAA,IACb,GAAG;AAAA,IACH,CAAC,GAAG,8BAA8B,OAAO,SAAS,GAAG,GAAG,GAAG,IAAI,GAAG;AAAA,EACpE;AAAA,EACA,CAAC;AACH,IACE,CAAC;AAEP,MAAM,oBACJ,CAAC,MAAM,UACL,CAAC,OAAO,SAAS,qBAAqB,UAAU,CAAC,MAC/C,aAAAA,QAAM,WAAW,CAAC,EAAE,UAAU,UAAU,YAAY,cAAc,WAAW,IAAI,GAAG,KAAK,GAAG,QAAQ;AAElG,MAAI,iBAAiB,0BAA0B,qBAAqB,OAAO,OAAO;AAClF,MAAI,OAAO,wBAAwB;AACjC,qBAAiB;AAAA,MACf,oBAAoB,EAAE,GAAG,MAAM,GAAG,YAAY,UAAU,CAAC;AAAA,MACzD;AAAA,MACA;AAAA,IACF;AAEF,QAAM,wBAAoB,eAAAC,SAAG,cAAc;AAC3C,QAAM,EAAE,QAAQ,gCAAgC,CAAC,EAAE,IAAI;AACvD,QAAM,EAAE,cAAc,WAAW,QAAI;AAAA,IACnC;AAAA,IACA;AAAA,IACA,EAAE,GAAG,WAAW;AAAA,IAChB,EAAE,QAAQ,QAAQ;AAAA,EACpB;AACA,QAAM,yBAAyB,EAAE,GAAG,OAAO,GAAG,KAAK;AACnD,gCAA8B,QAAQ,CAAC,YAAY;AACjD,WAAO,uBAAuB,OAAO;AAAA,EACvC,CAAC;AAED,UAAI,gDAAoB,KAAK,GAAG;AAC9B,WAAO,KAAK,sBAAsB,EAAE,QAAQ,CAAC,QAAQ;AACnD,UAAI,KAAC,mDAAuB,GAAG;AAAG,eAAO,uBAAuB,GAAG;AAAA,IACrE,CAAC;AAAA,EACH;AAEA,SAAO,aAAAD,QAAM;AAAA,IACX,MAAM;AAAA,IACN;AAAA,MACE,KAAK,YAAY;AAAA,MACjB,WAAW,CAAC,YAAY,mBAAmB,SAAS,EAAE,KAAK,GAAG;AAAA,MAC9D,GAAG;AAAA,IACL;AAAA,IACA;AAAA,EACF;AACF,CAAC;AAEP,IAAO,4BAAQ;",
|
|
6
|
-
"names": ["React", "cx"]
|
|
7
|
-
}
|
|
@@ -1,323 +0,0 @@
|
|
|
1
|
-
# aggregatedClasses
|
|
2
|
-
|
|
3
|
-
Utility to clean up the renders of too many classNames, internally uses the classNamePipeline and obj-str to ease the workflow.
|
|
4
|
-
Follows BEM methodology (block - element - modifier)
|
|
5
|
-
<br> This utility allows us to create components outside the render method with the block-element-modifiers injected in the className
|
|
6
|
-
## Constructor
|
|
7
|
-
|
|
8
|
-
```jsx
|
|
9
|
-
const blockName = 'form-item'
|
|
10
|
-
|
|
11
|
-
const Label = aggregatedClasses('div')(blockName, 'label')
|
|
12
|
-
const InputController = aggregatedClasses('div')(blockName, 'controller')
|
|
13
|
-
|
|
14
|
-
// generates
|
|
15
|
-
<div className='ds-em-form-item__label' />
|
|
16
|
-
<div className='ds-em-form-item__controller' />
|
|
17
|
-
|
|
18
|
-
// and based on the props passed through classProps is going to inject the proper modifiers
|
|
19
|
-
render() {
|
|
20
|
-
return (
|
|
21
|
-
<Label
|
|
22
|
-
classProps={{
|
|
23
|
-
hasError: true,
|
|
24
|
-
readOnly: true,
|
|
25
|
-
disabled: true
|
|
26
|
-
}}
|
|
27
|
-
/>
|
|
28
|
-
)
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
// generates
|
|
32
|
-
<div className='ds-em-form-item__label ds-em-form-item__label--error ds-em-form-item__label--readonly ds-em-form-item__label--disabled' />
|
|
33
|
-
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
This creates a component with the specified element or other component and creates the className based on the blockName, the elementName, and the props that this component is going to receive.
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
### Parameters
|
|
40
|
-
```js
|
|
41
|
-
export default type => (block, element, additionalClassNames, options)
|
|
42
|
-
```
|
|
43
|
-
|
|
44
|
-
@type - element or component to create <br>
|
|
45
|
-
@block - block name <br>
|
|
46
|
-
@element - element name
|
|
47
|
-
@additionalModifiers - object that appends new modifiers to the className if the value is true. <br>
|
|
48
|
-
Also we can use a function that takes the props of the component created <br>
|
|
49
|
-
<br>
|
|
50
|
-
@options - Object to configure 'prefix'
|
|
51
|
-
|
|
52
|
-
####Example
|
|
53
|
-
```js
|
|
54
|
-
const Wrapper = aggregatedClasses('div')(blockName, 'elementName', props => ({
|
|
55
|
-
someModifier: true,
|
|
56
|
-
otherModifier: props.hasClass
|
|
57
|
-
}))
|
|
58
|
-
```
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
####Example
|
|
62
|
-
```js
|
|
63
|
-
const Wrapper = aggregatedClasses('div')(blockName, 'elementName', {someClassName: true}, {prefix: 'DIMSUM'})
|
|
64
|
-
```
|
|
65
|
-
|
|
66
|
-
```jsx
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
// this translates
|
|
70
|
-
const Wrapper = ({ children, ...rest }) => {
|
|
71
|
-
const { cssClassName } = convertPropToCssClassName(
|
|
72
|
-
blockName,
|
|
73
|
-
null,
|
|
74
|
-
{ ...rest })
|
|
75
|
-
return (
|
|
76
|
-
<div className={cssClassName}>
|
|
77
|
-
{ children }
|
|
78
|
-
</div>
|
|
79
|
-
)
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
// to this
|
|
83
|
-
const WrapperClassed = aggregatedClasses('div')(blockName, null)
|
|
84
|
-
```
|
|
85
|
-
|
|
86
|
-
## Complete example
|
|
87
|
-
before
|
|
88
|
-
```jsx
|
|
89
|
-
import React, { Component } from 'react'
|
|
90
|
-
import getSvgPath from 'components/basic/form/OutlinedInputField/getSvgPath'
|
|
91
|
-
import { convertPropToCssClassName } from '@elliemae/ds-classnames'
|
|
92
|
-
import { DSTextWrapper } from 'components/index'
|
|
93
|
-
|
|
94
|
-
const blockName = 'labeled-outline'
|
|
95
|
-
const pfxBlockName = `em-ds-${blockName}`
|
|
96
|
-
|
|
97
|
-
class DSFloatingLabelInput extends Component {
|
|
98
|
-
constructor(props) {
|
|
99
|
-
super(props)
|
|
100
|
-
this.wrapper = React.createRef()
|
|
101
|
-
this.pathEl = React.createRef()
|
|
102
|
-
this.outlineEl = React.createRef()
|
|
103
|
-
this.outlineIdleEl = React.createRef()
|
|
104
|
-
this.labelEl = React.createRef()
|
|
105
|
-
this.state = {
|
|
106
|
-
open: props.open,
|
|
107
|
-
value: props.value,
|
|
108
|
-
focused: false,
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
componentWillUnmount() {
|
|
112
|
-
window.removeEventListener('resize', this.updatePath)
|
|
113
|
-
}
|
|
114
|
-
get sizes() {
|
|
115
|
-
return {
|
|
116
|
-
labelWidth: this.labelEl.current.offsetWidth * 0.9,
|
|
117
|
-
width: this.wrapper.current.offsetWidth,
|
|
118
|
-
height: this.wrapper.current.offsetHeight,
|
|
119
|
-
radiusStyle: window.getComputedStyle(this.outlineIdleEl.current).getPropertyValue('border-radius'),
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
updatePath() {
|
|
123
|
-
const path = getSvgPath(this.sizes)
|
|
124
|
-
this.pathEl.current.setAttribute('d', path)
|
|
125
|
-
}
|
|
126
|
-
openOutline() {
|
|
127
|
-
this.setState({ open: true })
|
|
128
|
-
}
|
|
129
|
-
closeOutline() {
|
|
130
|
-
this.setState({ open: false })
|
|
131
|
-
}
|
|
132
|
-
render() {
|
|
133
|
-
const {
|
|
134
|
-
className,
|
|
135
|
-
hasError,
|
|
136
|
-
readOnly,
|
|
137
|
-
disabled,
|
|
138
|
-
inputComponent,
|
|
139
|
-
label,
|
|
140
|
-
} = this.props
|
|
141
|
-
const InputComponent = inputComponent
|
|
142
|
-
const { open, focused, value } = this.state
|
|
143
|
-
const isOpen = open || focused || !!value
|
|
144
|
-
|
|
145
|
-
const { cssClassName: classNames } = convertPropToCssClassName(
|
|
146
|
-
blockName,
|
|
147
|
-
className, {
|
|
148
|
-
hasError,
|
|
149
|
-
readOnly,
|
|
150
|
-
disabled,
|
|
151
|
-
})
|
|
152
|
-
return (
|
|
153
|
-
<div
|
|
154
|
-
ref={this.wrapper}
|
|
155
|
-
className={`${classNames} ${isOpen ? `${pfxBlockName}--opened` : ''} ${focused ? `${pfxBlockName}--focused` : ''}`}
|
|
156
|
-
onMouseEnter={this.openOutline}
|
|
157
|
-
onMouseLeave={this.closeOutline}
|
|
158
|
-
>
|
|
159
|
-
<div
|
|
160
|
-
ref={this.outlineEl}
|
|
161
|
-
className={`${pfxBlockName}__outline`}
|
|
162
|
-
>
|
|
163
|
-
<svg>
|
|
164
|
-
<path
|
|
165
|
-
ref={this.pathEl}
|
|
166
|
-
className={`${pfxBlockName}__outline__path`}
|
|
167
|
-
/>
|
|
168
|
-
</svg>
|
|
169
|
-
</div>
|
|
170
|
-
<div
|
|
171
|
-
ref={this.outlineIdleEl}
|
|
172
|
-
className={`${pfxBlockName}__idle`}
|
|
173
|
-
/>
|
|
174
|
-
<div className={`${pfxBlockName}__content`}>
|
|
175
|
-
<InputComponent
|
|
176
|
-
disabled={disabled}
|
|
177
|
-
hasError={hasError}
|
|
178
|
-
onBlur={() => this.setState({ focused: false })}
|
|
179
|
-
onChange={e => this.setState({ value: e.target.value })}
|
|
180
|
-
onFocus={() => this.setState({ focused: true })}
|
|
181
|
-
readOnly={readOnly}
|
|
182
|
-
value={value}
|
|
183
|
-
/>
|
|
184
|
-
<label
|
|
185
|
-
ref={this.labelEl}
|
|
186
|
-
className={`${pfxBlockName}__label ${isOpen ? `${pfxBlockName}__label--floated` : ''}`}
|
|
187
|
-
>
|
|
188
|
-
<DSTextWrapper
|
|
189
|
-
innerRef={this.labelEl}
|
|
190
|
-
maxWidth='20px'
|
|
191
|
-
text={label}
|
|
192
|
-
textEllipsis
|
|
193
|
-
/>
|
|
194
|
-
</label>
|
|
195
|
-
</div>
|
|
196
|
-
</div>
|
|
197
|
-
)
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
export default DSFloatingLabelInput
|
|
202
|
-
|
|
203
|
-
```
|
|
204
|
-
|
|
205
|
-
after
|
|
206
|
-
|
|
207
|
-
```jsx
|
|
208
|
-
import React, { Component } from 'react'
|
|
209
|
-
import getSvgPath from 'components/basic/form/OutlinedInputField/getSvgPath'
|
|
210
|
-
import { DSTextWrapper } from 'components/index'
|
|
211
|
-
import { aggregatedClasses } from '@elliemae/ds-classnames'
|
|
212
|
-
|
|
213
|
-
const blockName = 'labeled-outline'
|
|
214
|
-
|
|
215
|
-
const Wrapper = aggregatedClasses('div')(blockName, null, ({ isOpen, isFocused }) => ({
|
|
216
|
-
opened: isOpen,
|
|
217
|
-
focused: isFocused,
|
|
218
|
-
}))
|
|
219
|
-
|
|
220
|
-
const FloatingLabel = aggregatedClasses('label')(blockName, 'label', ({ isOpen }) => ({
|
|
221
|
-
floated: isOpen,
|
|
222
|
-
}))
|
|
223
|
-
|
|
224
|
-
const OutlineContent = aggregatedClasses('div')(blockName, 'content')
|
|
225
|
-
const OutlineIdle = aggregatedClasses('div')(blockName, 'idle')
|
|
226
|
-
const Outline = aggregatedClasses('div')(blockName, 'outline')
|
|
227
|
-
const OutlinePath = aggregatedClasses('path')(blockName, 'outline__path')
|
|
228
|
-
|
|
229
|
-
class DSFloatingLabelInput extends Component {
|
|
230
|
-
constructor(props) {
|
|
231
|
-
super(props)
|
|
232
|
-
this.wrapper = React.createRef()
|
|
233
|
-
this.pathEl = React.createRef()
|
|
234
|
-
this.outlineEl = React.createRef()
|
|
235
|
-
this.outlineIdleEl = React.createRef()
|
|
236
|
-
this.labelEl = React.createRef()
|
|
237
|
-
this.state = {
|
|
238
|
-
open: props.open,
|
|
239
|
-
value: props.value,
|
|
240
|
-
focused: false,
|
|
241
|
-
}
|
|
242
|
-
}
|
|
243
|
-
componentDidMount() {
|
|
244
|
-
// TODO: not getting referenced elements height / width without this
|
|
245
|
-
// this is a temporary workaround
|
|
246
|
-
setTimeout(() => this.updatePath(), 1)
|
|
247
|
-
window.addEventListener('resize', this.updatePath)
|
|
248
|
-
}
|
|
249
|
-
componentWillUnmount() {
|
|
250
|
-
window.removeEventListener('resize', this.updatePath)
|
|
251
|
-
}
|
|
252
|
-
get sizes() {
|
|
253
|
-
return {
|
|
254
|
-
labelWidth: this.labelEl.current.offsetWidth * 0.9,
|
|
255
|
-
width: this.wrapper.current.offsetWidth,
|
|
256
|
-
height: this.wrapper.current.offsetHeight,
|
|
257
|
-
radiusStyle: window.getComputedStyle(this.outlineIdleEl.current).getPropertyValue('border-radius'),
|
|
258
|
-
}
|
|
259
|
-
}
|
|
260
|
-
updatePath() {
|
|
261
|
-
const path = getSvgPath(this.sizes)
|
|
262
|
-
this.pathEl.current.setAttribute('d', path)
|
|
263
|
-
}
|
|
264
|
-
openOutline() {
|
|
265
|
-
this.setState({ open: true })
|
|
266
|
-
}
|
|
267
|
-
closeOutline() {
|
|
268
|
-
this.setState({ open: false })
|
|
269
|
-
}
|
|
270
|
-
render() {
|
|
271
|
-
const {
|
|
272
|
-
hasError,
|
|
273
|
-
readOnly,
|
|
274
|
-
disabled,
|
|
275
|
-
inputComponent,
|
|
276
|
-
label,
|
|
277
|
-
} = this.props
|
|
278
|
-
const InputComponent = inputComponent
|
|
279
|
-
const { open, focused, value } = this.state
|
|
280
|
-
const isOpen = open || focused || !!value
|
|
281
|
-
|
|
282
|
-
return (
|
|
283
|
-
<Wrapper
|
|
284
|
-
classProps={{ hasError, isOpen, isFocused: focused, readOnly, disabled }}
|
|
285
|
-
innerRef={this.wrapper}
|
|
286
|
-
onMouseEnter={this.openOutline}
|
|
287
|
-
onMouseLeave={this.closeOutline}
|
|
288
|
-
>
|
|
289
|
-
<Outline innerRef={this.outlineEl}>
|
|
290
|
-
<svg>
|
|
291
|
-
<OutlinePath innerRef={this.pathEl} />
|
|
292
|
-
</svg>
|
|
293
|
-
</Outline>
|
|
294
|
-
<OutlineIdle innerRef={this.outlineIdleEl} />
|
|
295
|
-
<OutlineContent>
|
|
296
|
-
<InputComponent
|
|
297
|
-
disabled={disabled}
|
|
298
|
-
hasError={hasError}
|
|
299
|
-
onBlur={() => this.setState({ focused: false })}
|
|
300
|
-
onChange={e => this.setState({ value: e.target.value })}
|
|
301
|
-
onFocus={() => this.setState({ focused: true })}
|
|
302
|
-
readOnly={readOnly}
|
|
303
|
-
value={value}
|
|
304
|
-
/>
|
|
305
|
-
<FloatingLabel
|
|
306
|
-
classProps={{ isOpen }}
|
|
307
|
-
innerRef={this.labelEl}
|
|
308
|
-
>
|
|
309
|
-
<DSTextWrapper
|
|
310
|
-
maxWidth='20px'
|
|
311
|
-
text={label}
|
|
312
|
-
textEllipsis
|
|
313
|
-
/>
|
|
314
|
-
</FloatingLabel>
|
|
315
|
-
</OutlineContent>
|
|
316
|
-
</Wrapper>
|
|
317
|
-
)
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
|
|
321
|
-
export default DSFloatingLabelInput
|
|
322
|
-
|
|
323
|
-
```
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var classNameManager_exports = {};
|
|
30
|
-
__export(classNameManager_exports, {
|
|
31
|
-
convertPropToCssClassName: () => cssPipeline,
|
|
32
|
-
cssPrefix: () => cssPrefix,
|
|
33
|
-
default: () => classNameManager_default
|
|
34
|
-
});
|
|
35
|
-
module.exports = __toCommonJS(classNameManager_exports);
|
|
36
|
-
var React = __toESM(require("react"));
|
|
37
|
-
var import_ds_utilities = require("@elliemae/ds-utilities");
|
|
38
|
-
var import_dimsum_config = require("./dimsum.config.js");
|
|
39
|
-
var import_converPropsToFormModifiers = require("./converPropsToFormModifiers.js");
|
|
40
|
-
var import_convertPropsToLayoutModifiers = require("./convertPropsToLayoutModifiers.js");
|
|
41
|
-
var import_convertPropToFeedBackModifiers = require("./convertPropToFeedBackModifiers.js");
|
|
42
|
-
var import_convertPropsToSizeModifiers = require("./convertPropsToSizeModifiers.js");
|
|
43
|
-
var import_convertPropsToTextModifiers = require("./convertPropsToTextModifiers.js");
|
|
44
|
-
var import_convertPropsToColorModifiers = require("./convertPropsToColorModifiers.js");
|
|
45
|
-
const cssPrefix = `${import_dimsum_config.dimsumConfig.classNamePrefix}-`;
|
|
46
|
-
const executePipelines = (props) => {
|
|
47
|
-
const form = (0, import_converPropsToFormModifiers.pipe)().execute(props);
|
|
48
|
-
const layout = (0, import_convertPropsToLayoutModifiers.pipe)().execute(props);
|
|
49
|
-
const feedback = (0, import_convertPropToFeedBackModifiers.pipe)().execute(props);
|
|
50
|
-
const size = (0, import_convertPropsToSizeModifiers.pipe)().execute(props);
|
|
51
|
-
const text = (0, import_convertPropsToTextModifiers.pipe)().execute(props);
|
|
52
|
-
const color = (0, import_convertPropsToColorModifiers.pipe)().execute(props);
|
|
53
|
-
return [...form, ...layout, ...feedback, ...size, ...text, ...color];
|
|
54
|
-
};
|
|
55
|
-
const cssPipeline = (blockName = "block", cssClassNameModifier = "", props = {}, options = {}) => {
|
|
56
|
-
const { prefix, element } = options;
|
|
57
|
-
const prefixBlockName = `${prefix || cssPrefix}${blockName}${element ? `__${element}` : ""}`;
|
|
58
|
-
const pipes = !(0, import_ds_utilities.isEmpty)(props) ? executePipelines(props) : [];
|
|
59
|
-
const basePipeline = [prefixBlockName, ...pipes];
|
|
60
|
-
const className = cssClassNameModifier ? [...basePipeline].join(` ${prefixBlockName}--`).concat(` ${cssClassNameModifier}`) : [...basePipeline].join(` ${prefixBlockName}--`);
|
|
61
|
-
return {
|
|
62
|
-
blockName,
|
|
63
|
-
cssPrefix,
|
|
64
|
-
prefixBlockName,
|
|
65
|
-
cssClassName: className,
|
|
66
|
-
mainModifier(modifier) {
|
|
67
|
-
return `${className}--${modifier}`;
|
|
68
|
-
},
|
|
69
|
-
classNameBlock(elementName, usePrefix = true) {
|
|
70
|
-
return `${!usePrefix ? blockName : prefixBlockName}-${elementName}`;
|
|
71
|
-
},
|
|
72
|
-
classNameBlockModifier(modifierName, elementBlockName = "") {
|
|
73
|
-
return `${prefixBlockName}-${elementBlockName}--${modifierName}`;
|
|
74
|
-
},
|
|
75
|
-
classNameElement(elementName, elementBlockName = "") {
|
|
76
|
-
return `${prefixBlockName}${elementBlockName ? `-${elementBlockName}` : ""}__${elementName}`;
|
|
77
|
-
},
|
|
78
|
-
classNameModifier(modifierName, elementName = "") {
|
|
79
|
-
return `${prefixBlockName}${elementName ? `__${elementName}` : ""}--${modifierName}`;
|
|
80
|
-
}
|
|
81
|
-
};
|
|
82
|
-
};
|
|
83
|
-
var classNameManager_default = cssPipeline;
|
|
84
|
-
//# sourceMappingURL=classNameManager.js.map
|