@kaspernj/api-maker 1.0.2023 → 1.0.2025
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/table/column-content.js +6 -6
- package/build/utils/card.js +11 -10
- package/build/utils/checkbox.js +14 -13
- package/link.sh +8 -0
- package/package.json +2 -2
- package/src/table/column-content.jsx +2 -2
- package/src/utils/card.jsx +24 -17
- package/src/utils/checkbox.jsx +9 -16
|
@@ -68,7 +68,7 @@ export default class ApiMakerTableColumnContent {
|
|
|
68
68
|
return this.columnsContentFromAttributeAndPath();
|
|
69
69
|
}
|
|
70
70
|
}
|
|
71
|
-
presentColumnValue
|
|
71
|
+
presentColumnValue = value => {
|
|
72
72
|
let contentText;
|
|
73
73
|
if (value instanceof Date) {
|
|
74
74
|
contentText = this.presentDateTime({
|
|
@@ -98,11 +98,11 @@ export default class ApiMakerTableColumnContent {
|
|
|
98
98
|
return contentText;
|
|
99
99
|
}
|
|
100
100
|
return /*#__PURE__*/React.createElement(Text, null, contentText);
|
|
101
|
-
}
|
|
102
|
-
presentDateTime({
|
|
101
|
+
};
|
|
102
|
+
presentDateTime = ({
|
|
103
103
|
apiMakerType,
|
|
104
104
|
value
|
|
105
|
-
}) {
|
|
105
|
+
}) => {
|
|
106
106
|
if (!apiMakerType || apiMakerType == "time") {
|
|
107
107
|
const dateTimeFormatName = this.table.props.defaultDateTimeFormatName || "time.formats.default";
|
|
108
108
|
return this.l(dateTimeFormatName, value);
|
|
@@ -112,6 +112,6 @@ export default class ApiMakerTableColumnContent {
|
|
|
112
112
|
} else {
|
|
113
113
|
throw new Error(`Unhandled type: ${apiMakerType}`);
|
|
114
114
|
}
|
|
115
|
-
}
|
|
115
|
+
};
|
|
116
116
|
}
|
|
117
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["digs","inflection","modelCallbackArgs","MoneyFormatter","React","Text","ApiMakerTableColumnContent","constructor","column","l","mode","model","t","table","columnContentFromContentArg","args","value","content","presentColumnValue","columnsContentFromAttributeAndPath","attribute","attributeName","attributeNameUnderscore","underscore","path","currentModel","length","pathPart","Error","modelName","human","isAttributeLoaded","attributes","find","name","modelColumn","getColumn","getType","contentText","presentDateTime","apiMakerType","createElement","Date","isMoney","format","defaultValue","Array","isArray","map","valuePart","filter","Boolean","join","dateTimeFormatName","props","defaultDateTimeFormatName","dateFormatName","defaultDateFormatName"],"sources":["../../src/table/column-content.jsx"],"sourcesContent":["import {digs} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport modelCallbackArgs from \"./model-callback-args\"\nimport MoneyFormatter from \"../money-formatter\"\nimport React from \"react\"\nimport Text from \"../utils/text\"\n\nexport default class ApiMakerTableColumnContent {\n  constructor({column, l, mode = \"react-native\", model, t, table}) {\n    this.column = column\n    this.l = l\n    this.mode = mode\n    this.model = model\n    this.t = t\n    this.table = table\n  }\n\n  columnContentFromContentArg() {\n    const args = modelCallbackArgs(this.table, this.model)\n\n    args.mode = this.mode\n\n    const value = this.column.content(args)\n\n    return this.presentColumnValue(value)\n  }\n\n  columnsContentFromAttributeAndPath() {\n    const {attribute: attributeName} = digs(this.column, \"attribute\")\n    const attributeNameUnderscore = inflection.underscore(attributeName)\n    const path = this.column.path || []\n    let value\n    let currentModel = this.model\n\n    if (path.length > 0) {\n      for (const pathPart of path) {\n        currentModel = currentModel[pathPart]()\n        if (!currentModel) return\n      }\n    }\n\n    if (!(attributeName in currentModel)) {\n      throw new Error(`${currentModel.constructor.modelName().human()} doesn't respond to ${attributeName}`)\n    }\n\n    if (currentModel.isAttributeLoaded(attributeName)) {\n      value = currentModel[attributeName]()\n    }\n\n    const attribute = currentModel.constructor.attributes().find((attribute) => attribute.name() == attributeNameUnderscore)\n    const modelColumn = attribute?.getColumn()\n\n    if (modelColumn?.getType() == \"date\" && value) {\n      const contentText = this.presentDateTime({apiMakerType: \"date\", value})\n\n      if (this.mode == \"html\") {\n        return contentText\n      } else {\n        return (\n          <Text>{contentText}</Text>\n        )\n      }\n    }\n\n    return this.presentColumnValue(value)\n  }\n\n  content() {\n    if (this.column.content) {\n      return this.columnContentFromContentArg()\n    } else if (!this.column.content && this.column.attribute) {\n      return this.columnsContentFromAttributeAndPath()\n    }\n  }\n\n  presentColumnValue(value) {\n    let contentText\n\n    if (value instanceof Date) {\n      contentText = this.presentDateTime({value})\n    } else if (MoneyFormatter.isMoney(value)) {\n      contentText = MoneyFormatter.format(value)\n    } else if (typeof value == \"boolean\") {\n      if (value) {\n        contentText = this.t(\"js.shared.yes\", {defaultValue: \"Yes\"})\n      } else {\n        contentText = this.t(\"js.shared.no\", {defaultValue: \"No\"})\n      }\n    } else if (Array.isArray(value)) {\n      contentText = value\n        .map((valuePart) => this.presentColumnValue(valuePart))\n        .filter((valuePart) => Boolean(valuePart))\n        .join(\", \")\n\n    } else if (typeof value == \"string\") {\n      contentText = value\n    } else {\n      // Its a React node - just return it and trust the provider to be HTML compatible.\n      return value\n    }\n\n    if (this.mode == \"html\") {\n      return contentText\n    }\n\n    return <Text>{contentText}</Text>\n  }\n\n  presentDateTime({apiMakerType, value}) {\n    if (!apiMakerType || apiMakerType == \"time\") {\n      const dateTimeFormatName = this.table.props.defaultDateTimeFormatName || \"time.formats.default\"\n\n      return this.l(dateTimeFormatName, value)\n    } else if (apiMakerType == \"date\") {\n      const dateFormatName = this.table.props.defaultDateFormatName || \"date.formats.default\"\n\n      return this.l(dateFormatName, value)\n    } else {\n      throw new Error(`Unhandled type: ${apiMakerType}`)\n    }\n  }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["digs","inflection","modelCallbackArgs","MoneyFormatter","React","Text","ApiMakerTableColumnContent","constructor","column","l","mode","model","t","table","columnContentFromContentArg","args","value","content","presentColumnValue","columnsContentFromAttributeAndPath","attribute","attributeName","attributeNameUnderscore","underscore","path","currentModel","length","pathPart","Error","modelName","human","isAttributeLoaded","attributes","find","name","modelColumn","getColumn","getType","contentText","presentDateTime","apiMakerType","createElement","Date","isMoney","format","defaultValue","Array","isArray","map","valuePart","filter","Boolean","join","dateTimeFormatName","props","defaultDateTimeFormatName","dateFormatName","defaultDateFormatName"],"sources":["../../src/table/column-content.jsx"],"sourcesContent":["import {digs} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport modelCallbackArgs from \"./model-callback-args\"\nimport MoneyFormatter from \"../money-formatter\"\nimport React from \"react\"\nimport Text from \"../utils/text\"\n\nexport default class ApiMakerTableColumnContent {\n  constructor({column, l, mode = \"react-native\", model, t, table}) {\n    this.column = column\n    this.l = l\n    this.mode = mode\n    this.model = model\n    this.t = t\n    this.table = table\n  }\n\n  columnContentFromContentArg() {\n    const args = modelCallbackArgs(this.table, this.model)\n\n    args.mode = this.mode\n\n    const value = this.column.content(args)\n\n    return this.presentColumnValue(value)\n  }\n\n  columnsContentFromAttributeAndPath() {\n    const {attribute: attributeName} = digs(this.column, \"attribute\")\n    const attributeNameUnderscore = inflection.underscore(attributeName)\n    const path = this.column.path || []\n    let value\n    let currentModel = this.model\n\n    if (path.length > 0) {\n      for (const pathPart of path) {\n        currentModel = currentModel[pathPart]()\n        if (!currentModel) return\n      }\n    }\n\n    if (!(attributeName in currentModel)) {\n      throw new Error(`${currentModel.constructor.modelName().human()} doesn't respond to ${attributeName}`)\n    }\n\n    if (currentModel.isAttributeLoaded(attributeName)) {\n      value = currentModel[attributeName]()\n    }\n\n    const attribute = currentModel.constructor.attributes().find((attribute) => attribute.name() == attributeNameUnderscore)\n    const modelColumn = attribute?.getColumn()\n\n    if (modelColumn?.getType() == \"date\" && value) {\n      const contentText = this.presentDateTime({apiMakerType: \"date\", value})\n\n      if (this.mode == \"html\") {\n        return contentText\n      } else {\n        return (\n          <Text>{contentText}</Text>\n        )\n      }\n    }\n\n    return this.presentColumnValue(value)\n  }\n\n  content() {\n    if (this.column.content) {\n      return this.columnContentFromContentArg()\n    } else if (!this.column.content && this.column.attribute) {\n      return this.columnsContentFromAttributeAndPath()\n    }\n  }\n\n  presentColumnValue = (value) => {\n    let contentText\n\n    if (value instanceof Date) {\n      contentText = this.presentDateTime({value})\n    } else if (MoneyFormatter.isMoney(value)) {\n      contentText = MoneyFormatter.format(value)\n    } else if (typeof value == \"boolean\") {\n      if (value) {\n        contentText = this.t(\"js.shared.yes\", {defaultValue: \"Yes\"})\n      } else {\n        contentText = this.t(\"js.shared.no\", {defaultValue: \"No\"})\n      }\n    } else if (Array.isArray(value)) {\n      contentText = value\n        .map((valuePart) => this.presentColumnValue(valuePart))\n        .filter((valuePart) => Boolean(valuePart))\n        .join(\", \")\n\n    } else if (typeof value == \"string\") {\n      contentText = value\n    } else {\n      // Its a React node - just return it and trust the provider to be HTML compatible.\n      return value\n    }\n\n    if (this.mode == \"html\") {\n      return contentText\n    }\n\n    return <Text>{contentText}</Text>\n  }\n\n  presentDateTime = ({apiMakerType, value}) => {\n    if (!apiMakerType || apiMakerType == \"time\") {\n      const dateTimeFormatName = this.table.props.defaultDateTimeFormatName || \"time.formats.default\"\n\n      return this.l(dateTimeFormatName, value)\n    } else if (apiMakerType == \"date\") {\n      const dateFormatName = this.table.props.defaultDateFormatName || \"date.formats.default\"\n\n      return this.l(dateFormatName, value)\n    } else {\n      throw new Error(`Unhandled type: ${apiMakerType}`)\n    }\n  }\n}\n"],"mappings":"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","ignoreList":[]}
|
package/build/utils/card.js
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import
|
|
1
|
+
import React, { useMemo } from "react";
|
|
2
|
+
import classNames from "classnames";
|
|
2
3
|
import memo from "set-state-compare/src/memo";
|
|
3
4
|
import PropTypes from "prop-types";
|
|
4
5
|
import propTypesExact from "prop-types-exact";
|
|
5
|
-
import { shapeComponent } from "set-state-compare/src/shape-component";
|
|
6
|
+
import { shapeComponent, ShapeComponent } from "set-state-compare/src/shape-component";
|
|
6
7
|
import Text from "./text";
|
|
7
|
-
export default memo(shapeComponent(class ApiMakerUtilsCard extends
|
|
8
|
+
export default memo(shapeComponent(class ApiMakerUtilsCard extends ShapeComponent {
|
|
8
9
|
static propTypes = propTypesExact({
|
|
9
10
|
children: PropTypes.node,
|
|
10
11
|
controls: PropTypes.node,
|
|
@@ -24,28 +25,28 @@ export default memo(shapeComponent(class ApiMakerUtilsCard extends BaseComponent
|
|
|
24
25
|
component,
|
|
25
26
|
...restDataSet
|
|
26
27
|
} = dataSet || {};
|
|
27
|
-
const actualDataSet = Object.assign({
|
|
28
|
+
const actualDataSet = useMemo(() => Object.assign({
|
|
28
29
|
component: classNames("api-maker/utils/card", component)
|
|
29
|
-
}, restDataSet);
|
|
30
|
-
const actualStyle = Object.assign({
|
|
30
|
+
}, restDataSet), [component, restDataSet]);
|
|
31
|
+
const actualStyle = useMemo(() => Object.assign({
|
|
31
32
|
backgroundColor: "#fff",
|
|
32
33
|
borderRadius: 15,
|
|
33
34
|
padding: 30
|
|
34
|
-
}, style);
|
|
35
|
+
}, style), [style]);
|
|
35
36
|
return /*#__PURE__*/React.createElement(View, {
|
|
36
37
|
dataSet: actualDataSet,
|
|
37
38
|
style: actualStyle
|
|
38
39
|
}, controls && /*#__PURE__*/React.createElement(View, {
|
|
39
|
-
style: {
|
|
40
|
+
style: this.controlsViewStyle ||= {
|
|
40
41
|
position: "absolute",
|
|
41
42
|
top: 15,
|
|
42
43
|
right: 15
|
|
43
44
|
}
|
|
44
45
|
}, controls), header && /*#__PURE__*/React.createElement(Text, {
|
|
45
|
-
style: {
|
|
46
|
+
style: this.headerTextStyle ||= {
|
|
46
47
|
fontSize: 24
|
|
47
48
|
}
|
|
48
49
|
}, header), children);
|
|
49
50
|
}
|
|
50
51
|
}));
|
|
51
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsInVzZU1lbW8iLCJjbGFzc05hbWVzIiwibWVtbyIsIlByb3BUeXBlcyIsInByb3BUeXBlc0V4YWN0Iiwic2hhcGVDb21wb25lbnQiLCJTaGFwZUNvbXBvbmVudCIsIlRleHQiLCJBcGlNYWtlclV0aWxzQ2FyZCIsInByb3BUeXBlcyIsImNoaWxkcmVuIiwibm9kZSIsImNvbnRyb2xzIiwiZGF0YVNldCIsIm9iamVjdCIsImhlYWRlciIsInN0cmluZyIsInN0eWxlIiwicmVuZGVyIiwicHJvcHMiLCJjb21wb25lbnQiLCJyZXN0RGF0YVNldCIsImFjdHVhbERhdGFTZXQiLCJPYmplY3QiLCJhc3NpZ24iLCJhY3R1YWxTdHlsZSIsImJhY2tncm91bmRDb2xvciIsImJvcmRlclJhZGl1cyIsInBhZGRpbmciLCJjcmVhdGVFbGVtZW50IiwiVmlldyIsImNvbnRyb2xzVmlld1N0eWxlIiwicG9zaXRpb24iLCJ0b3AiLCJyaWdodCIsImhlYWRlclRleHRTdHlsZSIsImZvbnRTaXplIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2NhcmQuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge3VzZU1lbW99IGZyb20gXCJyZWFjdFwiXG5pbXBvcnQgY2xhc3NOYW1lcyBmcm9tIFwiY2xhc3NuYW1lc1wiXG5pbXBvcnQgbWVtbyBmcm9tIFwic2V0LXN0YXRlLWNvbXBhcmUvc3JjL21lbW9cIlxuaW1wb3J0IFByb3BUeXBlcyBmcm9tIFwicHJvcC10eXBlc1wiXG5pbXBvcnQgcHJvcFR5cGVzRXhhY3QgZnJvbSBcInByb3AtdHlwZXMtZXhhY3RcIlxuaW1wb3J0IHtzaGFwZUNvbXBvbmVudCwgU2hhcGVDb21wb25lbnR9IGZyb20gXCJzZXQtc3RhdGUtY29tcGFyZS9zcmMvc2hhcGUtY29tcG9uZW50XCJcbmltcG9ydCBUZXh0IGZyb20gXCIuL3RleHRcIlxuXG5leHBvcnQgZGVmYXVsdCBtZW1vKHNoYXBlQ29tcG9uZW50KGNsYXNzIEFwaU1ha2VyVXRpbHNDYXJkIGV4dGVuZHMgU2hhcGVDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0gcHJvcFR5cGVzRXhhY3Qoe1xuICAgIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgICBjb250cm9sczogUHJvcFR5cGVzLm5vZGUsXG4gICAgZGF0YVNldDogUHJvcFR5cGVzLm9iamVjdCxcbiAgICBoZWFkZXI6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgc3R5bGU6IFByb3BUeXBlcy5vYmplY3RcbiAgfSlcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3Qge2NoaWxkcmVuLCBjb250cm9scywgZGF0YVNldCwgaGVhZGVyLCBzdHlsZX0gPSB0aGlzLnByb3BzXG4gICAgY29uc3Qge2NvbXBvbmVudCwgLi4ucmVzdERhdGFTZXR9ID0gZGF0YVNldCB8fCB7fVxuXG4gICAgY29uc3QgYWN0dWFsRGF0YVNldCA9IHVzZU1lbW8oKCkgPT5cbiAgICAgIE9iamVjdC5hc3NpZ24oXG4gICAgICAgIHtjb21wb25lbnQ6IGNsYXNzTmFtZXMoXCJhcGktbWFrZXIvdXRpbHMvY2FyZFwiLCBjb21wb25lbnQpfSxcbiAgICAgICAgcmVzdERhdGFTZXRcbiAgICAgIClcbiAgICAsIFtjb21wb25lbnQsIHJlc3REYXRhU2V0XSlcblxuICAgIGNvbnN0IGFjdHVhbFN0eWxlID0gdXNlTWVtbygoKSA9PlxuICAgICAgT2JqZWN0LmFzc2lnbihcbiAgICAgICAge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogXCIjZmZmXCIsXG4gICAgICAgICAgYm9yZGVyUmFkaXVzOiAxNSxcbiAgICAgICAgICBwYWRkaW5nOiAzMFxuICAgICAgICB9LFxuICAgICAgICBzdHlsZVxuICAgICAgKVxuICAgICwgW3N0eWxlXSlcblxuICAgIHJldHVybiAoXG4gICAgICA8VmlldyBkYXRhU2V0PXthY3R1YWxEYXRhU2V0fSBzdHlsZT17YWN0dWFsU3R5bGV9PlxuICAgICAgICB7Y29udHJvbHMgJiZcbiAgICAgICAgICA8VmlldyBzdHlsZT17dGhpcy5jb250cm9sc1ZpZXdTdHlsZSB8fD0ge3Bvc2l0aW9uOiBcImFic29sdXRlXCIsIHRvcDogMTUsIHJpZ2h0OiAxNX19PlxuICAgICAgICAgICAge2NvbnRyb2xzfVxuICAgICAgICAgIDwvVmlldz5cbiAgICAgICAgfVxuICAgICAgICB7aGVhZGVyICYmXG4gICAgICAgICAgPFRleHQgc3R5bGU9e3RoaXMuaGVhZGVyVGV4dFN0eWxlIHx8PSB7Zm9udFNpemU6IDI0fX0+XG4gICAgICAgICAgICB7aGVhZGVyfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgfVxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1ZpZXc+XG4gICAgKVxuICB9XG59KSlcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsS0FBSyxJQUFHQyxPQUFPLFFBQU8sT0FBTztBQUNwQyxPQUFPQyxVQUFVLE1BQU0sWUFBWTtBQUNuQyxPQUFPQyxJQUFJLE1BQU0sNEJBQTRCO0FBQzdDLE9BQU9DLFNBQVMsTUFBTSxZQUFZO0FBQ2xDLE9BQU9DLGNBQWMsTUFBTSxrQkFBa0I7QUFDN0MsU0FBUUMsY0FBYyxFQUFFQyxjQUFjLFFBQU8sdUNBQXVDO0FBQ3BGLE9BQU9DLElBQUksTUFBTSxRQUFRO0FBRXpCLGVBQWVMLElBQUksQ0FBQ0csY0FBYyxDQUFDLE1BQU1HLGlCQUFpQixTQUFTRixjQUFjLENBQUM7RUFDaEYsT0FBT0csU0FBUyxHQUFHTCxjQUFjLENBQUM7SUFDaENNLFFBQVEsRUFBRVAsU0FBUyxDQUFDUSxJQUFJO0lBQ3hCQyxRQUFRLEVBQUVULFNBQVMsQ0FBQ1EsSUFBSTtJQUN4QkUsT0FBTyxFQUFFVixTQUFTLENBQUNXLE1BQU07SUFDekJDLE1BQU0sRUFBRVosU0FBUyxDQUFDYSxNQUFNO0lBQ3hCQyxLQUFLLEVBQUVkLFNBQVMsQ0FBQ1c7RUFDbkIsQ0FBQyxDQUFDO0VBRUZJLE1BQU1BLENBQUEsRUFBRztJQUNQLE1BQU07TUFBQ1IsUUFBUTtNQUFFRSxRQUFRO01BQUVDLE9BQU87TUFBRUUsTUFBTTtNQUFFRTtJQUFLLENBQUMsR0FBRyxJQUFJLENBQUNFLEtBQUs7SUFDL0QsTUFBTTtNQUFDQyxTQUFTO01BQUUsR0FBR0M7SUFBVyxDQUFDLEdBQUdSLE9BQU8sSUFBSSxDQUFDLENBQUM7SUFFakQsTUFBTVMsYUFBYSxHQUFHdEIsT0FBTyxDQUFDLE1BQzVCdUIsTUFBTSxDQUFDQyxNQUFNLENBQ1g7TUFBQ0osU0FBUyxFQUFFbkIsVUFBVSxDQUFDLHNCQUFzQixFQUFFbUIsU0FBUztJQUFDLENBQUMsRUFDMURDLFdBQ0YsQ0FBQyxFQUNELENBQUNELFNBQVMsRUFBRUMsV0FBVyxDQUFDLENBQUM7SUFFM0IsTUFBTUksV0FBVyxHQUFHekIsT0FBTyxDQUFDLE1BQzFCdUIsTUFBTSxDQUFDQyxNQUFNLENBQ1g7TUFDRUUsZUFBZSxFQUFFLE1BQU07TUFDdkJDLFlBQVksRUFBRSxFQUFFO01BQ2hCQyxPQUFPLEVBQUU7SUFDWCxDQUFDLEVBQ0RYLEtBQ0YsQ0FBQyxFQUNELENBQUNBLEtBQUssQ0FBQyxDQUFDO0lBRVYsb0JBQ0VsQixLQUFBLENBQUE4QixhQUFBLENBQUNDLElBQUk7TUFBQ2pCLE9BQU8sRUFBRVMsYUFBYztNQUFDTCxLQUFLLEVBQUVRO0lBQVksR0FDOUNiLFFBQVEsaUJBQ1BiLEtBQUEsQ0FBQThCLGFBQUEsQ0FBQ0MsSUFBSTtNQUFDYixLQUFLLEVBQUUsSUFBSSxDQUFDYyxpQkFBaUIsS0FBSztRQUFDQyxRQUFRLEVBQUUsVUFBVTtRQUFFQyxHQUFHLEVBQUUsRUFBRTtRQUFFQyxLQUFLLEVBQUU7TUFBRTtJQUFFLEdBQ2hGdEIsUUFDRyxDQUFDLEVBRVJHLE1BQU0saUJBQ0xoQixLQUFBLENBQUE4QixhQUFBLENBQUN0QixJQUFJO01BQUNVLEtBQUssRUFBRSxJQUFJLENBQUNrQixlQUFlLEtBQUs7UUFBQ0MsUUFBUSxFQUFFO01BQUU7SUFBRSxHQUNsRHJCLE1BQ0csQ0FBQyxFQUVSTCxRQUNHLENBQUM7RUFFWDtBQUNGLENBQUMsQ0FBQyxDQUFDIiwiaWdub3JlTGlzdCI6W119
|
package/build/utils/checkbox.js
CHANGED
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
import BaseComponent from "../base-component";
|
|
2
2
|
import { CheckBox, Pressable, View } from "react-native";
|
|
3
|
+
import React, { useMemo } from "react";
|
|
3
4
|
import memo from "set-state-compare/src/memo";
|
|
4
5
|
import PropTypes from "prop-types";
|
|
5
6
|
import propTypesExact from "prop-types-exact";
|
|
6
|
-
import React from "react";
|
|
7
7
|
import { shapeComponent } from "set-state-compare/src/shape-component";
|
|
8
8
|
import Text from "./text";
|
|
9
9
|
export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseComponent {
|
|
10
10
|
static defaultProps = {
|
|
11
|
-
|
|
11
|
+
dataSet: null,
|
|
12
|
+
label: undefined,
|
|
13
|
+
style: null
|
|
12
14
|
};
|
|
13
15
|
static propTypes = propTypesExact({
|
|
14
16
|
checked: PropTypes.bool,
|
|
@@ -36,20 +38,19 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
|
|
|
36
38
|
isChecked
|
|
37
39
|
} = this.tt;
|
|
38
40
|
const {
|
|
39
|
-
|
|
41
|
+
dataSet,
|
|
42
|
+
label,
|
|
43
|
+
style
|
|
40
44
|
} = this.p;
|
|
41
|
-
const {
|
|
42
|
-
dataSet
|
|
43
|
-
} = this.props;
|
|
44
|
-
const actualStyle = Object.assign({
|
|
45
|
+
const actualStyle = useMemo(() => Object.assign({
|
|
45
46
|
flexDirection: "row",
|
|
46
47
|
alignItems: "center"
|
|
47
|
-
},
|
|
48
|
-
const actualDataSet = Object.assign({
|
|
48
|
+
}, style), [style]);
|
|
49
|
+
const actualDataSet = useMemo(() => Object.assign({
|
|
49
50
|
checked: isChecked
|
|
50
|
-
}, dataSet);
|
|
51
|
+
}, dataSet), [dataSet, isChecked]);
|
|
51
52
|
return /*#__PURE__*/React.createElement(View, {
|
|
52
|
-
dataSet: {
|
|
53
|
+
dataSet: this.viewContainerDataSet ||= {
|
|
53
54
|
component: "api-maker/utils/checkbox"
|
|
54
55
|
},
|
|
55
56
|
style: actualStyle
|
|
@@ -60,7 +61,7 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
|
|
|
60
61
|
}), label && /*#__PURE__*/React.createElement(Pressable, {
|
|
61
62
|
onPress: this.tt.onLabelPressed
|
|
62
63
|
}, /*#__PURE__*/React.createElement(Text, {
|
|
63
|
-
style: {
|
|
64
|
+
style: this.textStyle ||= {
|
|
64
65
|
marginLeft: 3
|
|
65
66
|
}
|
|
66
67
|
}, label)));
|
|
@@ -75,4 +76,4 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
|
|
|
75
76
|
});
|
|
76
77
|
};
|
|
77
78
|
}));
|
|
78
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJCYXNlQ29tcG9uZW50IiwiQ2hlY2tCb3giLCJQcmVzc2FibGUiLCJWaWV3IiwiUmVhY3QiLCJ1c2VNZW1vIiwibWVtbyIsIlByb3BUeXBlcyIsInByb3BUeXBlc0V4YWN0Iiwic2hhcGVDb21wb25lbnQiLCJUZXh0IiwiQXBpTWFrZXJVdGlsc0NoZWNrYm94IiwiZGVmYXVsdFByb3BzIiwiZGF0YVNldCIsImxhYmVsIiwidW5kZWZpbmVkIiwic3R5bGUiLCJwcm9wVHlwZXMiLCJjaGVja2VkIiwiYm9vbCIsIm9iamVjdCIsImRlZmF1bHRDaGVja2VkIiwic3RyaW5nIiwib25DaGVja2VkQ2hhbmdlIiwiZnVuYyIsInNldHVwIiwidXNlU3RhdGVzIiwicHJvcHMiLCJpc0NoZWNrZWQiLCJjYWxjdWxhdGVDaGVja2VkIiwicCIsInMiLCJyZW5kZXIiLCJ0dCIsImFjdHVhbFN0eWxlIiwiT2JqZWN0IiwiYXNzaWduIiwiZmxleERpcmVjdGlvbiIsImFsaWduSXRlbXMiLCJhY3R1YWxEYXRhU2V0IiwiY3JlYXRlRWxlbWVudCIsInZpZXdDb250YWluZXJEYXRhU2V0IiwiY29tcG9uZW50Iiwib25WYWx1ZUNoYW5nZSIsInZhbHVlIiwib25QcmVzcyIsIm9uTGFiZWxQcmVzc2VkIiwidGV4dFN0eWxlIiwibWFyZ2luTGVmdCIsImUiLCJzZXRTdGF0ZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jaGVja2JveC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJhc2VDb21wb25lbnQgZnJvbSBcIi4uL2Jhc2UtY29tcG9uZW50XCJcbmltcG9ydCB7Q2hlY2tCb3gsIFByZXNzYWJsZSwgVmlld30gZnJvbSBcInJlYWN0LW5hdGl2ZVwiXG5pbXBvcnQgUmVhY3QsIHt1c2VNZW1vfSBmcm9tIFwicmVhY3RcIlxuaW1wb3J0IG1lbW8gZnJvbSBcInNldC1zdGF0ZS1jb21wYXJlL3NyYy9tZW1vXCJcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSBcInByb3AtdHlwZXNcIlxuaW1wb3J0IHByb3BUeXBlc0V4YWN0IGZyb20gXCJwcm9wLXR5cGVzLWV4YWN0XCJcbmltcG9ydCB7c2hhcGVDb21wb25lbnR9IGZyb20gXCJzZXQtc3RhdGUtY29tcGFyZS9zcmMvc2hhcGUtY29tcG9uZW50XCJcbmltcG9ydCBUZXh0IGZyb20gXCIuL3RleHRcIlxuXG5leHBvcnQgZGVmYXVsdCBtZW1vKHNoYXBlQ29tcG9uZW50KGNsYXNzIEFwaU1ha2VyVXRpbHNDaGVja2JveCBleHRlbmRzIEJhc2VDb21wb25lbnQge1xuICBzdGF0aWMgZGVmYXVsdFByb3BzID0ge1xuICAgIGRhdGFTZXQ6IG51bGwsXG4gICAgbGFiZWw6IHVuZGVmaW5lZCxcbiAgICBzdHlsZTogbnVsbFxuICB9XG5cbiAgc3RhdGljIHByb3BUeXBlcyA9IHByb3BUeXBlc0V4YWN0KHtcbiAgICBjaGVja2VkOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBkYXRhU2V0OiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIGRlZmF1bHRDaGVja2VkOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBsYWJlbDogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBvbkNoZWNrZWRDaGFuZ2U6IFByb3BUeXBlcy5mdW5jLFxuICAgIHN0eWxlOiBQcm9wVHlwZXMub2JqZWN0XG4gIH0pXG5cbiAgc2V0dXAoKSB7XG4gICAgdGhpcy51c2VTdGF0ZXMoe1xuICAgICAgY2hlY2tlZDogdGhpcy5wcm9wcy5kZWZhdWx0Q2hlY2tlZFxuICAgIH0pXG4gICAgdGhpcy5pc0NoZWNrZWQgPSB0aGlzLmNhbGN1bGF0ZUNoZWNrZWQoKVxuICB9XG5cbiAgY2FsY3VsYXRlQ2hlY2tlZCgpIHtcbiAgICBpZiAoXCJjaGVja2VkXCIgaW4gdGhpcy5wcm9wcykge1xuICAgICAgcmV0dXJuIHRoaXMucC5jaGVja2VkXG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiB0aGlzLnMuY2hlY2tlZFxuICAgIH1cbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7aXNDaGVja2VkfSA9IHRoaXMudHRcbiAgICBjb25zdCB7ZGF0YVNldCwgbGFiZWwsIHN0eWxlfSA9IHRoaXMucFxuICAgIGNvbnN0IGFjdHVhbFN0eWxlID0gdXNlTWVtbygoKSA9PiBPYmplY3QuYXNzaWduKHtmbGV4RGlyZWN0aW9uOiBcInJvd1wiLCBhbGlnbkl0ZW1zOiBcImNlbnRlclwifSwgc3R5bGUpLCBbc3R5bGVdKVxuICAgIGNvbnN0IGFjdHVhbERhdGFTZXQgPSB1c2VNZW1vKCgpID0+IE9iamVjdC5hc3NpZ24oe2NoZWNrZWQ6IGlzQ2hlY2tlZH0sIGRhdGFTZXQpLCBbZGF0YVNldCwgaXNDaGVja2VkXSlcblxuICAgIHJldHVybiAoXG4gICAgICA8Vmlld1xuICAgICAgICBkYXRhU2V0PXt0aGlzLnZpZXdDb250YWluZXJEYXRhU2V0IHx8PSB7Y29tcG9uZW50OiBcImFwaS1tYWtlci91dGlscy9jaGVja2JveFwifX1cbiAgICAgICAgc3R5bGU9e2FjdHVhbFN0eWxlfVxuICAgICAgPlxuICAgICAgICA8Q2hlY2tCb3ggZGF0YVNldD17YWN0dWFsRGF0YVNldH0gb25WYWx1ZUNoYW5nZT17dGhpcy50dC5vblZhbHVlQ2hhbmdlfSB2YWx1ZT17aXNDaGVja2VkfSAvPlxuICAgICAgICB7bGFiZWwgJiZcbiAgICAgICAgICA8UHJlc3NhYmxlIG9uUHJlc3M9e3RoaXMudHQub25MYWJlbFByZXNzZWR9PlxuICAgICAgICAgICAgPFRleHQgc3R5bGU9e3RoaXMudGV4dFN0eWxlIHx8PSB7bWFyZ2luTGVmdDogM319PlxuICAgICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9QcmVzc2FibGU+XG4gICAgICAgIH1cbiAgICAgIDwvVmlldz5cbiAgICApXG4gIH1cblxuICBvbkxhYmVsUHJlc3NlZCA9ICgpID0+IHRoaXMucC5vbkNoZWNrZWRDaGFuZ2UoIXRoaXMudHQuaXNDaGVja2VkKVxuXG4gIG9uVmFsdWVDaGFuZ2UgPSAoZSkgPT4ge1xuICAgIGlmICh0aGlzLnByb3BzLm9uQ2hlY2tlZENoYW5nZSkge1xuICAgICAgdGhpcy5wLm9uQ2hlY2tlZENoYW5nZShlKVxuICAgIH1cblxuICAgIHRoaXMuc2V0U3RhdGUoe2NoZWNrZWQ6ICF0aGlzLnR0LmlzQ2hlY2tlZH0pXG4gIH1cbn0pKVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxhQUFhLE1BQU0sbUJBQW1CO0FBQzdDLFNBQVFDLFFBQVEsRUFBRUMsU0FBUyxFQUFFQyxJQUFJLFFBQU8sY0FBYztBQUN0RCxPQUFPQyxLQUFLLElBQUdDLE9BQU8sUUFBTyxPQUFPO0FBQ3BDLE9BQU9DLElBQUksTUFBTSw0QkFBNEI7QUFDN0MsT0FBT0MsU0FBUyxNQUFNLFlBQVk7QUFDbEMsT0FBT0MsY0FBYyxNQUFNLGtCQUFrQjtBQUM3QyxTQUFRQyxjQUFjLFFBQU8sdUNBQXVDO0FBQ3BFLE9BQU9DLElBQUksTUFBTSxRQUFRO0FBRXpCLGVBQWVKLElBQUksQ0FBQ0csY0FBYyxDQUFDLE1BQU1FLHFCQUFxQixTQUFTWCxhQUFhLENBQUM7RUFDbkYsT0FBT1ksWUFBWSxHQUFHO0lBQ3BCQyxPQUFPLEVBQUUsSUFBSTtJQUNiQyxLQUFLLEVBQUVDLFNBQVM7SUFDaEJDLEtBQUssRUFBRTtFQUNULENBQUM7RUFFRCxPQUFPQyxTQUFTLEdBQUdULGNBQWMsQ0FBQztJQUNoQ1UsT0FBTyxFQUFFWCxTQUFTLENBQUNZLElBQUk7SUFDdkJOLE9BQU8sRUFBRU4sU0FBUyxDQUFDYSxNQUFNO0lBQ3pCQyxjQUFjLEVBQUVkLFNBQVMsQ0FBQ1ksSUFBSTtJQUM5QkwsS0FBSyxFQUFFUCxTQUFTLENBQUNlLE1BQU07SUFDdkJDLGVBQWUsRUFBRWhCLFNBQVMsQ0FBQ2lCLElBQUk7SUFDL0JSLEtBQUssRUFBRVQsU0FBUyxDQUFDYTtFQUNuQixDQUFDLENBQUM7RUFFRkssS0FBS0EsQ0FBQSxFQUFHO0lBQ04sSUFBSSxDQUFDQyxTQUFTLENBQUM7TUFDYlIsT0FBTyxFQUFFLElBQUksQ0FBQ1MsS0FBSyxDQUFDTjtJ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
|
package/link.sh
ADDED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kaspernj/api-maker",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.2025",
|
|
4
4
|
"description": "My new module",
|
|
5
5
|
"main": "build/index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -64,7 +64,7 @@
|
|
|
64
64
|
"@babel/preset-env": "^7.12.11",
|
|
65
65
|
"@babel/preset-react": "^7.26.3",
|
|
66
66
|
"babel-jest": "^29.0.1",
|
|
67
|
-
"eslint": "^
|
|
67
|
+
"eslint": "^9.23.0",
|
|
68
68
|
"eslint-find-rules": "^5.0.0",
|
|
69
69
|
"eslint-plugin-jest": "^28.2.0",
|
|
70
70
|
"eslint-plugin-react": "^7.23.2",
|
|
@@ -73,7 +73,7 @@ export default class ApiMakerTableColumnContent {
|
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
75
|
|
|
76
|
-
presentColumnValue(value) {
|
|
76
|
+
presentColumnValue = (value) => {
|
|
77
77
|
let contentText
|
|
78
78
|
|
|
79
79
|
if (value instanceof Date) {
|
|
@@ -106,7 +106,7 @@ export default class ApiMakerTableColumnContent {
|
|
|
106
106
|
return <Text>{contentText}</Text>
|
|
107
107
|
}
|
|
108
108
|
|
|
109
|
-
presentDateTime({apiMakerType, value}) {
|
|
109
|
+
presentDateTime = ({apiMakerType, value}) => {
|
|
110
110
|
if (!apiMakerType || apiMakerType == "time") {
|
|
111
111
|
const dateTimeFormatName = this.table.props.defaultDateTimeFormatName || "time.formats.default"
|
|
112
112
|
|
package/src/utils/card.jsx
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
|
-
import
|
|
1
|
+
import React, {useMemo} from "react"
|
|
2
|
+
import classNames from "classnames"
|
|
2
3
|
import memo from "set-state-compare/src/memo"
|
|
3
4
|
import PropTypes from "prop-types"
|
|
4
5
|
import propTypesExact from "prop-types-exact"
|
|
5
|
-
import {shapeComponent} from "set-state-compare/src/shape-component"
|
|
6
|
+
import {shapeComponent, ShapeComponent} from "set-state-compare/src/shape-component"
|
|
6
7
|
import Text from "./text"
|
|
7
8
|
|
|
8
|
-
export default memo(shapeComponent(class ApiMakerUtilsCard extends
|
|
9
|
+
export default memo(shapeComponent(class ApiMakerUtilsCard extends ShapeComponent {
|
|
9
10
|
static propTypes = propTypesExact({
|
|
10
11
|
children: PropTypes.node,
|
|
11
12
|
controls: PropTypes.node,
|
|
@@ -17,28 +18,34 @@ export default memo(shapeComponent(class ApiMakerUtilsCard extends BaseComponent
|
|
|
17
18
|
render() {
|
|
18
19
|
const {children, controls, dataSet, header, style} = this.props
|
|
19
20
|
const {component, ...restDataSet} = dataSet || {}
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
21
|
+
|
|
22
|
+
const actualDataSet = useMemo(() =>
|
|
23
|
+
Object.assign(
|
|
24
|
+
{component: classNames("api-maker/utils/card", component)},
|
|
25
|
+
restDataSet
|
|
26
|
+
)
|
|
27
|
+
, [component, restDataSet])
|
|
28
|
+
|
|
29
|
+
const actualStyle = useMemo(() =>
|
|
30
|
+
Object.assign(
|
|
31
|
+
{
|
|
32
|
+
backgroundColor: "#fff",
|
|
33
|
+
borderRadius: 15,
|
|
34
|
+
padding: 30
|
|
35
|
+
},
|
|
36
|
+
style
|
|
37
|
+
)
|
|
38
|
+
, [style])
|
|
32
39
|
|
|
33
40
|
return (
|
|
34
41
|
<View dataSet={actualDataSet} style={actualStyle}>
|
|
35
42
|
{controls &&
|
|
36
|
-
<View style={{position: "absolute", top: 15, right: 15}}>
|
|
43
|
+
<View style={this.controlsViewStyle ||= {position: "absolute", top: 15, right: 15}}>
|
|
37
44
|
{controls}
|
|
38
45
|
</View>
|
|
39
46
|
}
|
|
40
47
|
{header &&
|
|
41
|
-
<Text style={{fontSize: 24}}>
|
|
48
|
+
<Text style={this.headerTextStyle ||= {fontSize: 24}}>
|
|
42
49
|
{header}
|
|
43
50
|
</Text>
|
|
44
51
|
}
|
package/src/utils/checkbox.jsx
CHANGED
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
import BaseComponent from "../base-component"
|
|
2
2
|
import {CheckBox, Pressable, View} from "react-native"
|
|
3
|
+
import React, {useMemo} from "react"
|
|
3
4
|
import memo from "set-state-compare/src/memo"
|
|
4
5
|
import PropTypes from "prop-types"
|
|
5
6
|
import propTypesExact from "prop-types-exact"
|
|
6
|
-
import React from "react"
|
|
7
7
|
import {shapeComponent} from "set-state-compare/src/shape-component"
|
|
8
8
|
import Text from "./text"
|
|
9
9
|
|
|
10
10
|
export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseComponent {
|
|
11
11
|
static defaultProps = {
|
|
12
|
-
|
|
12
|
+
dataSet: null,
|
|
13
|
+
label: undefined,
|
|
14
|
+
style: null
|
|
13
15
|
}
|
|
14
16
|
|
|
15
17
|
static propTypes = propTypesExact({
|
|
@@ -38,28 +40,19 @@ export default memo(shapeComponent(class ApiMakerUtilsCheckbox extends BaseCompo
|
|
|
38
40
|
|
|
39
41
|
render() {
|
|
40
42
|
const {isChecked} = this.tt
|
|
41
|
-
const {label} = this.p
|
|
42
|
-
const {
|
|
43
|
-
const
|
|
44
|
-
{flexDirection: "row", alignItems: "center"},
|
|
45
|
-
this.props.style
|
|
46
|
-
)
|
|
47
|
-
const actualDataSet = Object.assign(
|
|
48
|
-
{
|
|
49
|
-
checked: isChecked
|
|
50
|
-
},
|
|
51
|
-
dataSet
|
|
52
|
-
)
|
|
43
|
+
const {dataSet, label, style} = this.p
|
|
44
|
+
const actualStyle = useMemo(() => Object.assign({flexDirection: "row", alignItems: "center"}, style), [style])
|
|
45
|
+
const actualDataSet = useMemo(() => Object.assign({checked: isChecked}, dataSet), [dataSet, isChecked])
|
|
53
46
|
|
|
54
47
|
return (
|
|
55
48
|
<View
|
|
56
|
-
dataSet={{component: "api-maker/utils/checkbox"}}
|
|
49
|
+
dataSet={this.viewContainerDataSet ||= {component: "api-maker/utils/checkbox"}}
|
|
57
50
|
style={actualStyle}
|
|
58
51
|
>
|
|
59
52
|
<CheckBox dataSet={actualDataSet} onValueChange={this.tt.onValueChange} value={isChecked} />
|
|
60
53
|
{label &&
|
|
61
54
|
<Pressable onPress={this.tt.onLabelPressed}>
|
|
62
|
-
<Text style={{marginLeft: 3}}>
|
|
55
|
+
<Text style={this.textStyle ||= {marginLeft: 3}}>
|
|
63
56
|
{label}
|
|
64
57
|
</Text>
|
|
65
58
|
</Pressable>
|