-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
cb4911f
commit 4783afa
Showing
2 changed files
with
40 additions
and
69 deletions.
There are no files selected for viewing
107 changes: 39 additions & 68 deletions
107
Southwind.React/App/Southwind/Templates/SalesEstimation.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,87 +1,58 @@ | ||
import * as React from 'react' | ||
import * as React from 'react' | ||
import { ProductEntity, ProductPredictorPublication } from '../Southwind.Entities' | ||
import { ValueLine, EntityLine, EntityCombo, EntityList, EntityDetail, EntityStrip, EntityRepeater, TypeContext, FormControlReadonly, FormGroup } from '@framework/Lines' | ||
import * as Finder from '@framework/Finder'; | ||
import { is } from '@framework/Signum.Entities'; | ||
import { ajaxPost } from '@framework/Services'; | ||
import { is, liteKey } from '@framework/Signum.Entities'; | ||
import { ajaxPost, useAPI } from '@framework/Services'; | ||
import { Gradient, Color } from '@extensions/Basics/Color'; | ||
import { toLite } from '@framework/Signum.Entities'; | ||
import { classes } from '@framework/Globals'; | ||
import { EntityControlMessage } from '@framework/Signum.Entities'; | ||
import { PredictorEntity } from '@extensions/MachineLearning/Signum.Entities.MachineLearning'; | ||
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||
|
||
interface SalesEstimationProps { | ||
ctx: TypeContext<ProductEntity> | ||
} | ||
|
||
interface SalesEstimationState { | ||
estimation?: number; | ||
} | ||
var gradient = new Gradient([ | ||
{ value: 0, color: Color.parse("red") }, | ||
{ value: 1, color: Color.parse("gold") }, | ||
{ value: 2, color: Color.parse("green") }, | ||
{ value: 3, color: Color.parse("blue") }, | ||
]); | ||
|
||
export default class SalesEstimation extends React.Component<SalesEstimationProps, SalesEstimationState> { | ||
export default function SalesEstimation({ ctx }: { ctx: TypeContext<ProductEntity> }) { | ||
|
||
constructor(props: SalesEstimationProps) { | ||
super(props); | ||
this.state = {}; | ||
} | ||
|
||
componentWillMount() { | ||
this.loadData(this.props); | ||
} | ||
|
||
componentWillReceiveProps(newProps: SalesEstimationProps) { | ||
if (!is(newProps.ctx.value, this.props.ctx.value)) | ||
this.loadData(newProps); | ||
} | ||
|
||
loadData(props: SalesEstimationProps) { | ||
ajaxPost<number>({ url: "~/api/salesEstimation" }, toLite(props.ctx.value)) | ||
.then(estimation => this.setState({ estimation })) | ||
.done(); | ||
function handleViewClick(e: React.MouseEvent<any>) { | ||
e.preventDefault(); | ||
Finder.exploreWindowsOpen({ queryName: PredictorEntity, parentToken: "Entity.Publication", parentValue: ProductPredictorPublication.MonthlySales }, e); | ||
} | ||
|
||
gradient = new Gradient([ | ||
{ value: 0, color: Color.parse("red") }, | ||
{ value: 1, color: Color.parse("gold") }, | ||
{ value: 2, color: Color.parse("green") }, | ||
{ value: 3, color: Color.parse("blue") }, | ||
]); | ||
|
||
render() { | ||
const ctx = this.props.ctx; | ||
const estimation = useAPI(undefined, [ctx.value.id], signal => ajaxPost<number>({ url: "~/api/salesEstimation", signal }, toLite(ctx.value))); | ||
|
||
const color = this.state.estimation != null ? this.gradient.getCachedColor(this.props.ctx.value.unitsInStock! / (Math.max(1, this.state.estimation))) : undefined; | ||
const color = estimation != null ? gradient.getCachedColor(ctx.value.unitsInStock! / (Math.max(1, estimation))) : undefined; | ||
|
||
return ( | ||
<FormGroup ctx={ctx} labelText="Sales next month" helpText="Monthly estimation using Predicitor extension"> | ||
{ | ||
this.state.estimation != null && | ||
<div className={ctx.inputGroupClass}> | ||
<div className="input-group-prepend"> | ||
<span className="input-group-text"> | ||
<FontAwesomeIcon icon={["far", "lightbulb"]} /> | ||
</span> | ||
</div> | ||
<p className={classes(ctx.formControlClass, "readonly numeric")} style={{ color: color && color.toString() }}> | ||
{this.state.estimation} | ||
</p> | ||
<div className="input-group-append"> | ||
<a href="#" className={classes("sf-line-button", "sf-view", "btn input-group-text")} | ||
onClick={this.handleViewClick} | ||
title={EntityControlMessage.View.niceToString()}> | ||
<FontAwesomeIcon icon={"arrow-right"} /> | ||
</a> | ||
</div> | ||
return ( | ||
<FormGroup ctx={ctx} labelText="Sales next month" helpText="Monthly estimation using Predicitor extension"> | ||
{ | ||
estimation != null && | ||
<div className={ctx.inputGroupClass}> | ||
<div className="input-group-prepend"> | ||
<span className="input-group-text"> | ||
<FontAwesomeIcon icon={["far", "lightbulb"]} /> | ||
</span> | ||
</div> | ||
} | ||
</FormGroup> | ||
); | ||
} | ||
|
||
handleViewClick = (e: React.MouseEvent<any>) => { | ||
e.preventDefault(); | ||
Finder.exploreWindowsOpen({ queryName: PredictorEntity, parentToken: "Entity.Publication", parentValue: ProductPredictorPublication.MonthlySales }, e); | ||
} | ||
}//SalesEstimation | ||
<p className={classes(ctx.formControlClass, "readonly numeric")} style={{ color: color && color.toString() }}> | ||
{estimation} | ||
</p> | ||
<div className="input-group-append"> | ||
<a href="#" className={classes("sf-line-button", "sf-view", "btn input-group-text")} | ||
onClick={handleViewClick} | ||
title={EntityControlMessage.View.niceToString()}> | ||
<FontAwesomeIcon icon={"arrow-right"} /> | ||
</a> | ||
</div> | ||
</div> | ||
} | ||
</FormGroup> | ||
); | ||
} | ||
|