@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.
Files changed (58) hide show
  1. package/dist/cjs/index.js +2 -11
  2. package/dist/cjs/index.js.map +2 -2
  3. package/dist/esm/index.js +1 -7
  4. package/dist/esm/index.js.map +3 -3
  5. package/dist/types/index.d.ts +1 -2
  6. package/package.json +8 -45
  7. package/dist/cjs/aggregatedClasses.js +0 -87
  8. package/dist/cjs/aggregatedClasses.js.map +0 -7
  9. package/dist/cjs/aggregatedClasses.md +0 -323
  10. package/dist/cjs/classNameManager.js +0 -84
  11. package/dist/cjs/classNameManager.js.map +0 -7
  12. package/dist/cjs/converPropsToFormModifiers.js +0 -59
  13. package/dist/cjs/converPropsToFormModifiers.js.map +0 -7
  14. package/dist/cjs/convertPropToFeedBackModifiers.js +0 -61
  15. package/dist/cjs/convertPropToFeedBackModifiers.js.map +0 -7
  16. package/dist/cjs/convertPropsToColorModifiers.js +0 -59
  17. package/dist/cjs/convertPropsToColorModifiers.js.map +0 -7
  18. package/dist/cjs/convertPropsToLayoutModifiers.js +0 -61
  19. package/dist/cjs/convertPropsToLayoutModifiers.js.map +0 -7
  20. package/dist/cjs/convertPropsToSizeModifiers.js +0 -78
  21. package/dist/cjs/convertPropsToSizeModifiers.js.map +0 -7
  22. package/dist/cjs/convertPropsToTextModifiers.js +0 -59
  23. package/dist/cjs/convertPropsToTextModifiers.js.map +0 -7
  24. package/dist/cjs/dimsum.config.js +0 -38
  25. package/dist/cjs/dimsum.config.js.map +0 -7
  26. package/dist/cjs/validateNativeProps.js +0 -430
  27. package/dist/cjs/validateNativeProps.js.map +0 -7
  28. package/dist/esm/aggregatedClasses.js +0 -60
  29. package/dist/esm/aggregatedClasses.js.map +0 -7
  30. package/dist/esm/aggregatedClasses.md +0 -323
  31. package/dist/esm/classNameManager.js +0 -54
  32. package/dist/esm/classNameManager.js.map +0 -7
  33. package/dist/esm/converPropsToFormModifiers.js +0 -29
  34. package/dist/esm/converPropsToFormModifiers.js.map +0 -7
  35. package/dist/esm/convertPropToFeedBackModifiers.js +0 -31
  36. package/dist/esm/convertPropToFeedBackModifiers.js.map +0 -7
  37. package/dist/esm/convertPropsToColorModifiers.js +0 -29
  38. package/dist/esm/convertPropsToColorModifiers.js.map +0 -7
  39. package/dist/esm/convertPropsToLayoutModifiers.js +0 -31
  40. package/dist/esm/convertPropsToLayoutModifiers.js.map +0 -7
  41. package/dist/esm/convertPropsToSizeModifiers.js +0 -48
  42. package/dist/esm/convertPropsToSizeModifiers.js.map +0 -7
  43. package/dist/esm/convertPropsToTextModifiers.js +0 -29
  44. package/dist/esm/convertPropsToTextModifiers.js.map +0 -7
  45. package/dist/esm/dimsum.config.js +0 -8
  46. package/dist/esm/dimsum.config.js.map +0 -7
  47. package/dist/esm/validateNativeProps.js +0 -400
  48. package/dist/esm/validateNativeProps.js.map +0 -7
  49. package/dist/types/aggregatedClasses.d.ts +0 -11
  50. package/dist/types/classNameManager.d.ts +0 -28
  51. package/dist/types/converPropsToFormModifiers.d.ts +0 -15
  52. package/dist/types/convertPropToFeedBackModifiers.d.ts +0 -17
  53. package/dist/types/convertPropsToColorModifiers.d.ts +0 -11
  54. package/dist/types/convertPropsToLayoutModifiers.d.ts +0 -17
  55. package/dist/types/convertPropsToSizeModifiers.d.ts +0 -25
  56. package/dist/types/convertPropsToTextModifiers.d.ts +0 -15
  57. package/dist/types/dimsum.config.d.ts +0 -4
  58. 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
- var import_classNameManager = __toESM(require("./classNameManager.js"));
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
@@ -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 { default as convertPropToCssClassName, cssPrefix } from './classNameManager.js';\nexport { default as aggregatedClasses } from './aggregatedClasses.js';\n", "import * as React from 'react';\nexport { React };\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADAvB,8BAAgE;AAChE,+BAA6C;",
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
- import { default as default2, cssPrefix } from "./classNameManager.js";
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
@@ -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 { default as convertPropToCssClassName, cssPrefix } from './classNameManager.js';\nexport { default as aggregatedClasses } from './aggregatedClasses.js';\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACAvB,SAAoB,WAAXA,UAAsC,iBAAiB;AAChE,SAAoB,WAAXA,gBAAoC;",
6
- "names": ["default"]
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
  }
@@ -1,2 +1 @@
1
- export { default as convertPropToCssClassName, cssPrefix } from './classNameManager.js';
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.26.1-rc.1",
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
- "obj-str": "~1.1.0",
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.26.1-rc.1"
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": "pui-cli test --passWithNoTests",
93
- "lint": "node ../../../scripts/lint.mjs",
94
- "eslint:fix": "eslint --ext='.js,.jsx,.test.js,.ts,.tsx' --fix --config='../../../.eslintrc.js' src/",
95
- "dts": "node ../../../scripts/dts.mjs",
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": "npm exec ../../util/ds-codemods -- check-missing-packages --projectFolderPath=\"./\" --ignorePackagesGlobPattern=\"\" --ignoreFilesGlobPattern=\"**/test-ables/*,**/tests/*\"",
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