@procore/storybook-addon 0.3.1 → 2.0.0

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 (30) hide show
  1. package/README.md +14 -7
  2. package/dist/asset/procoreLogo.d.ts.map +1 -0
  3. package/dist/configurations/previewHead.d.ts.map +1 -0
  4. package/dist/{packages/storybook-addon/src/configurations → configurations}/theme.d.ts +1 -1
  5. package/dist/configurations/theme.d.ts.map +1 -0
  6. package/dist/constant/external-urls.d.ts.map +1 -0
  7. package/dist/index.d.ts +4 -0
  8. package/dist/index.d.ts.map +1 -0
  9. package/dist/index.js +1 -0
  10. package/dist/index.mjs +11 -0
  11. package/dist/preset.d.ts +22 -0
  12. package/dist/preset.d.ts.map +1 -0
  13. package/dist/preset.js +29 -0
  14. package/dist/preset.mjs +92 -0
  15. package/dist/utils/index.d.ts +2 -0
  16. package/dist/utils/index.d.ts.map +1 -0
  17. package/package.json +50 -35
  18. package/preset.js +2 -0
  19. package/dist/packages/storybook-addon/src/asset/procoreLogo.d.ts.map +0 -1
  20. package/dist/packages/storybook-addon/src/configurations/previewHead.d.ts.map +0 -1
  21. package/dist/packages/storybook-addon/src/configurations/theme.d.ts.map +0 -1
  22. package/dist/packages/storybook-addon/src/constant/external-urls.d.ts.map +0 -1
  23. package/dist/packages/storybook-addon/src/index.d.ts +0 -24
  24. package/dist/packages/storybook-addon/src/index.d.ts.map +0 -1
  25. package/dist/packages/storybook-addon/src/typings/index.d.ts +0 -4
  26. package/dist/storybook-addon.es.js +0 -4887
  27. package/dist/storybook-addon.umd.js +0 -251
  28. /package/dist/{packages/storybook-addon/src/asset → asset}/procoreLogo.d.ts +0 -0
  29. /package/dist/{packages/storybook-addon/src/configurations → configurations}/previewHead.d.ts +0 -0
  30. /package/dist/{packages/storybook-addon/src/constant → constant}/external-urls.d.ts +0 -0
package/README.md CHANGED
@@ -36,9 +36,9 @@ This simple addon adds 3 main addon used across different apps at Procore.
36
36
  In order to set the theme by default values ${\text{\color{green}{createProcoreTheme}}}$ needs to be added in `manager.js`. If no parameter has been passed to the `createProcoreTheme` the aforementioned default values will be set.
37
37
 
38
38
  ```tsx
39
- // .storybook/YourTheme.js
39
+ // .storybook/manager.js
40
40
  import { createProcoreTheme } from '@procore/storybook-addon';
41
- import { addons } from '@storybook/addons';
41
+ import { addons } from '@storybook/manager-api';
42
42
 
43
43
  addons.setConfig({
44
44
  theme: createProcoreTheme(),
@@ -48,10 +48,10 @@ addons.setConfig({
48
48
  For more configuration please visit: https://storybook.js.org/docs/react/configure/theming
49
49
 
50
50
  ```tsx
51
- // .storybook/YourTheme.js
51
+ // .storybook/manager.js
52
52
  // example below will override Procore default theming configuration
53
- import { createProcoreTheme } from '@procore/storybook-addon'
54
- import { addons } from '@storybook/addons'
53
+ import { createProcoreTheme } from '@procore/storybook-addon';
54
+ import { addons } from '@storybook/manager-api';
55
55
 
56
56
  addons.setConfig({
57
57
  theme: createProcoreTheme({
@@ -60,7 +60,8 @@ addons.setConfig({
60
60
  brandUrl: 'https://example.com',
61
61
  brandImage: 'https://place-hold.it/350x150',
62
62
  brandTarget: '_self',
63
- });
63
+ }),
64
+ });
64
65
  ```
65
66
 
66
67
  </details>
@@ -90,10 +91,16 @@ function ExampleRequest() {
90
91
  <details>
91
92
  <summary>Extensions and Rules</summary>
92
93
 
93
- this library by default supports: ['.ts', '.tsx', '.js', '.jsx', '.css', '.scss'] extensions and adds css-loader as a rule to config module.
94
+ this library by default supports: ['.ts', '.tsx', '.js', '.jsx', '.css'] extensions and adds css-loader as a rule to config module.
95
+
96
+ To enable `.scss` support - install `sass` module. Addon checks if `sass` is present in `node_modules`.
94
97
 
95
98
  This library also adds basic ${\text{\color{green}{Typescript}}}$ configs.
96
99
 
97
100
  Please refer to [Storybook Docs](https://storybook.js.org/docs/react/configure/overview) to override or add more configurations.
98
101
 
99
102
  </details>
103
+
104
+ ## Testing
105
+
106
+ This addon should be tested by running `storybook` in `example-apps/react-ts` and `example-apps/react-core-scripts` apps.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"procoreLogo.d.ts","sourceRoot":"","sources":["../../src/asset/procoreLogo.ts"],"names":[],"mappings":";AAAA,wBAAg0F"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"previewHead.d.ts","sourceRoot":"","sources":["../../src/configurations/previewHead.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAMhD,MAAM,CAAC,OAAO,WACZ,IAAI,EAAE,GAAG,EACT,QAAQ,CAAC,EAAE,MAAM,CAAC,WAAW,EAAE,GAAG,CAAC,EACnC,UAAU,CAAC,EAAE,kBAAkB,UAuChC"}
@@ -1,3 +1,3 @@
1
1
  import type { ThemeVars } from '@storybook/theming';
2
- export declare const createProcoreTheme: (vars?: Partial<ThemeVars> | undefined) => ThemeVars;
2
+ export declare const createProcoreTheme: (vars?: Partial<ThemeVars>) => ThemeVars;
3
3
  //# sourceMappingURL=theme.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../src/configurations/theme.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAIpD,eAAO,MAAM,kBAAkB,UAAW,QAAQ,SAAS,CAAC,cAO3D,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"external-urls.d.ts","sourceRoot":"","sources":["../../src/constant/external-urls.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ,+BAA+B,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { createProcoreTheme } from './configurations/theme';
2
+ declare const _default: {};
3
+ export default _default;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;;AAG5D,wBAAkB"}
package/dist/index.js ADDED
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const A=require("@storybook/theming"),g="",U="https://design.procore.com",C=o=>A.create({base:"light",brandUrl:U,brandImage:g,...o}),K={};exports.createProcoreTheme=C;exports.default=K;
package/dist/index.mjs ADDED
@@ -0,0 +1,11 @@
1
+ import { create as o } from "@storybook/theming";
2
+ const g = "", U = "https://design.procore.com", K = (A) => o({
3
+ base: "light",
4
+ brandUrl: U,
5
+ brandImage: g,
6
+ ...A
7
+ }), F = {};
8
+ export {
9
+ K as createProcoreTheme,
10
+ F as default
11
+ };
@@ -0,0 +1,22 @@
1
+ import previewHead from './configurations/previewHead';
2
+ export declare const addons: () => (string | {
3
+ name: string;
4
+ options: {
5
+ cssModules: {
6
+ localIdentName: string;
7
+ };
8
+ sass?: {
9
+ implementation: any;
10
+ } | undefined;
11
+ };
12
+ })[];
13
+ export declare function babelDefault(config: any): any;
14
+ export declare const typescript: {
15
+ checkOptions: {
16
+ check: boolean;
17
+ exclude: RegExp;
18
+ };
19
+ reactDocgen: boolean;
20
+ };
21
+ export { previewHead };
22
+ //# sourceMappingURL=preset.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"preset.d.ts","sourceRoot":"","sources":["../src/preset.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,8BAA8B,CAAC;AAIvD,eAAO,MAAM,MAAM;;;;;;;;;;IAqBlB,CAAC;AAEF,wBAAgB,YAAY,CAAC,MAAM,EAAE,GAAG,OAsBvC;AAED,eAAO,MAAM,UAAU;;;;;;CAMtB,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,CAAC"}
package/dist/preset.js ADDED
@@ -0,0 +1,29 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i={includeBoxSizing:!0};function r(e,t,s){const{includeBoxSizing:o=!0}={...i,...s};return`
2
+ ${e}
3
+ <meta charset="UTF-8" />
4
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
5
+ <link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap">
6
+
7
+ <style>
8
+ ${o?`
9
+ *,
10
+ *:before,
11
+ *:after {
12
+ -webkit-box-sizing: inherit;
13
+ -moz-box-sizing: inherit;
14
+ box-sizing: inherit;
15
+ }
16
+ html {
17
+ -webkit-box-sizing: border-box;
18
+ -moz-box-sizing: border-box;
19
+ box-sizing: border-box;
20
+ }
21
+ `:""}
22
+ html {
23
+ font-family: Inter, sans-serif;
24
+ }
25
+ body {
26
+ width: 100%;
27
+ }
28
+ </style>
29
+ `}function n(e){try{return require(e)}catch{return}}const c=require("find-babel-config"),a=()=>{const e=n("sass");return[{name:"@storybook/addon-styling",options:{...e?{sass:{implementation:e}}:{},cssModules:{localIdentName:"[name]__[local]--[hash:base64:5]"}}},"@storybook/addon-essentials","@storybook/addon-storysource","@storybook/addon-a11y"]};function l(e){const t=process.cwd(),{file:s}=c.sync(t,1);if(s)return e;{const o=n("@procore/core-scripts/dist/babel/config");if(o!=null&&o.createConfigForReact)return console.log("\x1B[32minfo\x1B[0m @procore/storybook-addon => Using @procore/core-scripts babel config"),o.createConfigForReact({})}return e}const d={checkOptions:{check:!0,exclude:/node_modules/},reactDocgen:!1};exports.addons=a;exports.babelDefault=l;exports.previewHead=r;exports.typescript=d;
@@ -0,0 +1,92 @@
1
+ const i = {
2
+ includeBoxSizing: !0
3
+ };
4
+ function c(e, t, s) {
5
+ const { includeBoxSizing: o = !0 } = {
6
+ ...i,
7
+ ...s
8
+ };
9
+ return `
10
+ ${e}
11
+ <meta charset="UTF-8" />
12
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
13
+ <link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap">
14
+
15
+ <style>
16
+ ${o ? `
17
+ *,
18
+ *:before,
19
+ *:after {
20
+ -webkit-box-sizing: inherit;
21
+ -moz-box-sizing: inherit;
22
+ box-sizing: inherit;
23
+ }
24
+ html {
25
+ -webkit-box-sizing: border-box;
26
+ -moz-box-sizing: border-box;
27
+ box-sizing: border-box;
28
+ }
29
+ ` : ""}
30
+ html {
31
+ font-family: Inter, sans-serif;
32
+ }
33
+ body {
34
+ width: 100%;
35
+ }
36
+ </style>
37
+ `;
38
+ }
39
+ function n(e) {
40
+ try {
41
+ return require(e);
42
+ } catch {
43
+ return;
44
+ }
45
+ }
46
+ const r = require("find-babel-config"), a = () => {
47
+ const e = n("sass");
48
+ return [
49
+ {
50
+ name: "@storybook/addon-styling",
51
+ options: {
52
+ ...e ? {
53
+ sass: {
54
+ implementation: e
55
+ }
56
+ } : {},
57
+ cssModules: { localIdentName: "[name]__[local]--[hash:base64:5]" }
58
+ }
59
+ },
60
+ "@storybook/addon-essentials",
61
+ "@storybook/addon-storysource",
62
+ "@storybook/addon-a11y"
63
+ ];
64
+ };
65
+ function l(e) {
66
+ const t = process.cwd(), { file: s } = r.sync(t, 1);
67
+ if (s)
68
+ return e;
69
+ {
70
+ const o = n(
71
+ "@procore/core-scripts/dist/babel/config"
72
+ );
73
+ if (o != null && o.createConfigForReact)
74
+ return console.log(
75
+ "\x1B[32minfo\x1B[0m @procore/storybook-addon => Using @procore/core-scripts babel config"
76
+ ), o.createConfigForReact({});
77
+ }
78
+ return e;
79
+ }
80
+ const d = {
81
+ checkOptions: {
82
+ check: !0,
83
+ exclude: /node_modules/
84
+ },
85
+ reactDocgen: !1
86
+ };
87
+ export {
88
+ a as addons,
89
+ l as babelDefault,
90
+ c as previewHead,
91
+ d as typescript
92
+ };
@@ -0,0 +1,2 @@
1
+ export declare function requireIfExists(moduleName: string): any;
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,OAMjD"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@procore/storybook-addon",
3
- "version": "0.3.1",
3
+ "version": "2.0.0",
4
4
  "description": "Procore Storybook Configuration",
5
5
  "author": "Procore Technologies",
6
6
  "homepage": "https://github.com/procore/frontend-tooling#readme",
@@ -20,13 +20,19 @@
20
20
  },
21
21
  "exports": {
22
22
  ".": {
23
- "import": "./dist/storybook-addon.es.js",
24
- "require": "./dist/storybook-addon.umd.js"
23
+ "require": "./dist/index.js",
24
+ "import": "./dist/index.mjs",
25
+ "types": "./dist/index.d.ts"
26
+ },
27
+ "./preset": {
28
+ "require": "./dist/preset.js",
29
+ "import": "./dist/preset.mjs",
30
+ "types": "./dist/preset.d.ts"
25
31
  }
26
32
  },
27
- "main": "./dist/storybook-addon.umd.js",
28
- "module": "./dist/storybook-addon.es.js",
29
- "types": "./dist/packages/storybook-addon/src/index.d.ts",
33
+ "main": "dist/index.js",
34
+ "module": "dist/index.mjs",
35
+ "types": "dist/index.d.ts",
30
36
  "files": [
31
37
  "dist",
32
38
  "LICENSE",
@@ -34,39 +40,48 @@
34
40
  "*.js",
35
41
  "*.d.ts"
36
42
  ],
37
- "peerDependencies": {
38
- "react": "^17.0.1 || ^18.0.0",
39
- "react-dom": "^17.0.1 || ^18.0.0"
43
+ "scripts": {
44
+ "build": "vite build",
45
+ "build:release": "yarn build",
46
+ "format": "prettier --ignore-unknown --write .",
47
+ "format:check": "prettier --cache --ignore-unknown --check .",
48
+ "test": "vitest run --passWithNoTests --coverage"
40
49
  },
41
50
  "dependencies": {
42
- "@storybook/addon-a11y": "^6.5.16",
43
- "@storybook/addon-essentials": "^6.5.16",
44
- "@storybook/addon-storysource": "^6.5.16",
45
- "@storybook/preset-scss": "^1.0.3"
51
+ "@storybook/addon-a11y": "^7.1.1",
52
+ "@storybook/addon-essentials": "^7.1.1",
53
+ "@storybook/addon-storysource": "^7.1.1",
54
+ "@storybook/addon-styling": "^1.3.4",
55
+ "@storybook/theming": "^7.1.1",
56
+ "find-babel-config": "^2.0.0"
57
+ },
58
+ "peerDependencies": {
59
+ "@procore/core-scripts": "*",
60
+ "sass": "^1.3.0"
61
+ },
62
+ "peerDependenciesMeta": {
63
+ "sass": {
64
+ "optional": true
65
+ },
66
+ "@procore/core-scripts": {
67
+ "optional": true
68
+ }
46
69
  },
47
70
  "devDependencies": {
48
- "@babel/core": "^7.21.4",
49
- "@storybook/core-webpack": "7.0.0-alpha.0",
50
- "@storybook/theming": "^6.5.16",
51
- "css-loader": "^6.7.3",
52
- "eslint": "^8.37.0",
53
- "prettier": "^2.8.7",
54
- "react": "^17.0.2",
55
- "react-dom": "^17.0.2",
71
+ "@babel/core": "^7.22.9",
72
+ "@procore/prettier-config": "1.0.0",
73
+ "@procore/typescript-config": "1.0.0",
74
+ "@procore/vite": "1.1.0",
75
+ "@storybook/react": "^7.1.1",
76
+ "@storybook/react-webpack5": "^7.1.1",
77
+ "@types/react": "^18.2.16",
78
+ "@vitest/coverage-c8": "^0.31.4",
79
+ "eslint": "^8.45.0",
80
+ "prettier": "^2.8.8",
56
81
  "rimraf": "^3.0.2",
57
- "sass-loader": "^11.1.1",
58
- "style-loader": "^3.3.2",
59
82
  "typescript": "^4.9.5",
60
- "vite": "^3.2.5",
61
- "webpack": "^5.77.0",
62
- "@procore/typescript-config": "1.0.0",
63
- "@procore/prettier-config": "1.0.0",
64
- "@procore/vite": "1.0.0"
65
- },
66
- "scripts": {
67
- "build": "vite build",
68
- "format": "prettier --ignore-unknown --write .",
69
- "format:check": "prettier --cache --ignore-unknown --check .",
70
- "test": "echo \"no test has been specified\" && exit 0"
83
+ "vite": "^4.4.7",
84
+ "vite-plugin-dts": "^3.3.1",
85
+ "vitest": "^0.32.4"
71
86
  }
72
- }
87
+ }
package/preset.js ADDED
@@ -0,0 +1,2 @@
1
+ // @ts-ignore
2
+ export * from './dist/preset.mjs';
@@ -1 +0,0 @@
1
- {"version":3,"file":"procoreLogo.d.ts","sourceRoot":"","sources":["procoreLogo.ts"],"names":[],"mappings":";AAAA,wBAAg0F"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"previewHead.d.ts","sourceRoot":"","sources":["previewHead.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAMhD,MAAM,CAAC,OAAO,WACZ,IAAI,EAAE,GAAG,EACT,QAAQ,CAAC,EAAE,MAAM,CAAC,WAAW,EAAE,GAAG,CAAC,EACnC,UAAU,CAAC,EAAE,kBAAkB,UAuChC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["theme.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAIpD,eAAO,MAAM,kBAAkB,sDAO9B,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"external-urls.d.ts","sourceRoot":"","sources":["external-urls.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ,+BAA+B,CAAC"}
@@ -1,24 +0,0 @@
1
- import previewHead from './configurations/previewHead';
2
- export { createProcoreTheme } from './configurations/theme';
3
- declare const _default: {
4
- previewHead: typeof previewHead;
5
- addons: (string | {
6
- name: string;
7
- options: {
8
- cssLoaderOptions: {
9
- modules: {
10
- localIdentName: string;
11
- };
12
- };
13
- };
14
- })[];
15
- typescript: {
16
- checkOptions: {
17
- check: boolean;
18
- exclude: RegExp;
19
- };
20
- reactDocgen: boolean;
21
- };
22
- };
23
- export default _default;
24
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,8BAA8B,CAAC;AAEvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;;;;;;;;;;;;;;AAE5D,wBAyBE"}
@@ -1,4 +0,0 @@
1
- export interface PreviewHeadOptions {
2
- includeBoxSizing?: boolean;
3
- extraPreviewHeadstyle?: string;
4
- }