UNPKG

sn-controls-react

Version:

React controls for sensenet ECM

447 lines (446 loc) 15.1 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/viewcontrols/EditView.tsx</title> <meta charset="utf-8" /> <link rel="stylesheet" href="..\..\prettify.css" /> <link rel="stylesheet" href="..\..\base.css" /> <meta name="viewport" content="width=device-width, initial-scale=1"> <style type='text/css'> .coverage-summary .sorter { background-image: url(..\..\sort-arrow-sprite.png); } </style> </head> <body> <div class='wrapper'> <div class='pad1'> <h1> <a href="..\..\index.html">All files</a> / <a href="index.html">src/viewcontrols</a> EditView.tsx </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">36.67% </span> <span class="quiet">Statements</span> <span class='fraction'>11/30</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/10</span> </div> <div class='fl pad1y space-right2'> <span class="strong">14.29% </span> <span class="quiet">Functions</span> <span class='fraction'>1/7</span> </div> <div class='fl pad1y space-right2'> <span class="strong">33.33% </span> <span class="quiet">Lines</span> <span class='fraction'>9/27</span> </div> </div> </div> <div class='status-line low'></div> <pre><table class="coverage"> <tr><td class="line-count quiet">1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128</td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">/** * @module ViewControls * */ /** */ import * as React from 'react' import { Content, ContentTypes } from 'sn-client-js' &nbsp; import { Row, Button, Col } from 'react-materialize' import { styles } from './EditViewStyles' &nbsp; /** * Interface for EditView properties */ interface IEditViewProps { content, schema, history, repository, onSubmit: Function } &nbsp; /** * View Control for editing a Content, works with a single Content and based on the ReactControlMapper * * Usage: * ```html * &lt;EditView content={selectedContent} schema={schema} history={history} onSubmit={editSubmitClick} repository={repository} /&gt; * ``` */ export class EditView extends React.Component&lt;IEditViewProps, { content, schema, saveableContent }&gt; { /** * constructor * @param {object} props */ <span class="fstat-no" title="function not covered" > constructor(</span>props: any) { <span class="cstat-no" title="statement not covered" > super(props);</span> /** * @type {object} * @property {any} content selected Content * @property {any} schema schema object of the selected Content's Content Type * @property {any} saveableContent Content to store only the used fields. Will be used at saving. */ <span class="cstat-no" title="statement not covered" > this.state = {</span> content: this.props.content, schema: this.props.schema, saveableContent: Content.Create(ContentTypes.Task, { Id: this.props.content.Id }, this.props.repository) }; &nbsp; <span class="cstat-no" title="statement not covered" > this.handleInputChange = this.handleInputChange.bind(this);</span> } &nbsp; /** * handle change event on an input * @param {SytheticEvent} event */ <span class="fstat-no" title="function not covered" > handleInputChange(</span>event) { const target = <span class="cstat-no" title="statement not covered" >event.target;</span> const value = <span class="cstat-no" title="statement not covered" >target.type === 'checkbox' ? target.checked : target.value;</span> const name = <span class="cstat-no" title="statement not covered" >target.name;</span> <span class="cstat-no" title="statement not covered" > this.state.saveableContent[name] = value;</span> &nbsp; <span class="cstat-no" title="statement not covered" > this.setState({</span> content: this.props.content }); } /** * eturns a value of an input * @param {string} name name of the input * @return {any} value of the input or null */ <span class="fstat-no" title="function not covered" > getFieldValue(</span>name) { <span class="cstat-no" title="statement not covered" > if (this.props.content[name]) {</span> <span class="cstat-no" title="statement not covered" > return this.props.content[name]</span> } else { <span class="cstat-no" title="statement not covered" > return null</span> } } /** * render * @return {ReactElement} markup */ <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > render() {</span></span> const fieldSettings = <span class="cstat-no" title="statement not covered" >this.props.schema.FieldMappings;</span> const that = <span class="cstat-no" title="statement not covered" >this;</span> <span class="cstat-no" title="statement not covered" > return (</span> &lt;Row&gt; &lt;form style={styles.container} onSubmit={ <span class="fstat-no" title="function not covered" > (</span>e) =&gt; { <span class="cstat-no" title="statement not covered" > e.preventDefault();</span> <span class="cstat-no" title="statement not covered" > this.props.onSubmit(this.props.content.Id, this.props.content.Type, this.state.saveableContent.GetFields())</span> <span class="cstat-no" title="statement not covered" > this.props.history.goBack()</span> } }&gt; &lt;h4&gt;Edit {this.props.content.DisplayName}&lt;/h4&gt; { fieldSettings.map(<span class="fstat-no" title="function not covered" >function (</span>e, i) { <span class="cstat-no" title="statement not covered" > return (&lt;Col</span> s={12} m={fieldSettings[i].ControlType.name === 'RichTextEditor' ? 12 : 6} l={fieldSettings[i].ControlType.name === 'RichTextEditor' ? 12 : 6} key={fieldSettings[i].ClientSettings.name}&gt; { React.createElement( fieldSettings[i].ControlType, { ...fieldSettings[i].ClientSettings, 'data-actionName': 'edit', 'data-fieldValue': that.getFieldValue(fieldSettings[i].ClientSettings.name), onChange: that.handleInputChange }) } &lt;/Col&gt;) &nbsp; }) } &lt;Col s={12} m={12} l={12} style={styles.buttonContainer}&gt; &lt;Button waves='light'&gt;Submit&lt;/Button&gt; &lt;Button waves='light'&gt;Cancel&lt;/Button&gt; &lt;/Col &gt; &lt;/form&gt; &lt;/Row &gt; ) } } &nbsp;</pre></td></tr> </table></pre> <div class='push'></div><!-- for sticky footer --> </div><!-- /wrapper --> <div class='footer quiet pad2 space-top1 center small'> Code coverage generated by <a href="https://istanbul.js.org/" target="_blank">istanbul</a> at Thu Jul 20 2017 09:43:59 GMT+0200 (Central Europe Daylight Time) </div> </div> <script src="..\..\prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="..\..\sorter.js"></script> </body> </html>