react-form-with-constraints-tools
Advanced tools
Comparing version 0.10.0-beta.2 to 0.10.0-beta.3
@@ -1,69 +0,39 @@ | ||
"use strict"; | ||
var __extends = (this && this.__extends) || (function () { | ||
var extendStatics = Object.setPrototypeOf || | ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || | ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; | ||
return function (d, b) { | ||
extendStatics(d, b); | ||
function __() { this.constructor = d; } | ||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); | ||
}; | ||
})(); | ||
var __values = (this && this.__values) || function (o) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; | ||
if (m) return m.call(o); | ||
return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
}; | ||
var __importDefault = (this && this.__importDefault) || function (mod) { | ||
return (mod && mod.__esModule) ? mod : { "default": mod }; | ||
}; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var react_1 = __importDefault(require("react")); | ||
var react_dom_1 = __importDefault(require("react-dom")); | ||
var prop_types_1 = __importDefault(require("prop-types")); | ||
var react_form_with_constraints_1 = require("react-form-with-constraints"); | ||
exports.FormWithConstraints = react_form_with_constraints_1.FormWithConstraints; | ||
var DisplayFields = (function (_super) { | ||
__extends(DisplayFields, _super); | ||
function DisplayFields() { | ||
var _this = _super !== null && _super.apply(this, arguments) || this; | ||
_this.reRender = function () { | ||
_this.forceUpdate(); | ||
import React from 'react'; | ||
import ReactDOM from 'react-dom'; | ||
import PropTypes from 'prop-types'; | ||
import { FormWithConstraints, FieldFeedback as _FieldFeedback, FieldFeedbackType, FieldFeedbacks as _FieldFeedbacks, Async as _Async, FieldEvent } from 'react-form-with-constraints'; | ||
export class DisplayFields extends React.Component { | ||
constructor() { | ||
super(...arguments); | ||
this.reRender = () => { | ||
this.forceUpdate(); | ||
}; | ||
return _this; | ||
} | ||
DisplayFields.prototype.componentWillMount = function () { | ||
var form = this.context.form; | ||
form.fieldsStore.addListener(react_form_with_constraints_1.FieldEvent.Added, this.reRender); | ||
form.fieldsStore.addListener(react_form_with_constraints_1.FieldEvent.Removed, this.reRender); | ||
componentWillMount() { | ||
const { form } = this.context; | ||
form.fieldsStore.addListener(FieldEvent.Added, this.reRender); | ||
form.fieldsStore.addListener(FieldEvent.Removed, this.reRender); | ||
form.addFieldDidValidateEventListener(this.reRender); | ||
form.addFieldDidResetEventListener(this.reRender); | ||
}; | ||
DisplayFields.prototype.componentWillUnmount = function () { | ||
var form = this.context.form; | ||
form.fieldsStore.removeListener(react_form_with_constraints_1.FieldEvent.Added, this.reRender); | ||
form.fieldsStore.removeListener(react_form_with_constraints_1.FieldEvent.Removed, this.reRender); | ||
} | ||
componentWillUnmount() { | ||
const { form } = this.context; | ||
form.fieldsStore.removeListener(FieldEvent.Added, this.reRender); | ||
form.fieldsStore.removeListener(FieldEvent.Removed, this.reRender); | ||
form.removeFieldDidValidateEventListener(this.reRender); | ||
form.removeFieldDidResetEventListener(this.reRender); | ||
}; | ||
DisplayFields.prototype.render = function () { | ||
var str = stringifyWithUndefinedAndWithoutPropertyQuotes(this.context.form.fieldsStore.fields, 2); | ||
} | ||
render() { | ||
let str = stringifyWithUndefinedAndWithoutPropertyQuotes(this.context.form.fieldsStore.fields, 2); | ||
str = str.replace(/{\s+key: (.*),\s+type: (.*),\s+show: (.*)\s+}/g, '{ key: $1, type: $2, show: $3 }'); | ||
return react_1.default.createElement("pre", { style: { fontSize: 'small' } }, | ||
return React.createElement("pre", { style: { fontSize: 'small' } }, | ||
"Fields = ", | ||
str); | ||
}; | ||
DisplayFields.contextTypes = { | ||
form: prop_types_1.default.instanceOf(react_form_with_constraints_1.FormWithConstraints).isRequired | ||
}; | ||
return DisplayFields; | ||
}(react_1.default.Component)); | ||
exports.DisplayFields = DisplayFields; | ||
var stringifyWithUndefinedAndWithoutPropertyQuotes = function (obj, space) { | ||
var str = JSON.stringify(obj, function (_key, value) { return value === undefined ? '__undefined__' : value; }, space); | ||
} | ||
} | ||
DisplayFields.contextTypes = { | ||
form: PropTypes.instanceOf(FormWithConstraints).isRequired | ||
}; | ||
const stringifyWithUndefinedAndWithoutPropertyQuotes = (obj, space) => { | ||
let str = JSON.stringify(obj, (_key, value) => value === undefined ? '__undefined__' : value, space); | ||
str = str.replace(/"__undefined__"/g, 'undefined'); | ||
@@ -73,15 +43,12 @@ str = str.replace(/"([^"]+)":/g, '$1:'); | ||
}; | ||
var FieldFeedbacks = (function (_super) { | ||
__extends(FieldFeedbacks, _super); | ||
function FieldFeedbacks() { | ||
return _super !== null && _super.apply(this, arguments) || this; | ||
} | ||
FieldFeedbacks.prototype.render = function () { | ||
var _a = this.props, fieldName = _a.for, stop = _a.stop; | ||
var attr = ''; | ||
export { FormWithConstraints }; | ||
export class FieldFeedbacks extends _FieldFeedbacks { | ||
render() { | ||
const { for: fieldName, stop } = this.props; | ||
let attr = ''; | ||
if (fieldName) | ||
attr += "for=\"" + fieldName + "\" "; | ||
attr += "stop=\"" + stop + "\""; | ||
return (react_1.default.createElement(react_1.default.Fragment, null, | ||
react_1.default.createElement("li", null, | ||
attr += `for="${fieldName}" `; | ||
attr += `stop="${stop}"`; | ||
return (React.createElement(React.Fragment, null, | ||
React.createElement("li", null, | ||
"key=\"", | ||
@@ -91,15 +58,9 @@ this.key, | ||
attr), | ||
react_1.default.createElement("ul", null, _super.prototype.render.call(this)))); | ||
}; | ||
return FieldFeedbacks; | ||
}(react_form_with_constraints_1.FieldFeedbacks)); | ||
exports.FieldFeedbacks = FieldFeedbacks; | ||
var FieldFeedback = (function (_super) { | ||
__extends(FieldFeedback, _super); | ||
function FieldFeedback() { | ||
return _super !== null && _super.apply(this, arguments) || this; | ||
React.createElement("ul", null, super.render()))); | ||
} | ||
FieldFeedback.prototype.getTextDecoration = function () { | ||
var show = this.state.validation.show; | ||
var textDecoration = ''; | ||
} | ||
export class FieldFeedback extends _FieldFeedback { | ||
getTextDecoration() { | ||
const { show } = this.state.validation; | ||
let textDecoration = ''; | ||
switch (show) { | ||
@@ -114,7 +75,7 @@ case false: | ||
return textDecoration; | ||
}; | ||
FieldFeedback.prototype.render = function () { | ||
var _a = this.state.validation, key = _a.key, type = _a.type; | ||
return (react_1.default.createElement("li", null, | ||
react_1.default.createElement("span", { style: { textDecoration: this.getTextDecoration() } }, | ||
} | ||
render() { | ||
const { key, type } = this.state.validation; | ||
return (React.createElement("li", null, | ||
React.createElement("span", { style: { textDecoration: this.getTextDecoration() } }, | ||
"key=\"", | ||
@@ -126,57 +87,37 @@ key, | ||
' ', | ||
_super.prototype.render.call(this))); | ||
}; | ||
FieldFeedback.prototype.componentDidUpdate = function () { | ||
var e_1, _a; | ||
var el = react_dom_1.default.findDOMNode(this); | ||
var fieldFeedbackSpans = el.querySelectorAll('[data-feedback]'); | ||
try { | ||
for (var fieldFeedbackSpans_1 = __values(fieldFeedbackSpans), fieldFeedbackSpans_1_1 = fieldFeedbackSpans_1.next(); !fieldFeedbackSpans_1_1.done; fieldFeedbackSpans_1_1 = fieldFeedbackSpans_1.next()) { | ||
var fieldFeedbackSpan = fieldFeedbackSpans_1_1.value; | ||
fieldFeedbackSpan.style.display = 'inline'; | ||
} | ||
super.render())); | ||
} | ||
componentDidUpdate() { | ||
const el = ReactDOM.findDOMNode(this); | ||
const fieldFeedbackSpans = el.querySelectorAll('[data-feedback]'); | ||
for (const fieldFeedbackSpan of fieldFeedbackSpans) { | ||
fieldFeedbackSpan.style.display = 'inline'; | ||
} | ||
catch (e_1_1) { e_1 = { error: e_1_1 }; } | ||
finally { | ||
try { | ||
if (fieldFeedbackSpans_1_1 && !fieldFeedbackSpans_1_1.done && (_a = fieldFeedbackSpans_1.return)) _a.call(fieldFeedbackSpans_1); | ||
} | ||
finally { if (e_1) throw e_1.error; } | ||
} | ||
var li = el.closest('li.async'); | ||
const li = el.closest('li.async'); | ||
if (li !== null) { | ||
var async = li.querySelector('span[style]'); | ||
const async = li.querySelector('span[style]'); | ||
async.style.textDecoration = this.getTextDecoration(); | ||
} | ||
var type = this.state.validation.type; | ||
if (type === react_form_with_constraints_1.FieldFeedbackType.WhenValid) { | ||
var span = el.querySelector('span[style]'); | ||
var whenValid = el.querySelector("span." + this.props.classes.valid); | ||
const { type } = this.state.validation; | ||
if (type === FieldFeedbackType.WhenValid) { | ||
const span = el.querySelector('span[style]'); | ||
const whenValid = el.querySelector(`span.${this.props.classes.valid}`); | ||
span.style.textDecoration = whenValid !== null ? '' : 'line-through'; | ||
} | ||
}; | ||
return FieldFeedback; | ||
}(react_form_with_constraints_1.FieldFeedback)); | ||
exports.FieldFeedback = FieldFeedback; | ||
var Async = (function (_super) { | ||
__extends(Async, _super); | ||
function Async() { | ||
return _super !== null && _super.apply(this, arguments) || this; | ||
} | ||
Async.prototype.getTextDecoration = function () { | ||
} | ||
export class Async extends _Async { | ||
getTextDecoration() { | ||
return 'line-through dotted'; | ||
}; | ||
Async.prototype.componentWillUpdate = function () { | ||
var el = react_dom_1.default.findDOMNode(this); | ||
var async = el.querySelector('span[style]'); | ||
} | ||
componentWillUpdate() { | ||
const el = ReactDOM.findDOMNode(this); | ||
const async = el.querySelector('span[style]'); | ||
async.style.textDecoration = this.getTextDecoration(); | ||
}; | ||
Async.prototype.render = function () { | ||
return (react_1.default.createElement("li", { className: "async" }, | ||
react_1.default.createElement("span", { style: { textDecoration: this.getTextDecoration() } }, "Async"), | ||
react_1.default.createElement("ul", null, _super.prototype.render.call(this)))); | ||
}; | ||
return Async; | ||
}(react_form_with_constraints_1.Async)); | ||
exports.Async = Async; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DisplayFields.js","sourceRoot":"","sources":["../src/DisplayFields.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\n\nimport {\n  FormWithConstraints,\n  FormWithConstraintsChildContext,\n  FieldFeedback as _FieldFeedback, FieldFeedbackType,\n  FieldFeedbacks as _FieldFeedbacks,\n  Async as _Async,\n  FieldEvent\n} from 'react-form-with-constraints';\n\nexport interface DisplayFieldsProps {}\n\nexport class DisplayFields extends React.Component<DisplayFieldsProps> {\n  static contextTypes: React.ValidationMap<FormWithConstraintsChildContext> = {\n    form: PropTypes.instanceOf(FormWithConstraints).isRequired\n  };\n  context!: FormWithConstraintsChildContext;\n\n  componentWillMount() {\n    const { form } = this.context;\n    form.fieldsStore.addListener(FieldEvent.Added, this.reRender);\n    form.fieldsStore.addListener(FieldEvent.Removed, this.reRender);\n    form.addFieldDidValidateEventListener(this.reRender);\n    form.addFieldDidResetEventListener(this.reRender);\n  }\n\n  componentWillUnmount() {\n    const { form } = this.context;\n    form.fieldsStore.removeListener(FieldEvent.Added, this.reRender);\n    form.fieldsStore.removeListener(FieldEvent.Removed, this.reRender);\n    form.removeFieldDidValidateEventListener(this.reRender);\n    form.removeFieldDidResetEventListener(this.reRender);\n  }\n\n  reRender = () => {\n    this.forceUpdate();\n  }\n\n  render() {\n    let str = stringifyWithUndefinedAndWithoutPropertyQuotes(this.context.form.fieldsStore.fields, 2);\n\n    // Cosmetic: improve formatting\n    //\n    // Replace this string:\n    // {\n    //   key: \"1.0\",\n    //   type: \"error\",\n    //   show: true\n    // }\n    // with this:\n    // { key: \"1.0\", type: \"error\", show: true }\n    str = str.replace(/{\\s+key: (.*),\\s+type: (.*),\\s+show: (.*)\\s+}/g, '{ key: $1, type: $2, show: $3 }');\n\n    return <pre style={{fontSize: 'small'}}>Fields = {str}</pre>;\n  }\n}\n\n// See Preserving undefined that JSON.stringify otherwise removes https://stackoverflow.com/q/26540706\n// See JSON.stringify without quotes on properties? https://stackoverflow.com/q/11233498\nconst stringifyWithUndefinedAndWithoutPropertyQuotes = (obj: object, space?: string | number) => {\n  let str = JSON.stringify(obj, (_key, value) => value === undefined ? '__undefined__' : value, space);\n  str = str.replace(/\"__undefined__\"/g, 'undefined');\n  str = str.replace(/\"([^\"]+)\":/g, '$1:');\n  return str;\n};\n\nexport { FormWithConstraints };\n\nexport class FieldFeedbacks extends _FieldFeedbacks {\n  render() {\n    const { for: fieldName, stop } = this.props;\n\n    let attr = '';\n    if (fieldName) attr += `for=\"${fieldName}\" `;\n    attr += `stop=\"${stop}\"`;\n\n    return (\n      <>\n        <li>key=\"{this.key}\" {attr}</li>\n        <ul>\n          {super.render()}\n        </ul>\n      </>\n    );\n  }\n}\n\nexport class FieldFeedback extends _FieldFeedback {\n  private getTextDecoration() {\n    const { show } = this.state.validation;\n\n    let textDecoration = '';\n    switch (show) {\n      case false:\n        textDecoration = 'line-through';\n        break;\n      case undefined:\n        textDecoration = 'line-through dotted';\n        break;\n    }\n\n    return textDecoration;\n  }\n\n  render() {\n    const { key, type } = this.state.validation;\n\n    return (\n      <li>\n        <span style={{textDecoration: this.getTextDecoration()}}>key=\"{key}\" type=\"{type}\"</span>{' '}\n        {super.render()}\n      </li>\n    );\n  }\n\n  componentDidUpdate() {\n    const el = ReactDOM.findDOMNode(this) as HTMLLIElement;\n\n    // Hack: make FieldFeedback <span style=\"display: inline\">\n    // Also make Bootstrap 4 happy because it sets 'display: none', see https://github.com/twbs/bootstrap/blob/v4.1.2/scss/mixins/_forms.scss#L31\n    const fieldFeedbackSpans = el.querySelectorAll<HTMLSpanElement>('[data-feedback]');\n    for (const fieldFeedbackSpan of fieldFeedbackSpans) {\n      fieldFeedbackSpan.style.display = 'inline';\n    }\n\n    // Change Async parent style\n    const li = el.closest('li.async');\n    if (li !== null) {\n      const async = li.querySelector<HTMLSpanElement>('span[style]');\n      async!.style.textDecoration = this.getTextDecoration();\n    }\n\n    // Change whenValid style\n    const { type } = this.state.validation;\n    if (type === FieldFeedbackType.WhenValid) {\n      const span = el.querySelector<HTMLSpanElement>('span[style]');\n      const whenValid = el.querySelector<HTMLSpanElement>(`span.${this.props.classes!.valid}`);\n      span!.style.textDecoration = whenValid !== null ? '' : 'line-through';\n    }\n  }\n}\n\nexport class Async<T> extends _Async<T> {\n  private getTextDecoration() {\n    return 'line-through dotted';\n  }\n\n  componentWillUpdate() {\n    const el = ReactDOM.findDOMNode(this) as HTMLLIElement;\n\n    // Reset style\n    const async = el.querySelector<HTMLSpanElement>('span[style]');\n    async!.style.textDecoration = this.getTextDecoration();\n  }\n\n  render() {\n    return (\n      <li className=\"async\">\n        <span style={{textDecoration: this.getTextDecoration()}}>Async</span>\n        <ul>\n          {super.render()}\n        </ul>\n      </li>\n    );\n  }\n}\n"]} | ||
} | ||
render() { | ||
return (React.createElement("li", { className: "async" }, | ||
React.createElement("span", { style: { textDecoration: this.getTextDecoration() } }, "Async"), | ||
React.createElement("ul", null, super.render()))); | ||
} | ||
} |
@@ -1,7 +0,1 @@ | ||
"use strict"; | ||
function __export(m) { | ||
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; | ||
} | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
__export(require("./DisplayFields")); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxxQ0FBZ0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL0Rpc3BsYXlGaWVsZHMnO1xuIl19 | ||
export * from './DisplayFields'; |
{ | ||
"name": "react-form-with-constraints-tools", | ||
"version": "0.10.0-beta.2", | ||
"version": "0.10.0-beta.3", | ||
"repository": { | ||
@@ -17,14 +17,17 @@ "type": "git", | ||
], | ||
"main": "lib/index.js", | ||
"module": "lib/index.js", | ||
"types": "lib/index.d.ts", | ||
"files": [ | ||
"dist/", | ||
"lib/" | ||
"lib/", | ||
"lib-es5/" | ||
], | ||
"sideEffects": false, | ||
"scripts": { | ||
"clean": "del-cli lib dist coverage .rpt2_cache", | ||
"clean": "del-cli lib lib-es5 dist coverage .rpt2_cache", | ||
"tsc": "tsc", | ||
"build": "tsc --project tsconfig.lib.json", | ||
"build:es5": "tsc --project tsconfig.lib-es5.json", | ||
"dist": "cross-env NODE_ENV=development rollup --config && cross-env NODE_ENV=production rollup --config", | ||
"prepublishOnly": "npm run clean && npm run tsc && npm run build && npm run dist", | ||
"prepublishOnly": "npm run clean && npm run tsc && npm run build:es5 && npm run build && npm run dist", | ||
"test": "node --trace-warnings node_modules/.bin/jest --no-cache --verbose", | ||
@@ -51,3 +54,3 @@ "test:coverage": "node --trace-warnings node_modules/.bin/jest --no-cache --coverage" | ||
"react-dom": "latest", | ||
"react-form-with-constraints": "^0.10.0-beta.2", | ||
"react-form-with-constraints": "^0.10.0-beta.3", | ||
"rollup": "latest", | ||
@@ -63,3 +66,3 @@ "rollup-plugin-filesize": "latest", | ||
}, | ||
"gitHead": "3b9e2ec58e3a9a4c2e4be47ea1a0209ba1f36eba" | ||
"gitHead": "317dbf7a33647afbeac3609a7bbaeb67c25e31d1" | ||
} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
49189
15
542