dbm 1.0.6 → 1.1.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 (52) hide show
  1. package/flow/updatefunctions/dom/ElementPosition.js +1 -1
  2. package/flow/updatefunctions/dom/HorizontalFlip.js +5 -6
  3. package/flow/updatefunctions/dom/StyleObject.js +1 -1
  4. package/flow/updatefunctions/logic/Switch.js +6 -0
  5. package/graphapi/webclient/WebSocketConnection.js +13 -8
  6. package/graphapi/webclient/decode/index.js +16 -0
  7. package/package.json +1 -1
  8. package/react/BaseObject.js +18 -7
  9. package/react/ChildFunctions.js +27 -0
  10. package/react/admin/EditPage.js +12 -1
  11. package/react/admin/{Editor.js → editor/Editor.js} +27 -11
  12. package/react/admin/{EditorBlock.js → editor/EditorBlock.js} +15 -4
  13. package/react/admin/editor/EditorBlockFields.js +23 -0
  14. package/react/admin/editor/EditorBlockName.js +28 -0
  15. package/react/admin/editor/fields/CheckboxField.js +54 -0
  16. package/react/admin/editor/fields/ImageField.js +137 -0
  17. package/react/admin/editor/fields/RichTextField.js +75 -0
  18. package/react/admin/editor/fields/TextField.js +53 -0
  19. package/react/admin/editor/fields/index.js +4 -0
  20. package/react/admin/editor/index.js +6 -0
  21. package/react/admin/index.js +3 -4
  22. package/react/animation/AnimatedElement.js +22 -0
  23. package/react/animation/AnimationController.js +53 -0
  24. package/react/animation/index.js +22 -0
  25. package/react/area/HasData.js +5 -0
  26. package/react/area/InsertElement.js +1 -1
  27. package/react/area/List.js +46 -0
  28. package/react/area/OpenCloseExpandableArea.js +5 -3
  29. package/react/area/ResponsiveLayout.js +48 -0
  30. package/react/area/index.js +12 -1
  31. package/react/blocks/Image.js +17 -0
  32. package/react/blocks/index.js +69 -55
  33. package/react/cookies/CookieSettings.js +1 -1
  34. package/react/form/Checkbox.js +2 -1
  35. package/react/form/FormField.js +1 -0
  36. package/react/form/LabelledArea.js +22 -0
  37. package/react/form/index.js +2 -1
  38. package/react/image/CoverScaledImage.js +32 -0
  39. package/react/image/Image.js +37 -0
  40. package/react/image/WidthScaledImage.js +30 -0
  41. package/react/image/index.js +3 -0
  42. package/react/index.js +6 -1
  43. package/react/login/LoginForm.js +1 -1
  44. package/react/source/index.js +15 -1
  45. package/react/text/Link.js +18 -0
  46. package/react/text/index.js +1 -0
  47. package/site/SiteDataLoader.js +1 -1
  48. package/tracking/Controller.js +1 -1
  49. package/utils/ArrayFunctions.js +58 -4
  50. package/utils/UrlFunctions.js +77 -0
  51. package/utils/index.js +2 -1
  52. package/react/admin/EditorBlockName.js +0 -19
@@ -0,0 +1,32 @@
1
+ import Dbm from "../../index.js";
2
+ import React from "react";
3
+
4
+ export default class CoverScaledImage extends Dbm.react.BaseObject {
5
+ _construct() {
6
+ super._construct();
7
+ }
8
+
9
+ _removedUsedProps(aProps) {
10
+ delete aProps["image"];
11
+ delete aProps["targetWidth"];
12
+ delete aProps["targetHeight"];
13
+ }
14
+
15
+ _renderMainElement() {
16
+
17
+ let image = this.getPropValue("image");
18
+ let width = this.getPropValue("targetWidth");
19
+ let height = this.getPropValue("targetHeight");
20
+ let url = Dbm.utils.UrlFunctions.createCoverScaledImageUrl(image, width, height);
21
+
22
+ let newProps = this._copyProps({src: url});
23
+
24
+ let elementType = this.getPropValue("elementType");
25
+ if(elementType) {
26
+ newProps["elementType"] = elementType;
27
+ }
28
+
29
+ return React.createElement(Dbm.react.image.Image, newProps, this.getPropValue("children"));
30
+
31
+ }
32
+ }
@@ -0,0 +1,37 @@
1
+ import Dbm from "../../index.js";
2
+
3
+ export default class Image extends Dbm.react.BaseObject {
4
+ _construct() {
5
+ super._construct();
6
+ }
7
+
8
+ _removedUsedProps(aProps) {
9
+ let elementType = this.getPropValue("elementType");
10
+
11
+ let isDiv = (elementType !== "img");
12
+ if(isDiv) {
13
+ delete aProps["src"];
14
+ }
15
+ }
16
+
17
+ _renderMainElement() {
18
+
19
+ let src = this.getPropValue("src");
20
+ let elementType = this.getPropValue("elementType");
21
+
22
+ let isDiv = (elementType !== "img");
23
+ if(isDiv) {
24
+ let imageStyle = {
25
+ "backgroundImage": "url(" + src + ")"
26
+ };
27
+ let className = "image";
28
+
29
+ return this._createMainElement("div", {style: imageStyle, className: className}, this.getPropValue("children"));
30
+ }
31
+ else {
32
+ let className = "image";
33
+ return this._createMainElement("img", {src: src, className: className});
34
+ }
35
+
36
+ }
37
+ }
@@ -0,0 +1,30 @@
1
+ import Dbm from "../../index.js";
2
+ import React from "react";
3
+
4
+ export default class WidthScaledImage extends Dbm.react.BaseObject {
5
+ _construct() {
6
+ super._construct();
7
+ }
8
+
9
+ _removedUsedProps(aProps) {
10
+ delete aProps["image"];
11
+ delete aProps["targetWidth"];
12
+ }
13
+
14
+ _renderMainElement() {
15
+
16
+ let image = this.getPropValue("image");
17
+ let width = this.getPropValue("targetWidth");
18
+ let url = Dbm.utils.UrlFunctions.createScaledImageUrl(image, width);
19
+
20
+ let newProps = this._copyProps({src: url});
21
+
22
+ let elementType = this.getPropValue("elementType");
23
+ if(elementType) {
24
+ newProps["elementType"] = elementType;
25
+ }
26
+
27
+ return React.createElement(Dbm.react.image.Image, newProps, this.getPropValue("children"));
28
+
29
+ }
30
+ }
@@ -0,0 +1,3 @@
1
+ export {default as Image} from "./Image.js";
2
+ export {default as WidthScaledImage} from "./WidthScaledImage.js";
3
+ export {default as CoverScaledImage} from "./CoverScaledImage.js";
package/react/index.js CHANGED
@@ -1,6 +1,8 @@
1
1
  export {default as BaseObject} from "./BaseObject.js";
2
2
  export {default as RefToProperty} from "./RefToProperty.js";
3
3
 
4
+ export * as ChildFunctions from "./ChildFunctions.js";
5
+
4
6
  export * as modules from "./modules/index.js";
5
7
  export * as admin from "./admin/index.js";
6
8
  export * as blocks from "./blocks/index.js";
@@ -10,4 +12,7 @@ export * as area from "./area/index.js";
10
12
  export * as context from "./context/index.js";
11
13
  export * as source from "./source/index.js";
12
14
  export * as text from "./text/index.js";
13
- export * as login from "./login/index.js";
15
+ export * as login from "./login/index.js";
16
+ export * as image from "./image/index.js";
17
+ export * as animation from "./animation/index.js";
18
+
@@ -87,7 +87,7 @@ export default class LoginForm extends Dbm.react.BaseObject {
87
87
 
88
88
  _renderMainElement() {
89
89
 
90
- return this._createMainElement("div", {},
90
+ return this._createMainElement("div", {className: "content-narrow"},
91
91
  React.createElement("div", {className: "body-text"},
92
92
  React.createElement("div", {"className": ""},
93
93
  React.createElement("label", {className: "standard-field-label"},
@@ -1 +1,15 @@
1
- export {default as ContextVariableSource} from "./ContextVariableSource.js";
1
+ import Dbm from "../../index.js";
2
+
3
+ export {default as ContextVariableSource} from "./ContextVariableSource.js";
4
+
5
+ export let contextVariable = function(aPath) {
6
+ let newSource = new Dbm.react.source.ContextVariableSource();
7
+ newSource.item.path = aPath;
8
+
9
+ return newSource;
10
+ }
11
+
12
+ export let blockData = function(aPath) {
13
+ //METODO: check if blockdata is a source
14
+ return contextVariable("blockData." + aPath);
15
+ }
@@ -0,0 +1,18 @@
1
+ import Dbm from "../../index.js";
2
+
3
+ export default class Link extends Dbm.react.BaseObject {
4
+ _construct() {
5
+ super._construct();
6
+ }
7
+
8
+ _renderMainElement() {
9
+
10
+ let url = this.getPropValue("href");
11
+ let prefix = this.getPropValue("prefix");
12
+ if(prefix) {
13
+ url = prefix + url;
14
+ }
15
+
16
+ return this._createMainElement("a", {href: url}, this.getPropValue("children"));
17
+ }
18
+ }
@@ -3,6 +3,7 @@ import {createElement} from "react";
3
3
 
4
4
  export {default as Text} from "./Text.js";
5
5
  export {default as HtmlText} from "./HtmlText.js";
6
+ export {default as Link} from "./Link.js";
6
7
 
7
8
  export let text = function(aText) {
8
9
  if(typeof(aText) === "string") {
@@ -16,7 +16,7 @@ export default class SiteDataLoader extends Dbm.core.BaseObject {
16
16
  }
17
17
 
18
18
  _loadUrl() {
19
- console.log("_loadUrl");
19
+ //console.log("_loadUrl");
20
20
 
21
21
  let url = this.item.url;
22
22
  if(url != null) {
@@ -44,7 +44,7 @@ export default class Controller extends Dbm.core.BaseObject {
44
44
  }
45
45
 
46
46
  start() {
47
- console.log("start");
47
+ //console.log("start");
48
48
  this.item.active = true;
49
49
 
50
50
  return this;
@@ -1,9 +1,63 @@
1
- export let range = function(aStartValue, aEndValue, aStep = 1) {
2
- let returnArray = [];
1
+ export const range = function(aStartValue, aEndValue, aStepValue = 1, aIncludeEndValue = true) {
2
+
3
+ let returnArray = new Array();
4
+
5
+ let loopCompare;
6
+
7
+ if(aStepValue > 0) {
8
+ if(aIncludeEndValue) {
9
+ loopCompare = function(aIndex, aLimit) {
10
+ return aIndex <= aLimit;
11
+ };
12
+ }
13
+ else {
14
+ loopCompare = function(aIndex, aLimit) {
15
+ return aIndex < aLimit;
16
+ };
17
+ }
18
+ }
19
+ else {
20
+ if(aIncludeEndValue) {
21
+ loopCompare = function(aIndex, aLimit) {
22
+ return aIndex >= aLimit;
23
+ };
24
+ }
25
+ else {
26
+ loopCompare = function(aIndex, aLimit) {
27
+ return aIndex > aLimit;
28
+ };
29
+ }
30
+ }
31
+
32
+ for(let i = aStartValue; loopCompare(i, aEndValue); i += aStepValue) {
33
+ returnArray.push(i);
34
+ }
35
+
36
+ return returnArray;
37
+ }
3
38
 
39
+ export const removeDuplicates = function(aArray) {
40
+ let returnArray = [];
41
+
42
+ let currentArray = aArray;
43
+ let currentArrayLength = currentArray.length;
44
+ for(let i = 0; i < currentArrayLength; i++) {
45
+ let currentValue = currentArray[i];
46
+ if(returnArray.indexOf(currentValue) === -1) {
47
+ returnArray.push(currentValue);
48
+ }
49
+ }
50
+
4
51
  return returnArray;
5
52
  }
6
53
 
7
- export let removeDuplicates = function(aArray) {
8
- return aArray;
54
+ export const singleOrArray = function(aData) {
55
+ if(aData === null || aData === undefined) {
56
+ return [];
57
+ }
58
+ else if(aData instanceof Array) {
59
+ return aData;
60
+ }
61
+
62
+ return [aData];
9
63
  }
@@ -0,0 +1,77 @@
1
+ export let createScaledImageUrl = function(aImageData, aWantedWidth) {
2
+ if(!aImageData || !aImageData["url"]) {
3
+ return null;
4
+ }
5
+
6
+ let url = aImageData["url"];
7
+ if(url.substring(url.length-4).toLowerCase() === ".svg") {
8
+ return url;
9
+ }
10
+
11
+ if(aImageData["resizeUrl"]) {
12
+ let scaleToWidth = Math.min(
13
+ Math.round(window.devicePixelRatio*aWantedWidth),
14
+ Math.max(
15
+ 100,
16
+ 100*Math.round(window.devicePixelRatio*window.innerWidth/100)
17
+ )
18
+ );
19
+ url = aImageData["resizeUrl"].split("{scale}").join("width=" + scaleToWidth);
20
+ }
21
+
22
+ return url;
23
+ }
24
+
25
+ export let createCoverScaledImageUrl = function(aImageData, aWantedWidth, aWantedHeight) {
26
+ if(!aImageData || !aImageData["url"]) {
27
+ return null;
28
+ }
29
+
30
+ let url = aImageData["url"];
31
+ if(url.substring(url.length-4).toLowerCase() === ".svg") {
32
+ return url;
33
+ }
34
+
35
+ if(aImageData["resizeUrl"]) {
36
+ let scaleToWidth = Math.min(
37
+ Math.round(window.devicePixelRatio*aWantedWidth),
38
+ Math.max(
39
+ 100,
40
+ 100*Math.round(window.devicePixelRatio*window.innerWidth/100)
41
+ )
42
+ );
43
+
44
+ let scaleToHeight = Math.round(aWantedHeight*scaleToWidth/aWantedWidth);
45
+
46
+ url = aImageData["resizeUrl"].split("{scale}").join("width=" + scaleToWidth + ",height=" + scaleToHeight + ",fit=cover");
47
+ }
48
+
49
+ return url;
50
+ }
51
+
52
+ export let createContainScaledImageUrl = function(aImageData, aWantedWidth, aWantedHeight) {
53
+ if(!aImageData || !aImageData["url"]) {
54
+ return null;
55
+ }
56
+
57
+ let url = aImageData["url"];
58
+ if(url.substring(url.length-4).toLowerCase() === ".svg") {
59
+ return url;
60
+ }
61
+
62
+ if(aImageData["resizeUrl"]) {
63
+ let scaleToWidth = Math.min(
64
+ Math.round(window.devicePixelRatio*aWantedWidth),
65
+ Math.max(
66
+ 100,
67
+ 100*Math.round(window.devicePixelRatio*window.innerWidth/100)
68
+ )
69
+ );
70
+
71
+ let scaleToHeight = Math.round(aWantedHeight*scaleToWidth/aWantedWidth);
72
+
73
+ url = aImageData["resizeUrl"].split("{scale}").join("width=" + scaleToWidth + ",height=" + scaleToHeight + ",fit=contain");
74
+ }
75
+
76
+ return url;
77
+ }
package/utils/index.js CHANGED
@@ -1,3 +1,4 @@
1
1
  export * as ArrayFunctions from "./ArrayFunctions.js";
2
2
  export * as NumberFunctions from "./NumberFunctions.js";
3
- export * as StringFunctions from "./StringFunctions.js";
3
+ export * as StringFunctions from "./StringFunctions.js";
4
+ export * as UrlFunctions from "./UrlFunctions.js";
@@ -1,19 +0,0 @@
1
- import React from "react";
2
- import Dbm from "../../index.js";
3
-
4
- export default class EditorBlockName extends Dbm.react.BaseObject {
5
- _construct() {
6
- super._construct();
7
- }
8
-
9
- _renderMainElement() {
10
-
11
- let textSource = new Dbm.react.source.ContextVariableSource();
12
- textSource.item.path = "moduleData.editorData.name";
13
-
14
- return React.createElement("div", {"className": "editor-block-box editor-block-box-padding text-align-center"},
15
- Dbm.react.text.text(textSource),
16
- );
17
- }
18
- }
19
-