react-form-with-constraints-tools
Advanced tools
Comparing version 0.9.3 to 0.10.0-beta.1
@@ -65,3 +65,3 @@ (function (global, factory) { | ||
form.addFieldDidValidateEventListener(this.reRender); | ||
form.addResetEventListener(this.reRender); | ||
form.addFieldDidResetEventListener(this.reRender); | ||
}; | ||
@@ -73,3 +73,3 @@ DisplayFields.prototype.componentWillUnmount = function () { | ||
form.removeFieldDidValidateEventListener(this.reRender); | ||
form.removeResetEventListener(this.reRender); | ||
form.removeFieldDidResetEventListener(this.reRender); | ||
}; | ||
@@ -76,0 +76,0 @@ DisplayFields.prototype.render = function () { |
@@ -1,2 +0,2 @@ | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("react"),require("react-dom"),require("prop-types"),require("react-form-with-constraints")):"function"==typeof define&&define.amd?define(["exports","react","react-dom","prop-types","react-form-with-constraints"],t):t(e.ReactFormWithConstraintsTools={},e.React,e.ReactDOM,e.PropTypes,e.ReactFormWithConstraints)}(this,function(e,o,c,r,d){"use strict";o=o&&o.hasOwnProperty("default")?o.default:o,c=c&&c.hasOwnProperty("default")?c.default:c,r=r&&r.hasOwnProperty("default")?r.default:r;var n=function(e,t){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)t.hasOwnProperty(r)&&(e[r]=t[r])})(e,t)};function i(e,t){function r(){this.constructor=e}n(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}var t=function(t){function e(){var e=null!==t&&t.apply(this,arguments)||this;return e.reRender=function(){e.forceUpdate()},e}return i(e,t),e.prototype.componentWillMount=function(){var e=this.context.form;e.fieldsStore.addListener(d.FieldEvent.Added,this.reRender),e.fieldsStore.addListener(d.FieldEvent.Removed,this.reRender),e.addFieldDidValidateEventListener(this.reRender),e.addResetEventListener(this.reRender)},e.prototype.componentWillUnmount=function(){var e=this.context.form;e.fieldsStore.removeListener(d.FieldEvent.Added,this.reRender),e.fieldsStore.removeListener(d.FieldEvent.Removed,this.reRender),e.removeFieldDidValidateEventListener(this.reRender),e.removeResetEventListener(this.reRender)},e.prototype.render=function(){var e=s(this.context.form.fieldsStore.fields,2);return e=e.replace(/{\s+key: (.*),\s+type: (.*),\s+show: (.*)\s+}/g,"{ key: $1, type: $2, show: $3 }"),o.createElement("pre",{style:{fontSize:"small"}},"Fields = ",e)},e.contextTypes={form:r.instanceOf(d.FormWithConstraints).isRequired},e}(o.Component),s=function(e,t){var r=JSON.stringify(e,function(e,t){return void 0===t?"__undefined__":t},t);return r=(r=r.replace(/"__undefined__"/g,"undefined")).replace(/"([^"]+)":/g,"$1:")},l=function(n){function e(){return null!==n&&n.apply(this,arguments)||this}return i(e,n),e.prototype.render=function(){var e=this.props,t=e.for,r="";return t&&(r+='for="'+t+'" '),r+='stop="'+e.stop+'"',o.createElement(o.Fragment,null,o.createElement("li",null,'key="',this.key,'" ',r),o.createElement("ul",null,n.prototype.render.call(this)))},e}(d.FieldFeedbacks),a=function(n){function e(){return null!==n&&n.apply(this,arguments)||this}return i(e,n),e.prototype.getTextDecoration=function(){var e="";switch(this.state.validation.show){case!1:e="line-through";break;case void 0:e="line-through dotted"}return e},e.prototype.render=function(){var e=this.state.validation,t=e.key,r=e.type;return o.createElement("li",null,o.createElement("span",{style:{textDecoration:this.getTextDecoration()}},'key="',t,'" type="',r,'"')," ",n.prototype.render.call(this))},e.prototype.componentDidUpdate=function(){var t,e,r=c.findDOMNode(this),n=r.querySelectorAll("[data-feedback]");try{for(var o=function(e){var t="function"==typeof Symbol&&e[Symbol.iterator],r=0;return t?t.call(e):{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}}}(n),i=o.next();!i.done;i=o.next()){i.value.style.display="inline"}}catch(e){t={error:e}}finally{try{i&&!i.done&&(e=o.return)&&e.call(o)}finally{if(t)throw t.error}}var s=r.closest("li.async");null!==s&&(s.querySelector("span[style]").style.textDecoration=this.getTextDecoration());if(this.state.validation.type===d.FieldFeedbackType.WhenValid){var l=r.querySelector("span[style]"),a=r.querySelector("span."+this.props.classes.valid);l.style.textDecoration=null!==a?"":"line-through"}},e}(d.FieldFeedback),u=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.getTextDecoration=function(){return"line-through dotted"},t.prototype.componentWillUpdate=function(){c.findDOMNode(this).querySelector("span[style]").style.textDecoration=this.getTextDecoration()},t.prototype.render=function(){return o.createElement("li",{className:"async"},o.createElement("span",{style:{textDecoration:this.getTextDecoration()}},"Async"),o.createElement("ul",null,e.prototype.render.call(this)))},t}(d.Async);e.FormWithConstraints=d.FormWithConstraints,e.DisplayFields=t,e.FieldFeedbacks=l,e.FieldFeedback=a,e.Async=u,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("react"),require("react-dom"),require("prop-types"),require("react-form-with-constraints")):"function"==typeof define&&define.amd?define(["exports","react","react-dom","prop-types","react-form-with-constraints"],t):t(e.ReactFormWithConstraintsTools={},e.React,e.ReactDOM,e.PropTypes,e.ReactFormWithConstraints)}(this,function(e,o,c,r,d){"use strict";o=o&&o.hasOwnProperty("default")?o.default:o,c=c&&c.hasOwnProperty("default")?c.default:c,r=r&&r.hasOwnProperty("default")?r.default:r;var n=function(e,t){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)t.hasOwnProperty(r)&&(e[r]=t[r])})(e,t)};function i(e,t){function r(){this.constructor=e}n(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}var t=function(t){function e(){var e=null!==t&&t.apply(this,arguments)||this;return e.reRender=function(){e.forceUpdate()},e}return i(e,t),e.prototype.componentWillMount=function(){var e=this.context.form;e.fieldsStore.addListener(d.FieldEvent.Added,this.reRender),e.fieldsStore.addListener(d.FieldEvent.Removed,this.reRender),e.addFieldDidValidateEventListener(this.reRender),e.addFieldDidResetEventListener(this.reRender)},e.prototype.componentWillUnmount=function(){var e=this.context.form;e.fieldsStore.removeListener(d.FieldEvent.Added,this.reRender),e.fieldsStore.removeListener(d.FieldEvent.Removed,this.reRender),e.removeFieldDidValidateEventListener(this.reRender),e.removeFieldDidResetEventListener(this.reRender)},e.prototype.render=function(){var e=s(this.context.form.fieldsStore.fields,2);return e=e.replace(/{\s+key: (.*),\s+type: (.*),\s+show: (.*)\s+}/g,"{ key: $1, type: $2, show: $3 }"),o.createElement("pre",{style:{fontSize:"small"}},"Fields = ",e)},e.contextTypes={form:r.instanceOf(d.FormWithConstraints).isRequired},e}(o.Component),s=function(e,t){var r=JSON.stringify(e,function(e,t){return void 0===t?"__undefined__":t},t);return r=(r=r.replace(/"__undefined__"/g,"undefined")).replace(/"([^"]+)":/g,"$1:")},l=function(n){function e(){return null!==n&&n.apply(this,arguments)||this}return i(e,n),e.prototype.render=function(){var e=this.props,t=e.for,r="";return t&&(r+='for="'+t+'" '),r+='stop="'+e.stop+'"',o.createElement(o.Fragment,null,o.createElement("li",null,'key="',this.key,'" ',r),o.createElement("ul",null,n.prototype.render.call(this)))},e}(d.FieldFeedbacks),a=function(n){function e(){return null!==n&&n.apply(this,arguments)||this}return i(e,n),e.prototype.getTextDecoration=function(){var e="";switch(this.state.validation.show){case!1:e="line-through";break;case void 0:e="line-through dotted"}return e},e.prototype.render=function(){var e=this.state.validation,t=e.key,r=e.type;return o.createElement("li",null,o.createElement("span",{style:{textDecoration:this.getTextDecoration()}},'key="',t,'" type="',r,'"')," ",n.prototype.render.call(this))},e.prototype.componentDidUpdate=function(){var t,e,r=c.findDOMNode(this),n=r.querySelectorAll("[data-feedback]");try{for(var o=function(e){var t="function"==typeof Symbol&&e[Symbol.iterator],r=0;return t?t.call(e):{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}}}(n),i=o.next();!i.done;i=o.next()){i.value.style.display="inline"}}catch(e){t={error:e}}finally{try{i&&!i.done&&(e=o.return)&&e.call(o)}finally{if(t)throw t.error}}var s=r.closest("li.async");null!==s&&(s.querySelector("span[style]").style.textDecoration=this.getTextDecoration());if(this.state.validation.type===d.FieldFeedbackType.WhenValid){var l=r.querySelector("span[style]"),a=r.querySelector("span."+this.props.classes.valid);l.style.textDecoration=null!==a?"":"line-through"}},e}(d.FieldFeedback),u=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return i(t,e),t.prototype.getTextDecoration=function(){return"line-through dotted"},t.prototype.componentWillUpdate=function(){c.findDOMNode(this).querySelector("span[style]").style.textDecoration=this.getTextDecoration()},t.prototype.render=function(){return o.createElement("li",{className:"async"},o.createElement("span",{style:{textDecoration:this.getTextDecoration()}},"Async"),o.createElement("ul",null,e.prototype.render.call(this)))},t}(d.Async);e.FormWithConstraints=d.FormWithConstraints,e.DisplayFields=t,e.FieldFeedbacks=l,e.FieldFeedback=a,e.Async=u,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=react-form-with-constraints-tools.production.min.js.map |
@@ -45,3 +45,3 @@ "use strict"; | ||
form.addFieldDidValidateEventListener(this.reRender); | ||
form.addResetEventListener(this.reRender); | ||
form.addFieldDidResetEventListener(this.reRender); | ||
}; | ||
@@ -53,3 +53,3 @@ DisplayFields.prototype.componentWillUnmount = function () { | ||
form.removeFieldDidValidateEventListener(this.reRender); | ||
form.removeResetEventListener(this.reRender); | ||
form.removeFieldDidResetEventListener(this.reRender); | ||
}; | ||
@@ -180,2 +180,2 @@ DisplayFields.prototype.render = function () { | ||
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.addResetEventListener(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.removeResetEventListener(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"]} | ||
//# 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"]} |
{ | ||
"name": "react-form-with-constraints-tools", | ||
"version": "0.9.3", | ||
"version": "0.10.0-beta.1", | ||
"repository": { | ||
@@ -33,3 +33,3 @@ "type": "git", | ||
"peerDependencies": { | ||
"react-form-with-constraints": "^0.9.3" | ||
"react-form-with-constraints": "^0.10.0" | ||
}, | ||
@@ -51,6 +51,6 @@ "devDependencies": { | ||
"react-dom": "latest", | ||
"react-form-with-constraints": "^0.9.3", | ||
"react-form-with-constraints": "^0.10.0-beta.1", | ||
"rollup": "latest", | ||
"rollup-plugin-filesize": "latest", | ||
"rollup-plugin-gzip": "latest", | ||
"rollup-plugin-gzip": "^1.4.0", | ||
"rollup-plugin-strip": "latest", | ||
@@ -63,3 +63,3 @@ "rollup-plugin-typescript2": "latest", | ||
}, | ||
"gitHead": "1e9a57390ea5fb75472d7b0c208870abf2d97a93" | ||
"gitHead": "04800789b7d84c9acb6f1bf2c0da7a6620ec14be" | ||
} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
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
44363