@kaspernj/api-maker 1.0.2123 → 1.0.2125
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/inputs/attachment.js +21 -9
- package/package.json +1 -1
|
@@ -14,15 +14,17 @@ import useInput from "../use-input.js";
|
|
|
14
14
|
export default memo(shapeComponent(class ApiMakerInputsAttachment extends BaseComponent {
|
|
15
15
|
static propTypes = {
|
|
16
16
|
className: PropTypes.string,
|
|
17
|
-
|
|
17
|
+
contentType: PropTypes.string,
|
|
18
|
+
model: PropTypes.object,
|
|
18
19
|
onPurgeChanged: PropTypes.func,
|
|
19
|
-
purgeName: PropTypes.string
|
|
20
|
+
purgeName: PropTypes.string,
|
|
21
|
+
url: PropTypes.string
|
|
20
22
|
};
|
|
21
23
|
setup() {
|
|
22
24
|
const { t } = useI18n({ namespace: "js.api_maker.inputs.attachment" });
|
|
23
25
|
const { inputProps } = useInput({
|
|
24
26
|
props: {
|
|
25
|
-
inputProps: { name: ""
|
|
27
|
+
inputProps: { name: "" },
|
|
26
28
|
inputRef: undefined,
|
|
27
29
|
type: "file",
|
|
28
30
|
...this.props
|
|
@@ -36,19 +38,24 @@ export default memo(shapeComponent(class ApiMakerInputsAttachment extends BaseCo
|
|
|
36
38
|
}
|
|
37
39
|
render() {
|
|
38
40
|
const { inputProps, t } = this.tt;
|
|
39
|
-
const { attribute, checkboxComponent, className, label, model, name, onPurgeChanged, purgeName, wrapperOpts, ...restProps } = this.props;
|
|
41
|
+
const { attribute, checkboxComponent, className, contentType, id, label, model, name, onPurgeChanged, purgeName, url, wrapperOpts, ...restProps } = this.props;
|
|
40
42
|
const CheckboxComponent = checkboxComponent || Checkbox;
|
|
41
43
|
const newInputProps = Object.assign({}, inputProps, { type: "file" }); // eslint-disable-line prefer-object-spread
|
|
42
44
|
return (_jsxs("div", { className: classNames("api-maker--inputs--attachment", "components--inputs--input", className), ...restProps, children: [this.isImage() &&
|
|
43
45
|
_jsx("a", { href: this.getUrl(), target: "_blank", children: _jsx("img", { src: this.getUrl(), style: { maxWidth: "200px", maxHeight: "200px" } }) }), this.getUrl() &&
|
|
44
|
-
_jsxs("div", { className: "input-checkbox", style: { paddingTop: "15px", paddingBottom: "15px" }, children: [_jsx(CheckboxComponent, { id: this.getPurgeInputId(), name: this.getPurgeInputName(), onChange: this.
|
|
45
|
-
_jsx(ApiMakerInput, { defaultValue: null, inputProps: newInputProps, model: model })] }));
|
|
46
|
+
_jsxs("div", { className: "input-checkbox", style: { paddingTop: "15px", paddingBottom: "15px" }, children: [_jsx(CheckboxComponent, { id: this.getPurgeInputId(), name: this.getPurgeInputName(), onChange: this.tt.onPurgeChanged }), _jsx("label", { className: "checkbox-label", htmlFor: this.getPurgeInputId(), children: t("js.shared.delete") })] }), !this.s.purgeChecked &&
|
|
47
|
+
_jsx(ApiMakerInput, { defaultValue: null, inputProps: newInputProps, model: model, type: "file" })] }));
|
|
46
48
|
}
|
|
47
49
|
getContentType() {
|
|
50
|
+
if ("contentType" in this.props)
|
|
51
|
+
return this.props.contentType;
|
|
48
52
|
const { attribute, model } = this.p;
|
|
49
53
|
const attributeName = `${attribute}ContentType`;
|
|
54
|
+
const modelClassName = model ? model.modelClassData().name : "Attachment";
|
|
55
|
+
if (!model)
|
|
56
|
+
return null;
|
|
50
57
|
if (!(attributeName in model))
|
|
51
|
-
throw new Error(`No such method on ${
|
|
58
|
+
throw new Error(`No such method on ${modelClassName}: ${attributeName}`);
|
|
52
59
|
return model[attributeName]();
|
|
53
60
|
}
|
|
54
61
|
getPurgeInputId() {
|
|
@@ -66,10 +73,15 @@ export default memo(shapeComponent(class ApiMakerInputsAttachment extends BaseCo
|
|
|
66
73
|
return purgeInputName;
|
|
67
74
|
}
|
|
68
75
|
getUrl() {
|
|
76
|
+
if ("url" in this.props)
|
|
77
|
+
return this.props.url;
|
|
69
78
|
const { attribute, model } = this.p;
|
|
70
79
|
const attributeName = `${attribute}Url`;
|
|
80
|
+
const modelClassName = model ? model.modelClassData().name : "Attachment";
|
|
81
|
+
if (!model)
|
|
82
|
+
return null;
|
|
71
83
|
if (!(attributeName in model))
|
|
72
|
-
throw new Error(`No such method on ${
|
|
84
|
+
throw new Error(`No such method on ${modelClassName}: ${attributeName}`);
|
|
73
85
|
return model[attributeName]();
|
|
74
86
|
}
|
|
75
87
|
isImage() {
|
|
@@ -81,4 +93,4 @@ export default memo(shapeComponent(class ApiMakerInputsAttachment extends BaseCo
|
|
|
81
93
|
this.props.onPurgeChanged(e);
|
|
82
94
|
};
|
|
83
95
|
}));
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment.js","sourceRoot":"/src/","sources":["inputs/attachment.jsx"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable sort-imports */\nimport ApiMakerInput from \"./input\"\nimport {digg} from \"diggerize\"\nimport {shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport BaseComponent from \"../base-component\"\nimport Checkbox from \"./checkbox\"\nimport PropTypes from \"prop-types\"\nimport React from \"react\"\nimport classNames from \"classnames\" // eslint-disable-line import/no-unresolved\nimport memo from \"set-state-compare/build/memo.js\"\nimport useI18n from \"i18n-on-steroids/src/use-i18n.mjs\"\nimport useInput from \"../use-input.js\"\n\nexport default memo(shapeComponent(class ApiMakerInputsAttachment extends BaseComponent {\n  static propTypes = {\n    className: PropTypes.string,\n    model: PropTypes.object.isRequired,\n    onPurgeChanged: PropTypes.func,\n    purgeName: PropTypes.string\n  }\n\n  setup() {\n    const {t} = useI18n({namespace: \"js.api_maker.inputs.attachment\"})\n    const {inputProps} = useInput({\n      props: {\n        inputProps: {name: \"\", wrapperOpts: {}},\n        inputRef: undefined,\n        type: \"file\",\n        ...this.props\n      },\n      wrapperOptions: {type: \"file\"}\n    })\n\n    this.setInstance({inputProps, t})\n    this.useStates({\n      purgeChecked: false\n    })\n  }\n\n  render() {\n    const {inputProps, t} = this.tt\n    const {attribute, checkboxComponent, className, label, model, name, onPurgeChanged, purgeName, wrapperOpts, ...restProps} = this.props\n    const CheckboxComponent = checkboxComponent || Checkbox\n    const newInputProps = Object.assign({}, inputProps, {type: \"file\"}) // eslint-disable-line prefer-object-spread\n\n    return (\n      <div className={classNames(\"api-maker--inputs--attachment\", \"components--inputs--input\", className)} {...restProps}>\n        {this.isImage() &&\n          <a href={this.getUrl()} target=\"_blank\">\n            <img src={this.getUrl()} style={{maxWidth: \"200px\", maxHeight: \"200px\"}} />\n          </a>\n        }\n        {this.getUrl() &&\n          <div className=\"input-checkbox\" style={{paddingTop: \"15px\", paddingBottom: \"15px\"}}>\n            <CheckboxComponent id={this.getPurgeInputId()} name={this.getPurgeInputName()} onChange={this.props.onPurgeChanged} />\n            <label className=\"checkbox-label\" htmlFor={this.getPurgeInputId()}>\n              {t(\"js.shared.delete\")}\n            </label>\n          </div>\n        }\n        {!this.s.purgeChecked &&\n          <ApiMakerInput\n            defaultValue={null}\n            inputProps={newInputProps}\n            model={model}\n          />\n        }\n      </div>\n    )\n  }\n\n  getContentType() {\n    const {attribute, model} = this.p\n    const attributeName = `${attribute}ContentType`\n\n    if (!(attributeName in model)) throw new Error(`No such method on ${model.modelClassData().name}: ${attributeName}`)\n\n    return model[attributeName]()\n  }\n\n  getPurgeInputId() {\n    const {inputProps} = this.tt\n\n    return `${inputProps.id}_purge`\n  }\n\n  getPurgeInputName() {\n    if (\"purgeName\" in this.props) return this.props.purgeName\n\n    const {inputProps} = this.tt\n\n    if (!inputProps.name) return null\n\n    const match = inputProps.name.match(/^(.+)\\[(.+?)\\]$/)\n    const purgeInputName = `${match[1]}[${match[2]}_purge]`\n\n    return purgeInputName\n  }\n\n  getUrl() {\n    const {attribute, model} = this.p\n    const attributeName = `${attribute}Url`\n\n    if (!(attributeName in model)) throw new Error(`No such method on ${model.modelClassData().name}: ${attributeName}`)\n\n    return model[attributeName]()\n  }\n\n  isImage() {\n    return this.getContentType()?.startsWith(\"image/\")\n  }\n\n  onPurgeChanged = (e) => {\n    this.setState({purgeChecked: digg(e, \"target\", \"checked\")})\n\n    if (this.props.onPurgeChanged) this.props.onPurgeChanged(e)\n  }\n}))\n"]}
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment.js","sourceRoot":"/src/","sources":["inputs/attachment.jsx"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable sort-imports */\nimport ApiMakerInput from \"./input\"\nimport {digg} from \"diggerize\"\nimport {shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport BaseComponent from \"../base-component\"\nimport Checkbox from \"./checkbox\"\nimport PropTypes from \"prop-types\"\nimport React from \"react\"\nimport classNames from \"classnames\" // eslint-disable-line import/no-unresolved\nimport memo from \"set-state-compare/build/memo.js\"\nimport useI18n from \"i18n-on-steroids/src/use-i18n.mjs\"\nimport useInput from \"../use-input.js\"\n\nexport default memo(shapeComponent(class ApiMakerInputsAttachment extends BaseComponent {\n  static propTypes = {\n    className: PropTypes.string,\n    contentType: PropTypes.string,\n    model: PropTypes.object,\n    onPurgeChanged: PropTypes.func,\n    purgeName: PropTypes.string,\n    url: PropTypes.string\n  }\n\n  setup() {\n    const {t} = useI18n({namespace: \"js.api_maker.inputs.attachment\"})\n    const {inputProps} = useInput({\n      props: {\n        inputProps: {name: \"\"},\n        inputRef: undefined,\n        type: \"file\",\n        ...this.props\n      },\n      wrapperOptions: {type: \"file\"}\n    })\n\n    this.setInstance({inputProps, t})\n    this.useStates({\n      purgeChecked: false\n    })\n  }\n\n  render() {\n    const {inputProps, t} = this.tt\n    const {attribute, checkboxComponent, className, contentType, id, label, model, name, onPurgeChanged, purgeName, url, wrapperOpts, ...restProps} = this.props\n    const CheckboxComponent = checkboxComponent || Checkbox\n    const newInputProps = Object.assign({}, inputProps, {type: \"file\"}) // eslint-disable-line prefer-object-spread\n\n    return (\n      <div className={classNames(\"api-maker--inputs--attachment\", \"components--inputs--input\", className)} {...restProps}>\n        {this.isImage() &&\n          <a href={this.getUrl()} target=\"_blank\">\n            <img src={this.getUrl()} style={{maxWidth: \"200px\", maxHeight: \"200px\"}} />\n          </a>\n        }\n        {this.getUrl() &&\n          <div className=\"input-checkbox\" style={{paddingTop: \"15px\", paddingBottom: \"15px\"}}>\n            <CheckboxComponent id={this.getPurgeInputId()} name={this.getPurgeInputName()} onChange={this.tt.onPurgeChanged} />\n            <label className=\"checkbox-label\" htmlFor={this.getPurgeInputId()}>\n              {t(\"js.shared.delete\")}\n            </label>\n          </div>\n        }\n        {!this.s.purgeChecked &&\n          <ApiMakerInput\n            defaultValue={null}\n            inputProps={newInputProps}\n            model={model}\n            type=\"file\"\n          />\n        }\n      </div>\n    )\n  }\n\n  getContentType() {\n    if (\"contentType\" in this.props) return this.props.contentType\n\n    const {attribute, model} = this.p\n    const attributeName = `${attribute}ContentType`\n    const modelClassName = model ? model.modelClassData().name : \"Attachment\"\n\n    if (!model) return null\n\n    if (!(attributeName in model)) throw new Error(`No such method on ${modelClassName}: ${attributeName}`)\n\n    return model[attributeName]()\n  }\n\n  getPurgeInputId() {\n    const {inputProps} = this.tt\n\n    return `${inputProps.id}_purge`\n  }\n\n  getPurgeInputName() {\n    if (\"purgeName\" in this.props) return this.props.purgeName\n\n    const {inputProps} = this.tt\n\n    if (!inputProps.name) return null\n\n    const match = inputProps.name.match(/^(.+)\\[(.+?)\\]$/)\n    const purgeInputName = `${match[1]}[${match[2]}_purge]`\n\n    return purgeInputName\n  }\n\n  getUrl() {\n    if (\"url\" in this.props) return this.props.url\n\n    const {attribute, model} = this.p\n    const attributeName = `${attribute}Url`\n    const modelClassName = model ? model.modelClassData().name : \"Attachment\"\n\n    if (!model) return null\n\n    if (!(attributeName in model)) throw new Error(`No such method on ${modelClassName}: ${attributeName}`)\n\n    return model[attributeName]()\n  }\n\n  isImage() {\n    return this.getContentType()?.startsWith(\"image/\")\n  }\n\n  onPurgeChanged = (e) => {\n    this.setState({purgeChecked: digg(e, \"target\", \"checked\")})\n\n    if (this.props.onPurgeChanged) this.props.onPurgeChanged(e)\n  }\n}))\n"]}
|