@webiny/app 5.15.0-beta.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 (127) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +19 -0
  3. package/apollo-client/InMemoryCache.d.ts +7 -0
  4. package/apollo-client/InMemoryCache.js +60 -0
  5. package/apollo-client/InMemoryCache.js.map +1 -0
  6. package/components/Image.d.ts +3 -0
  7. package/components/Image.js +29 -0
  8. package/components/Image.js.map +1 -0
  9. package/components/Routes.d.ts +2 -0
  10. package/components/Routes.js +36 -0
  11. package/components/Routes.js.map +1 -0
  12. package/components/View.d.ts +8 -0
  13. package/components/View.js +24 -0
  14. package/components/View.js.map +1 -0
  15. package/components/index.d.ts +1 -0
  16. package/components/index.js +2 -0
  17. package/components/index.js.map +1 -0
  18. package/contexts/Ui/index.d.ts +27 -0
  19. package/contexts/Ui/index.js +70 -0
  20. package/contexts/Ui/index.js.map +1 -0
  21. package/hooks/useAutocomplete/index.d.ts +1 -0
  22. package/hooks/useAutocomplete/index.js +2 -0
  23. package/hooks/useAutocomplete/index.js.map +1 -0
  24. package/hooks/useAutocomplete/useAutocomplete.d.ts +6 -0
  25. package/hooks/useAutocomplete/useAutocomplete.js +28 -0
  26. package/hooks/useAutocomplete/useAutocomplete.js.map +1 -0
  27. package/hooks/useDataList/functions/getData.d.ts +2 -0
  28. package/hooks/useDataList/functions/getData.js +5 -0
  29. package/hooks/useDataList/functions/getData.js.map +1 -0
  30. package/hooks/useDataList/functions/getError.d.ts +2 -0
  31. package/hooks/useDataList/functions/getError.js +5 -0
  32. package/hooks/useDataList/functions/getError.js.map +1 -0
  33. package/hooks/useDataList/functions/getMeta.d.ts +2 -0
  34. package/hooks/useDataList/functions/getMeta.js +5 -0
  35. package/hooks/useDataList/functions/getMeta.js.map +1 -0
  36. package/hooks/useDataList/functions/index.d.ts +3 -0
  37. package/hooks/useDataList/functions/index.js +4 -0
  38. package/hooks/useDataList/functions/index.js.map +1 -0
  39. package/hooks/useDataList/functions/searchDataByKey.d.ts +2 -0
  40. package/hooks/useDataList/functions/searchDataByKey.js +22 -0
  41. package/hooks/useDataList/functions/searchDataByKey.js.map +1 -0
  42. package/hooks/useDataList/index.d.ts +1 -0
  43. package/hooks/useDataList/index.js +2 -0
  44. package/hooks/useDataList/index.js.map +1 -0
  45. package/hooks/useDataList/useDataList.d.ts +36 -0
  46. package/hooks/useDataList/useDataList.js +194 -0
  47. package/hooks/useDataList/useDataList.js.map +1 -0
  48. package/hooks/useDataList/utils/index.d.ts +2 -0
  49. package/hooks/useDataList/utils/index.js +3 -0
  50. package/hooks/useDataList/utils/index.js.map +1 -0
  51. package/hooks/useDataList/utils/prepareLoadListParams.d.ts +4 -0
  52. package/hooks/useDataList/utils/prepareLoadListParams.js +35 -0
  53. package/hooks/useDataList/utils/prepareLoadListParams.js.map +1 -0
  54. package/hooks/useDataList/utils/redirectToRouteWithQueryParams.d.ts +5 -0
  55. package/hooks/useDataList/utils/redirectToRouteWithQueryParams.js +23 -0
  56. package/hooks/useDataList/utils/redirectToRouteWithQueryParams.js.map +1 -0
  57. package/hooks/useDataList/utils/types.d.ts +34 -0
  58. package/hooks/useDataList/utils/types.js +2 -0
  59. package/hooks/useDataList/utils/types.js.map +1 -0
  60. package/hooks/useHandler.d.ts +1 -0
  61. package/hooks/useHandler.js +13 -0
  62. package/hooks/useHandler.js.map +1 -0
  63. package/hooks/useHandlers.d.ts +11 -0
  64. package/hooks/useHandlers.js +20 -0
  65. package/hooks/useHandlers.js.map +1 -0
  66. package/hooks/useUi.d.ts +2 -0
  67. package/hooks/useUi.js +6 -0
  68. package/hooks/useUi.js.map +1 -0
  69. package/i18n/i18n.d.ts +2 -0
  70. package/i18n/i18n.js +6 -0
  71. package/i18n/i18n.js.map +1 -0
  72. package/i18n/index.d.ts +1 -0
  73. package/i18n/index.js +2 -0
  74. package/i18n/index.js.map +1 -0
  75. package/package.json +70 -0
  76. package/plugins/AddQuerySelectionPlugin.d.ts +15 -0
  77. package/plugins/AddQuerySelectionPlugin.js +102 -0
  78. package/plugins/AddQuerySelectionPlugin.js.map +1 -0
  79. package/plugins/ApolloCacheObjectIdPlugin.d.ts +15 -0
  80. package/plugins/ApolloCacheObjectIdPlugin.js +41 -0
  81. package/plugins/ApolloCacheObjectIdPlugin.js.map +1 -0
  82. package/plugins/ApolloDynamicLink.d.ts +5 -0
  83. package/plugins/ApolloDynamicLink.js +63 -0
  84. package/plugins/ApolloDynamicLink.js.map +1 -0
  85. package/plugins/ApolloLinkPlugin.d.ts +12 -0
  86. package/plugins/ApolloLinkPlugin.js +41 -0
  87. package/plugins/ApolloLinkPlugin.js.map +1 -0
  88. package/plugins/ConsoleLinkPlugin.d.ts +8 -0
  89. package/plugins/ConsoleLinkPlugin.js +48 -0
  90. package/plugins/ConsoleLinkPlugin.js.map +1 -0
  91. package/plugins/LocaleHeaderLinkPlugin.d.ts +14 -0
  92. package/plugins/LocaleHeaderLinkPlugin.js +62 -0
  93. package/plugins/LocaleHeaderLinkPlugin.js.map +1 -0
  94. package/plugins/NetworkErrorLinkPlugin/ErrorOverlay.d.ts +6 -0
  95. package/plugins/NetworkErrorLinkPlugin/ErrorOverlay.js +77 -0
  96. package/plugins/NetworkErrorLinkPlugin/ErrorOverlay.js.map +1 -0
  97. package/plugins/NetworkErrorLinkPlugin/StyledComponents.d.ts +3 -0
  98. package/plugins/NetworkErrorLinkPlugin/StyledComponents.js +10 -0
  99. package/plugins/NetworkErrorLinkPlugin/StyledComponents.js.map +1 -0
  100. package/plugins/NetworkErrorLinkPlugin/assets/close_24px.svg +1 -0
  101. package/plugins/NetworkErrorLinkPlugin/createErrorOverlay.d.ts +5 -0
  102. package/plugins/NetworkErrorLinkPlugin/createErrorOverlay.js +28 -0
  103. package/plugins/NetworkErrorLinkPlugin/createErrorOverlay.js.map +1 -0
  104. package/plugins/NetworkErrorLinkPlugin.d.ts +7 -0
  105. package/plugins/NetworkErrorLinkPlugin.js +46 -0
  106. package/plugins/NetworkErrorLinkPlugin.js.map +1 -0
  107. package/plugins/OmitTypenameLinkPlugin.d.ts +8 -0
  108. package/plugins/OmitTypenameLinkPlugin.js +42 -0
  109. package/plugins/OmitTypenameLinkPlugin.js.map +1 -0
  110. package/plugins/RoutePlugin.d.ts +12 -0
  111. package/plugins/RoutePlugin.js +37 -0
  112. package/plugins/RoutePlugin.js.map +1 -0
  113. package/plugins/TenantHeaderLinkPlugin.d.ts +14 -0
  114. package/plugins/TenantHeaderLinkPlugin.js +64 -0
  115. package/plugins/TenantHeaderLinkPlugin.js.map +1 -0
  116. package/plugins/ViewPlugin.d.ts +14 -0
  117. package/plugins/ViewPlugin.js +42 -0
  118. package/plugins/ViewPlugin.js.map +1 -0
  119. package/plugins/image.d.ts +3 -0
  120. package/plugins/image.js +166 -0
  121. package/plugins/image.js.map +1 -0
  122. package/plugins/index.d.ts +20 -0
  123. package/plugins/index.js +74 -0
  124. package/plugins/index.js.map +1 -0
  125. package/types.d.ts +62 -0
  126. package/types.js +3 -0
  127. package/types.js.map +1 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/plugins/RoutePlugin.tsx"],"names":["Plugin","RoutePlugin","config","_config","route"],"mappings":";;;;;;AACA,SAASA,MAAT,QAAuB,iBAAvB;AAMA,WAAaC,WAAb;AAAA;;AAAA;;AAII,uBAAYC,MAAZ,EAA6B;AAAA;;AAAA;;AACzB;;AADyB;;AAEzB,UAAKC,OAAL,GAAeD,MAAM,IAAI,EAAzB;AAFyB;AAG5B;;AAPL;AAAA;AAAA,SASI,eAA6B;AACzB,aAAO,KAAKC,OAAL,CAAaC,KAApB;AACH;AAXL;;AAAA;AAAA,EAAiCJ,MAAjC;;gBAAaC,W,UACqB,O","sourcesContent":["import * as React from \"react\";\nimport { Plugin } from \"@webiny/plugins\";\n\ninterface Config {\n route: React.ReactElement;\n}\n\nexport class RoutePlugin extends Plugin {\n public static readonly type = \"route\";\n private _config: Partial<Config>;\n\n constructor(config?: Config) {\n super();\n this._config = config || {};\n }\n\n get route(): Config[\"route\"] {\n return this._config.route;\n }\n}\n"],"file":"RoutePlugin.js"}
@@ -0,0 +1,14 @@
1
+ import { ApolloLinkPlugin } from "./ApolloLinkPlugin";
2
+ declare global {
3
+ interface Window {
4
+ __PS_RENDER_TENANT__: string;
5
+ }
6
+ }
7
+ /**
8
+ * Append `x-tenant` header from URL query (necessary for prerendering service).
9
+ */
10
+ export declare class TenantHeaderLinkPlugin extends ApolloLinkPlugin {
11
+ private tenant;
12
+ constructor(tenant?: string);
13
+ createLink(): import("apollo-link").ApolloLink;
14
+ }
@@ -0,0 +1,64 @@
1
+ import _objectSpread from "@babel/runtime/helpers/objectSpread2";
2
+ import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
3
+ import _createClass from "@babel/runtime/helpers/createClass";
4
+ import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
5
+ import _inherits from "@babel/runtime/helpers/inherits";
6
+ import _createSuper from "@babel/runtime/helpers/createSuper";
7
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
8
+ import { setContext } from "apollo-link-context";
9
+ import { ApolloLinkPlugin } from "./ApolloLinkPlugin";
10
+
11
+ /**
12
+ * Append `x-tenant` header from URL query (necessary for prerendering service).
13
+ */
14
+ export var TenantHeaderLinkPlugin = /*#__PURE__*/function (_ApolloLinkPlugin) {
15
+ _inherits(TenantHeaderLinkPlugin, _ApolloLinkPlugin);
16
+
17
+ var _super = _createSuper(TenantHeaderLinkPlugin);
18
+
19
+ function TenantHeaderLinkPlugin(tenant) {
20
+ var _this;
21
+
22
+ _classCallCheck(this, TenantHeaderLinkPlugin);
23
+
24
+ _this = _super.call(this);
25
+
26
+ _defineProperty(_assertThisInitialized(_this), "tenant", void 0);
27
+
28
+ _this.name = "tenant-header-link";
29
+
30
+ if (!tenant) {
31
+ var query = new URLSearchParams(location.search);
32
+ tenant = query.get("__tenant") || window.__PS_RENDER_TENANT__;
33
+ }
34
+
35
+ _this.tenant = tenant;
36
+ return _this;
37
+ }
38
+
39
+ _createClass(TenantHeaderLinkPlugin, [{
40
+ key: "createLink",
41
+ value: function createLink() {
42
+ var _this2 = this;
43
+
44
+ return setContext(function (_, _ref) {
45
+ var headers = _ref.headers;
46
+
47
+ if (_this2.tenant) {
48
+ return {
49
+ headers: _objectSpread(_objectSpread({}, headers), {}, {
50
+ "x-tenant": _this2.tenant
51
+ })
52
+ };
53
+ }
54
+
55
+ return {
56
+ headers: headers
57
+ };
58
+ });
59
+ }
60
+ }]);
61
+
62
+ return TenantHeaderLinkPlugin;
63
+ }(ApolloLinkPlugin);
64
+ //# sourceMappingURL=TenantHeaderLinkPlugin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/plugins/TenantHeaderLinkPlugin.ts"],"names":["setContext","ApolloLinkPlugin","TenantHeaderLinkPlugin","tenant","name","query","URLSearchParams","location","search","get","window","__PS_RENDER_TENANT__","_","headers"],"mappings":";;;;;;;AAAA,SAASA,UAAT,QAA2B,qBAA3B;AACA,SAASC,gBAAT;;AAQA;AACA;AACA;AACA,WAAaC,sBAAb;AAAA;;AAAA;;AAGI,kCAAYC,MAAZ,EAA6B;AAAA;;AAAA;;AACzB;;AADyB;;AAEzB,UAAKC,IAAL,GAAY,oBAAZ;;AAEA,QAAI,CAACD,MAAL,EAAa;AACT,UAAME,KAAK,GAAG,IAAIC,eAAJ,CAAoBC,QAAQ,CAACC,MAA7B,CAAd;AACAL,MAAAA,MAAM,GAAGE,KAAK,CAACI,GAAN,CAAU,UAAV,KAAyBC,MAAM,CAACC,oBAAzC;AACH;;AAED,UAAKR,MAAL,GAAcA,MAAd;AATyB;AAU5B;;AAbL;AAAA;AAAA,WAeI,sBAAa;AAAA;;AACT,aAAOH,UAAU,CAAC,UAACY,CAAD,QAAoB;AAAA,YAAdC,OAAc,QAAdA,OAAc;;AAClC,YAAI,MAAI,CAACV,MAAT,EAAiB;AACb,iBAAO;AACHU,YAAAA,OAAO,kCACAA,OADA;AAEH,0BAAY,MAAI,CAACV;AAFd;AADJ,WAAP;AAMH;;AAED,eAAO;AAAEU,UAAAA,OAAO,EAAPA;AAAF,SAAP;AACH,OAXgB,CAAjB;AAYH;AA5BL;;AAAA;AAAA,EAA4CZ,gBAA5C","sourcesContent":["import { setContext } from \"apollo-link-context\";\nimport { ApolloLinkPlugin } from \"./ApolloLinkPlugin\";\n\ndeclare global {\n interface Window {\n __PS_RENDER_TENANT__: string;\n }\n}\n\n/**\n * Append `x-tenant` header from URL query (necessary for prerendering service).\n */\nexport class TenantHeaderLinkPlugin extends ApolloLinkPlugin {\n private tenant: string;\n\n constructor(tenant?: string) {\n super();\n this.name = \"tenant-header-link\";\n\n if (!tenant) {\n const query = new URLSearchParams(location.search);\n tenant = query.get(\"__tenant\") || window.__PS_RENDER_TENANT__;\n }\n\n this.tenant = tenant;\n }\n\n createLink() {\n return setContext((_, { headers }) => {\n if (this.tenant) {\n return {\n headers: {\n ...headers,\n \"x-tenant\": this.tenant\n }\n };\n }\n\n return { headers };\n });\n }\n}\n"],"file":"TenantHeaderLinkPlugin.js"}
@@ -0,0 +1,14 @@
1
+ import * as React from "react";
2
+ import { Plugin } from "@webiny/plugins";
3
+ interface Config<Props> {
4
+ name: string;
5
+ render(props: Props): React.ReactElement | null;
6
+ }
7
+ export declare class ViewPlugin<Props = any> extends Plugin {
8
+ static readonly type = "view";
9
+ private _config;
10
+ constructor(config?: Config<Props>);
11
+ get key(): string;
12
+ render(props: Props): React.ReactElement<any, string | ((props: any) => React.ReactElement<any, string | any | (new (props: any) => React.Component<any, any, any>)>) | (new (props: any) => React.Component<any, any, any>)>;
13
+ }
14
+ export {};
@@ -0,0 +1,42 @@
1
+ import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
2
+ import _createClass from "@babel/runtime/helpers/createClass";
3
+ import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
4
+ import _inherits from "@babel/runtime/helpers/inherits";
5
+ import _createSuper from "@babel/runtime/helpers/createSuper";
6
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
7
+ import { Plugin } from "@webiny/plugins";
8
+ export var ViewPlugin = /*#__PURE__*/function (_Plugin) {
9
+ _inherits(ViewPlugin, _Plugin);
10
+
11
+ var _super = _createSuper(ViewPlugin);
12
+
13
+ function ViewPlugin(config) {
14
+ var _this;
15
+
16
+ _classCallCheck(this, ViewPlugin);
17
+
18
+ _this = _super.call(this);
19
+
20
+ _defineProperty(_assertThisInitialized(_this), "_config", void 0);
21
+
22
+ _this._config = config || {};
23
+ return _this;
24
+ }
25
+
26
+ _createClass(ViewPlugin, [{
27
+ key: "key",
28
+ get: function get() {
29
+ return this._config.name;
30
+ }
31
+ }, {
32
+ key: "render",
33
+ value: function render(props) {
34
+ return this._config.render(props);
35
+ }
36
+ }]);
37
+
38
+ return ViewPlugin;
39
+ }(Plugin);
40
+
41
+ _defineProperty(ViewPlugin, "type", "view");
42
+ //# sourceMappingURL=ViewPlugin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/plugins/ViewPlugin.ts"],"names":["Plugin","ViewPlugin","config","_config","name","props","render"],"mappings":";;;;;;AACA,SAASA,MAAT,QAAuB,iBAAvB;AAOA,WAAaC,UAAb;AAAA;;AAAA;;AAII,sBAAYC,MAAZ,EAAoC;AAAA;;AAAA;;AAChC;;AADgC;;AAEhC,UAAKC,OAAL,GAAeD,MAAM,IAAI,EAAzB;AAFgC;AAGnC;;AAPL;AAAA;AAAA,SASI,eAAU;AACN,aAAO,KAAKC,OAAL,CAAaC,IAApB;AACH;AAXL;AAAA;AAAA,WAaI,gBAAOC,KAAP,EAAqB;AACjB,aAAO,KAAKF,OAAL,CAAaG,MAAb,CAAoBD,KAApB,CAAP;AACH;AAfL;;AAAA;AAAA,EAA6CL,MAA7C;;gBAAaC,U,UACqB,M","sourcesContent":["import * as React from \"react\";\nimport { Plugin } from \"@webiny/plugins\";\n\ninterface Config<Props> {\n name: string;\n render(props: Props): React.ReactElement | null;\n}\n\nexport class ViewPlugin<Props = any> extends Plugin {\n public static readonly type = \"view\";\n private _config: Partial<Config<Props>>;\n\n constructor(config?: Config<Props>) {\n super();\n this._config = config || {};\n }\n\n get key() {\n return this._config.name;\n }\n\n render(props: Props) {\n return this._config.render(props);\n }\n}\n"],"file":"ViewPlugin.js"}
@@ -0,0 +1,3 @@
1
+ import { ImageComponentPlugin } from "../types";
2
+ declare const _default: () => ImageComponentPlugin;
3
+ export default _default;
@@ -0,0 +1,166 @@
1
+ import _objectSpread from "@babel/runtime/helpers/objectSpread2";
2
+ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
3
+ var _excluded = ["transform", "srcSet"];
4
+ import React from "react";
5
+ import { Image } from "@webiny/ui/Image";
6
+ var SUPPORTED_IMAGE_RESIZE_WIDTHS = [100, 300, 500, 750, 1000, 1500, 2500];
7
+ /**
8
+ * Width of the image should not be just any random number. For optimization reasons,
9
+ * we only allow the ones listed in SUPPORTED_IMAGE_RESIZE_WIDTHS list (Webiny Cloud supports only these).
10
+ */
11
+
12
+ var getSupportedImageResizeWidth = function getSupportedImageResizeWidth(width) {
13
+ var output = SUPPORTED_IMAGE_RESIZE_WIDTHS[0];
14
+ var i = SUPPORTED_IMAGE_RESIZE_WIDTHS.length;
15
+
16
+ while (i >= 0) {
17
+ if (width === SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {
18
+ output = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];
19
+ break;
20
+ }
21
+
22
+ if (width > SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {
23
+ // Use next larger width. If there isn't any, use current.
24
+ output = SUPPORTED_IMAGE_RESIZE_WIDTHS[i + 1];
25
+
26
+ if (!output) {
27
+ output = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];
28
+ }
29
+
30
+ break;
31
+ }
32
+
33
+ i--;
34
+ }
35
+
36
+ return output;
37
+ };
38
+ /**
39
+ * Currently we only allow "width" as a transform option.
40
+ * @param args
41
+ */
42
+
43
+
44
+ var sanitizeTransformArgs = function sanitizeTransformArgs(args) {
45
+ var output = {};
46
+
47
+ if (args) {
48
+ var width = parseInt(args.width);
49
+
50
+ if (width > 0) {
51
+ output.width = getSupportedImageResizeWidth(width);
52
+ }
53
+ }
54
+
55
+ return output;
56
+ };
57
+
58
+ var getSizes = function getSizes(width) {
59
+ // Check if width was set as percentage, with "%" in the value.
60
+ if (typeof width === "string" && width.endsWith("%")) {
61
+ return "".concat(parseInt(width), "vw");
62
+ } // Check if width was set as viewport width, with "vw" in the value.
63
+
64
+
65
+ if (typeof width === "string" && width.endsWith("vw")) {
66
+ return "".concat(parseInt(width), "vw");
67
+ } // Check if width was set as relative, with "em" in the value.
68
+
69
+
70
+ if (typeof width === "string" && width.endsWith("em")) {
71
+ return "".concat(parseInt(width), "em");
72
+ }
73
+
74
+ return null;
75
+ };
76
+
77
+ var isFixedImageWidth = function isFixedImageWidth(width) {
78
+ if (Number.isFinite(width)) {
79
+ return true;
80
+ }
81
+
82
+ if (typeof width === "string" && width.endsWith("px")) {
83
+ return true;
84
+ }
85
+
86
+ return false;
87
+ };
88
+
89
+ var getSrcSetAutoSizes = function getSrcSetAutoSizes(max) {
90
+ max = isFixedImageWidth(max) ? parseInt("" + max) : 2500;
91
+ var maxWidth = getSupportedImageResizeWidth(max);
92
+ return SUPPORTED_IMAGE_RESIZE_WIDTHS.filter(function (supportedWidth) {
93
+ return supportedWidth <= maxWidth;
94
+ });
95
+ };
96
+
97
+ var convertTransformToQueryParams = function convertTransformToQueryParams(transform) {
98
+ return Object.keys(transform).map(function (key) {
99
+ return "".concat(key, "=").concat(transform[key]);
100
+ }).join("&");
101
+ };
102
+
103
+ export default (function () {
104
+ var imagePlugin = {
105
+ name: "image-component",
106
+ type: "image-component",
107
+ presets: {
108
+ avatar: {
109
+ width: 300
110
+ }
111
+ },
112
+ getImageSrc: function getImageSrc(props) {
113
+ if (!props) {
114
+ return "";
115
+ }
116
+
117
+ var src = props.src,
118
+ transform = props.transform;
119
+
120
+ if (!transform) {
121
+ return src;
122
+ }
123
+
124
+ if (!src || src.startsWith("data:") || src.endsWith("svg")) {
125
+ return src;
126
+ }
127
+
128
+ var params = sanitizeTransformArgs(transform);
129
+ params = convertTransformToQueryParams(params);
130
+ return src + "?" + params;
131
+ },
132
+ render: function render(props) {
133
+ var transform = props.transform,
134
+ srcSetInitial = props.srcSet,
135
+ imageProps = _objectWithoutProperties(props, _excluded);
136
+
137
+ var srcSet = srcSetInitial;
138
+ var sizes;
139
+ var src = imageProps.src;
140
+
141
+ if (srcSet && srcSet === "auto") {
142
+ srcSet = {}; // Check if image width was forced, and additionally if width was set as pixels, with "px" in the value.
143
+
144
+ var forcedWidth = props.width || props.style && props.style.width;
145
+ var srcSetAutoWidths = getSrcSetAutoSizes(forcedWidth);
146
+ srcSetAutoWidths.forEach(function (width) {
147
+ srcSet[width + "w"] = imagePlugin.getImageSrc({
148
+ src: src,
149
+ transform: _objectSpread(_objectSpread({}, transform), {}, {
150
+ width: width
151
+ })
152
+ });
153
+ });
154
+ sizes = getSizes(forcedWidth);
155
+ }
156
+
157
+ return /*#__PURE__*/React.createElement(Image, Object.assign({}, imageProps, {
158
+ srcSet: srcSet,
159
+ src: src,
160
+ sizes: sizes
161
+ }));
162
+ }
163
+ };
164
+ return imagePlugin;
165
+ });
166
+ //# sourceMappingURL=image.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/plugins/image.tsx"],"names":["React","Image","SUPPORTED_IMAGE_RESIZE_WIDTHS","getSupportedImageResizeWidth","width","output","i","length","sanitizeTransformArgs","args","parseInt","getSizes","endsWith","isFixedImageWidth","Number","isFinite","getSrcSetAutoSizes","max","maxWidth","filter","supportedWidth","convertTransformToQueryParams","transform","Object","keys","map","key","join","imagePlugin","name","type","presets","avatar","getImageSrc","props","src","startsWith","params","render","srcSetInitial","srcSet","imageProps","sizes","forcedWidth","style","srcSetAutoWidths","forEach"],"mappings":"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","sourcesContent":["import React from \"react\";\nimport { Image } from \"@webiny/ui/Image\";\nimport { ImageComponentPlugin } from \"../types\";\n\nconst SUPPORTED_IMAGE_RESIZE_WIDTHS = [100, 300, 500, 750, 1000, 1500, 2500];\n\n/**\n * Width of the image should not be just any random number. For optimization reasons,\n * we only allow the ones listed in SUPPORTED_IMAGE_RESIZE_WIDTHS list (Webiny Cloud supports only these).\n */\nconst getSupportedImageResizeWidth = width => {\n let output = SUPPORTED_IMAGE_RESIZE_WIDTHS[0];\n let i = SUPPORTED_IMAGE_RESIZE_WIDTHS.length;\n while (i >= 0) {\n if (width === SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {\n output = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];\n break;\n }\n\n if (width > SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {\n // Use next larger width. If there isn't any, use current.\n output = SUPPORTED_IMAGE_RESIZE_WIDTHS[i + 1];\n if (!output) {\n output = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];\n }\n break;\n }\n\n i--;\n }\n\n return output;\n};\n\n/**\n * Currently we only allow \"width\" as a transform option.\n * @param args\n */\nconst sanitizeTransformArgs = (args: { [key: string]: any }): Object => {\n const output: { [key: string]: any } = {};\n if (args) {\n const width = parseInt(args.width);\n if (width > 0) {\n output.width = getSupportedImageResizeWidth(width);\n }\n }\n\n return output;\n};\n\nconst getSizes = (width: any): string | null => {\n // Check if width was set as percentage, with \"%\" in the value.\n if (typeof width === \"string\" && width.endsWith(\"%\")) {\n return `${parseInt(width)}vw`;\n }\n // Check if width was set as viewport width, with \"vw\" in the value.\n if (typeof width === \"string\" && width.endsWith(\"vw\")) {\n return `${parseInt(width)}vw`;\n }\n\n // Check if width was set as relative, with \"em\" in the value.\n if (typeof width === \"string\" && width.endsWith(\"em\")) {\n return `${parseInt(width)}em`;\n }\n\n return null;\n};\n\nconst isFixedImageWidth = width => {\n if (Number.isFinite(width)) {\n return true;\n }\n\n if (typeof width === \"string\" && width.endsWith(\"px\")) {\n return true;\n }\n return false;\n};\n\nconst getSrcSetAutoSizes = (max: number | undefined) => {\n max = isFixedImageWidth(max) ? parseInt(\"\" + max) : 2500;\n const maxWidth = getSupportedImageResizeWidth(max);\n return SUPPORTED_IMAGE_RESIZE_WIDTHS.filter((supportedWidth: number) => {\n return supportedWidth <= maxWidth;\n });\n};\n\nconst convertTransformToQueryParams = (transform: Object): string => {\n return Object.keys(transform)\n .map(key => `${key}=${transform[key]}`)\n .join(\"&\");\n};\n\nexport default () => {\n const imagePlugin: ImageComponentPlugin = {\n name: \"image-component\",\n type: \"image-component\",\n presets: {\n avatar: { width: 300 }\n },\n getImageSrc: (props: { [key: string]: any }) => {\n if (!props) {\n return \"\";\n }\n\n const { src, transform } = props;\n if (!transform) {\n return src;\n }\n\n if (!src || src.startsWith(\"data:\") || src.endsWith(\"svg\")) {\n return src;\n }\n\n let params = sanitizeTransformArgs(transform);\n params = convertTransformToQueryParams(params);\n return src + \"?\" + params;\n },\n render(props: { [key: string]: any }) {\n const { transform, srcSet: srcSetInitial, ...imageProps } = props;\n let srcSet = srcSetInitial;\n let sizes;\n const src = imageProps.src;\n if (srcSet && srcSet === \"auto\") {\n srcSet = {};\n\n // Check if image width was forced, and additionally if width was set as pixels, with \"px\" in the value.\n const forcedWidth = props.width || (props.style && props.style.width);\n const srcSetAutoWidths = getSrcSetAutoSizes(forcedWidth);\n srcSetAutoWidths.forEach(width => {\n srcSet[width + \"w\"] = imagePlugin.getImageSrc({\n src,\n transform: { ...transform, width }\n });\n });\n sizes = getSizes(forcedWidth);\n }\n\n return <Image {...imageProps} srcSet={srcSet} src={src} sizes={sizes} />;\n }\n };\n\n return imagePlugin;\n};\n"],"file":"image.js"}
@@ -0,0 +1,20 @@
1
+ import { ReactNode } from "react";
2
+ import { Plugin } from "@webiny/plugins/types";
3
+ import imagePlugin from "./image";
4
+ export { imagePlugin };
5
+ declare type RenderPluginOptions<T> = {
6
+ wrapper?: boolean;
7
+ fn?: string;
8
+ filter?: (value: T, index: number, array: T[]) => boolean;
9
+ reverse?: boolean;
10
+ };
11
+ interface RenderPlugin {
12
+ <T extends Plugin = Plugin>(name: string, params?: any, options?: RenderPluginOptions<T>): ReactNode | ReactNode[];
13
+ }
14
+ interface RenderPlugins {
15
+ <T extends Plugin = Plugin>(type: string, params?: any, options?: RenderPluginOptions<T>): ReactNode | ReactNode[];
16
+ }
17
+ export declare const renderPlugin: RenderPlugin;
18
+ export declare const renderPlugins: RenderPlugins;
19
+ declare const _default: (() => import("../types").ImageComponentPlugin)[];
20
+ export default _default;
@@ -0,0 +1,74 @@
1
+ import React from "react";
2
+ import warning from "warning";
3
+ import { plugins } from "@webiny/plugins";
4
+ import imagePlugin from "./image";
5
+ export { imagePlugin };
6
+
7
+ var PluginComponent = function PluginComponent(props) {
8
+ return props.children;
9
+ };
10
+
11
+ var PluginsComponent = function PluginsComponent(props) {
12
+ return props.children;
13
+ };
14
+
15
+ export var renderPlugin = function renderPlugin(name) {
16
+ var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
17
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
18
+ var _options$wrapper = options.wrapper,
19
+ wrapper = _options$wrapper === void 0 ? true : _options$wrapper,
20
+ _options$fn = options.fn,
21
+ fn = _options$fn === void 0 ? "render" : _options$fn;
22
+ var plugin = plugins.byName(name);
23
+ warning(plugin, "No such plugin \"".concat(name, "\""));
24
+
25
+ if (!plugin) {
26
+ return null;
27
+ }
28
+
29
+ var content = plugin[fn](params);
30
+
31
+ if (content) {
32
+ return wrapper ? /*#__PURE__*/React.createElement(PluginComponent, {
33
+ key: plugin.name,
34
+ name: name,
35
+ params: params,
36
+ fn: fn
37
+ }, content) : /*#__PURE__*/React.cloneElement(content, {
38
+ key: plugin.name
39
+ });
40
+ }
41
+
42
+ return null;
43
+ };
44
+ export var renderPlugins = function renderPlugins(type) {
45
+ var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
46
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
47
+ var _options$wrapper2 = options.wrapper,
48
+ wrapper = _options$wrapper2 === void 0 ? true : _options$wrapper2,
49
+ _options$fn2 = options.fn,
50
+ fn = _options$fn2 === void 0 ? "render" : _options$fn2,
51
+ _options$filter = options.filter,
52
+ filter = _options$filter === void 0 ? function (v) {
53
+ return v;
54
+ } : _options$filter,
55
+ reverse = options.reverse;
56
+ var content = plugins.byType(type).filter(filter).map(function (plugin) {
57
+ return renderPlugin(plugin.name, params, {
58
+ wrapper: wrapper,
59
+ fn: fn
60
+ });
61
+ }).filter(Boolean);
62
+
63
+ if (reverse) {
64
+ content.reverse();
65
+ }
66
+
67
+ return wrapper ? /*#__PURE__*/React.createElement(PluginsComponent, {
68
+ type: type,
69
+ params: params,
70
+ fn: fn
71
+ }, content) : content;
72
+ };
73
+ export default [imagePlugin];
74
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/plugins/index.tsx"],"names":["React","warning","plugins","imagePlugin","PluginComponent","props","children","PluginsComponent","renderPlugin","name","params","options","wrapper","fn","plugin","byName","content","cloneElement","key","renderPlugins","type","filter","v","reverse","byType","map","Boolean"],"mappings":"AAAA,OAAOA,KAAP,MAA2D,OAA3D;AACA,OAAOC,OAAP,MAAoB,SAApB;AACA,SAASC,OAAT,QAAwB,iBAAxB;AAEA,OAAOC,WAAP;AAEA,SAASA,WAAT;;AAqBA,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAACC,KAAD;AAAA,SACpBA,KAAK,CAACC,QADc;AAAA,CAAxB;;AAEA,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACF,KAAD;AAAA,SACrBA,KAAK,CAACC,QADe;AAAA,CAAzB;;AAGA,OAAO,IAAME,YAA0B,GAAG,SAA7BA,YAA6B,CAACC,IAAD,EAAqC;AAAA,MAA9BC,MAA8B,uEAArB,EAAqB;AAAA,MAAjBC,OAAiB,uEAAP,EAAO;AAC3E,yBAA0CA,OAA1C,CAAQC,OAAR;AAAA,MAAQA,OAAR,iCAAkB,IAAlB;AAAA,oBAA0CD,OAA1C,CAAwBE,EAAxB;AAAA,MAAwBA,EAAxB,4BAA6B,QAA7B;AAEA,MAAMC,MAAM,GAAGZ,OAAO,CAACa,MAAR,CAAeN,IAAf,CAAf;AACAR,EAAAA,OAAO,CAACa,MAAD,6BAA4BL,IAA5B,QAAP;;AAEA,MAAI,CAACK,MAAL,EAAa;AACT,WAAO,IAAP;AACH;;AAED,MAAME,OAAO,GAAGF,MAAM,CAACD,EAAD,CAAN,CAAWH,MAAX,CAAhB;;AACA,MAAIM,OAAJ,EAAa;AACT,WAAOJ,OAAO,gBACV,oBAAC,eAAD;AAAiB,MAAA,GAAG,EAAEE,MAAM,CAACL,IAA7B;AAAmC,MAAA,IAAI,EAAEA,IAAzC;AAA+C,MAAA,MAAM,EAAEC,MAAvD;AAA+D,MAAA,EAAE,EAAEG;AAAnE,OACKG,OADL,CADU,gBAKVhB,KAAK,CAACiB,YAAN,CAAmBD,OAAnB,EAA4B;AAAEE,MAAAA,GAAG,EAAEJ,MAAM,CAACL;AAAd,KAA5B,CALJ;AAOH;;AACD,SAAO,IAAP;AACH,CArBM;AAuBP,OAAO,IAAMU,aAA4B,GAAG,SAA/BA,aAA+B,CAACC,IAAD,EAAqC;AAAA,MAA9BV,MAA8B,uEAArB,EAAqB;AAAA,MAAjBC,OAAiB,uEAAP,EAAO;AAC7E,0BAAoEA,OAApE,CAAQC,OAAR;AAAA,MAAQA,OAAR,kCAAkB,IAAlB;AAAA,qBAAoED,OAApE,CAAwBE,EAAxB;AAAA,MAAwBA,EAAxB,6BAA6B,QAA7B;AAAA,wBAAoEF,OAApE,CAAuCU,MAAvC;AAAA,MAAuCA,MAAvC,gCAAgD,UAAAC,CAAC;AAAA,WAAIA,CAAJ;AAAA,GAAjD;AAAA,MAAwDC,OAAxD,GAAoEZ,OAApE,CAAwDY,OAAxD;AAEA,MAAMP,OAAO,GAAGd,OAAO,CAClBsB,MADW,CACJJ,IADI,EAEXC,MAFW,CAEJA,MAFI,EAGXI,GAHW,CAGP,UAAAX,MAAM;AAAA,WAAIN,YAAY,CAACM,MAAM,CAACL,IAAR,EAAcC,MAAd,EAAsB;AAAEE,MAAAA,OAAO,EAAPA,OAAF;AAAWC,MAAAA,EAAE,EAAFA;AAAX,KAAtB,CAAhB;AAAA,GAHC,EAIXQ,MAJW,CAIJK,OAJI,CAAhB;;AAMA,MAAIH,OAAJ,EAAa;AACTP,IAAAA,OAAO,CAACO,OAAR;AACH;;AAED,SAAOX,OAAO,gBACV,oBAAC,gBAAD;AAAkB,IAAA,IAAI,EAAEQ,IAAxB;AAA8B,IAAA,MAAM,EAAEV,MAAtC;AAA8C,IAAA,EAAE,EAAEG;AAAlD,KACKG,OADL,CADU,GAKVA,OALJ;AAOH,CApBM;AAsBP,eAAe,CAACb,WAAD,CAAf","sourcesContent":["import React, { ReactNode, FunctionComponentElement } from \"react\";\nimport warning from \"warning\";\nimport { plugins } from \"@webiny/plugins\";\nimport { Plugin } from \"@webiny/plugins/types\";\nimport imagePlugin from \"./image\";\n\nexport { imagePlugin };\n\ntype RenderPluginOptions<T> = {\n wrapper?: boolean;\n fn?: string;\n filter?: (value: T, index: number, array: T[]) => boolean;\n reverse?: boolean;\n};\n\ninterface RenderPlugin {\n <T extends Plugin = Plugin>(name: string, params?: any, options?: RenderPluginOptions<T>):\n | ReactNode\n | ReactNode[];\n}\n\ninterface RenderPlugins {\n <T extends Plugin = Plugin>(type: string, params?: any, options?: RenderPluginOptions<T>):\n | ReactNode\n | ReactNode[];\n}\n\nconst PluginComponent = (props: { [key: string]: any }): FunctionComponentElement<{}> =>\n props.children;\nconst PluginsComponent = (props: { [key: string]: any }): FunctionComponentElement<{}> =>\n props.children;\n\nexport const renderPlugin: RenderPlugin = (name, params = {}, options = {}) => {\n const { wrapper = true, fn = \"render\" } = options;\n\n const plugin = plugins.byName(name);\n warning(plugin, `No such plugin \"${name}\"`);\n\n if (!plugin) {\n return null;\n }\n\n const content = plugin[fn](params);\n if (content) {\n return wrapper ? (\n <PluginComponent key={plugin.name} name={name} params={params} fn={fn}>\n {content}\n </PluginComponent>\n ) : (\n React.cloneElement(content, { key: plugin.name })\n );\n }\n return null;\n};\n\nexport const renderPlugins: RenderPlugins = (type, params = {}, options = {}) => {\n const { wrapper = true, fn = \"render\", filter = v => v, reverse } = options;\n\n const content = plugins\n .byType(type)\n .filter(filter)\n .map(plugin => renderPlugin(plugin.name, params, { wrapper, fn }))\n .filter(Boolean);\n\n if (reverse) {\n content.reverse();\n }\n\n return wrapper ? (\n <PluginsComponent type={type} params={params} fn={fn}>\n {content}\n </PluginsComponent>\n ) : (\n content\n );\n};\n\nexport default [imagePlugin];\n"],"file":"index.js"}
package/types.d.ts ADDED
@@ -0,0 +1,62 @@
1
+ import * as React from "react";
2
+ import { Plugin } from "@webiny/plugins/types";
3
+ import { ApolloClient } from "apollo-client";
4
+ import { CSSProperties } from "react";
5
+ export declare type WebinyInitPlugin = Plugin & {
6
+ type: "webiny-init";
7
+ init(): void;
8
+ };
9
+ export declare type UploadOptions = {
10
+ apolloClient: ApolloClient<object>;
11
+ };
12
+ export declare type UiStatePlugin = Plugin & {
13
+ type: "ui-state";
14
+ render(): React.ReactElement;
15
+ };
16
+ export declare type FileUploaderPlugin = Plugin & {
17
+ type: "file-uploader";
18
+ upload(file: File, options: UploadOptions): Promise<any>;
19
+ };
20
+ export declare type AppFileManagerStoragePlugin = Plugin & {
21
+ type: "app-file-manager-storage";
22
+ upload(file: File, options: UploadOptions): Promise<any>;
23
+ };
24
+ export { Plugin };
25
+ export declare type ImageProps = {
26
+ src: string;
27
+ preset?: string;
28
+ transform?: {
29
+ [key: string]: any;
30
+ };
31
+ srcSet?: {
32
+ [key: string]: any;
33
+ } | "auto";
34
+ className?: string;
35
+ title?: string;
36
+ alt?: string;
37
+ style?: CSSProperties;
38
+ };
39
+ /**
40
+ * "getImageSrc" has to be defined as a separate property, so its functionality can be reused outside of
41
+ * the Image component. This is ideal in cases where manual creation of image src is needed.
42
+ */
43
+ export declare type ImageComponentPlugin = Plugin & {
44
+ type: "image-component";
45
+ render: (props: ImageProps) => React.ReactElement;
46
+ getImageSrc: (props?: Object) => string;
47
+ presets: {
48
+ [key: string]: any;
49
+ };
50
+ };
51
+ /**
52
+ * Enables registering new routes.
53
+ * @see https://docs.webiny.com/docs/webiny-apps/admin/development/plugins-reference/app#route
54
+ */
55
+ export declare type RoutePlugin = Plugin & {
56
+ type: "route";
57
+ route: React.ReactElement;
58
+ };
59
+ export declare type CacheGetObjectIdPlugin = Plugin & {
60
+ type: "cache-get-object-id";
61
+ getObjectId(obj: Record<string, any>): string | undefined;
62
+ };