angular-instantsearch
Version:
Lightning-fast search for Angular apps, by Algolia.
135 lines (132 loc) • 13.1 kB
JavaScript
import { Inject, Component, Input, forwardRef, Optional } from '@angular/core';
import { connectRange } from 'instantsearch.js/es/connectors';
import { TypedBaseWidget } from '../typed-base-widget';
import { NgAisInstantSearch } from '../instantsearch/instantsearch';
import { NgAisIndex } from '../index-widget/index-widget';
import { parseNumberInput, noop } from '../utils';
export class NgAisRangeInput extends TypedBaseWidget {
constructor(parentIndex, instantSearchInstance) {
super('RangeInput');
this.parentIndex = parentIndex;
this.instantSearchInstance = instantSearchInstance;
// rendering options
this.currency = '$';
this.separator = 'to';
this.submitLabel = 'Go';
this.precision = 0;
this.state = {
range: { min: undefined, max: undefined },
refine: noop,
start: [0, 0],
// TODO: use canRefine & format
canRefine: false,
format: {
from: () => '',
to: () => '',
},
sendEvent: undefined,
};
}
get step() {
const precision = parseNumberInput(this.precision);
return 1 / Math.pow(10, precision);
}
get canRefine() {
return this.state.range.min !== this.state.range.max;
}
ngOnInit() {
this.createWidget(connectRange, {
attribute: this.attribute,
max: parseNumberInput(this.max),
min: parseNumberInput(this.min),
precision: parseNumberInput(this.precision),
}, {
$$widgetType: 'ais.rangeInput',
});
super.ngOnInit();
}
handleChange(event, type) {
const value = parseNumberInput(event.target.value);
if (type === 'min') {
this.minInputValue = value;
}
else {
this.maxInputValue = value;
}
}
handleSubmit(event) {
event.preventDefault();
this.state.refine([this.minInputValue, this.maxInputValue]);
}
}
NgAisRangeInput.decorators = [
{ type: Component, args: [{
selector: 'ais-range-input',
template: `
<div [ngClass]="[
cx(),
!canRefine ? cx('', 'noRefinement') : ''
]">
<form
[class]="cx('form')"
(submit)="handleSubmit($event)"
novalidate
>
<label [class]="cx('label')">
<span [class]="cx('currency')">{{currency}}</span>
<input
[ngClass]="[
cx('input'),
cx('input', 'min')
]"
type="number"
[min]="state.range.min"
[max]="state.range.max"
[placeholder]="state.range.min"
[value]="minInputValue"
[step]="step"
(change)="handleChange($event, 'min')"
/>
</label>
<span [class]="cx('separator')">{{separator}}</span>
<label [class]="cx('label')">
<span [class]="cx('currency')">{{currency}}</span>
<input
[ngClass]="[
cx('input'),
cx('input', 'max')
]"
type="number"
[min]="state.range.min"
[max]="state.range.max"
[placeholder]="state.range.max"
[value]="maxInputValue"
[step]="step"
(change)="handleChange($event, 'max')"
/>
</label>
<button
[class]="cx('submit')"
(click)="handleSubmit($event)"
>
{{submitLabel}}
</button>
</form>
</div>
`
},] }
];
NgAisRangeInput.ctorParameters = () => [
{ type: NgAisIndex, decorators: [{ type: Inject, args: [forwardRef(() => NgAisIndex),] }, { type: Optional }] },
{ type: NgAisInstantSearch, decorators: [{ type: Inject, args: [forwardRef(() => NgAisInstantSearch),] }] }
];
NgAisRangeInput.propDecorators = {
currency: [{ type: Input }],
separator: [{ type: Input }],
submitLabel: [{ type: Input }],
attribute: [{ type: Input }],
min: [{ type: Input }],
max: [{ type: Input }],
precision: [{ type: Input }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-input.js","sourceRoot":"","sources":["../../../src/range-input/range-input.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Component, Input, forwardRef, Optional } from '@angular/core';\n\nimport { connectRange } from 'instantsearch.js/es/connectors';\nimport {\n  RangeConnectorParams,\n  RangeWidgetDescription,\n  RangeRenderState,\n} from 'instantsearch.js/es/connectors/range/connectRange';\n\nimport { TypedBaseWidget } from '../typed-base-widget';\nimport { NgAisInstantSearch } from '../instantsearch/instantsearch';\nimport { NgAisIndex } from '../index-widget/index-widget';\nimport { parseNumberInput, noop } from '../utils';\n\n@Component({\n  selector: 'ais-range-input',\n  template: `\n    <div [ngClass]=\"[\n        cx(),\n        !canRefine ? cx('', 'noRefinement') : ''\n      ]\">\n      <form\n        [class]=\"cx('form')\"\n        (submit)=\"handleSubmit($event)\"\n        novalidate\n      >\n        <label [class]=\"cx('label')\">\n          <span [class]=\"cx('currency')\">{{currency}}</span>\n          <input\n            [ngClass]=\"[\n              cx('input'),\n              cx('input', 'min')\n            ]\"\n            type=\"number\"\n            [min]=\"state.range.min\"\n            [max]=\"state.range.max\"\n            [placeholder]=\"state.range.min\"\n            [value]=\"minInputValue\"\n            [step]=\"step\"\n            (change)=\"handleChange($event, 'min')\"\n          />\n        </label>\n\n        <span [class]=\"cx('separator')\">{{separator}}</span>\n\n        <label [class]=\"cx('label')\">\n          <span [class]=\"cx('currency')\">{{currency}}</span>\n          <input\n            [ngClass]=\"[\n              cx('input'),\n              cx('input', 'max')\n            ]\"\n            type=\"number\"\n            [min]=\"state.range.min\"\n            [max]=\"state.range.max\"\n            [placeholder]=\"state.range.max\"\n            [value]=\"maxInputValue\"\n            [step]=\"step\"\n            (change)=\"handleChange($event, 'max')\"\n          />\n        </label>\n\n        <button\n          [class]=\"cx('submit')\"\n          (click)=\"handleSubmit($event)\"\n        >\n          {{submitLabel}}\n        </button>\n      </form>\n    </div>\n  `,\n})\nexport class NgAisRangeInput extends TypedBaseWidget<\n  RangeWidgetDescription,\n  RangeConnectorParams\n> {\n  // rendering options\n  @Input() public currency: string = '$';\n  @Input() public separator: string = 'to';\n  @Input() public submitLabel: string = 'Go';\n\n  // instance options\n  @Input() public attribute: RangeConnectorParams['attribute'];\n  @Input() public min?: RangeConnectorParams['min'];\n  @Input() public max?: RangeConnectorParams['max'];\n  @Input() public precision?: RangeConnectorParams['precision'] = 0;\n\n  // inner state\n  public minInputValue?: number;\n  public maxInputValue?: number;\n\n  get step() {\n    const precision = parseNumberInput(this.precision);\n    return 1 / Math.pow(10, precision);\n  }\n\n  get canRefine() {\n    return this.state.range.min !== this.state.range.max;\n  }\n\n  public state: RangeRenderState = {\n    range: { min: undefined, max: undefined },\n    refine: noop,\n    start: [0, 0],\n    // TODO: use canRefine & format\n    canRefine: false,\n    format: {\n      from: () => '',\n      to: () => '',\n    },\n    sendEvent: undefined,\n  };\n\n  constructor(\n    @Inject(forwardRef(() => NgAisIndex))\n    @Optional()\n    public parentIndex: NgAisIndex,\n    @Inject(forwardRef(() => NgAisInstantSearch))\n    public instantSearchInstance: NgAisInstantSearch\n  ) {\n    super('RangeInput');\n  }\n\n  public ngOnInit() {\n    this.createWidget(\n      connectRange,\n      {\n        attribute: this.attribute,\n        max: parseNumberInput(this.max),\n        min: parseNumberInput(this.min),\n        precision: parseNumberInput(this.precision),\n      },\n      {\n        $$widgetType: 'ais.rangeInput',\n      }\n    );\n\n    super.ngOnInit();\n  }\n\n  public handleChange(event: any, type: string) {\n    const value = parseNumberInput(event.target.value);\n\n    if (type === 'min') {\n      this.minInputValue = value;\n    } else {\n      this.maxInputValue = value;\n    }\n  }\n\n  public handleSubmit(event: Event) {\n    event.preventDefault();\n    this.state.refine([this.minInputValue, this.maxInputValue]);\n  }\n}\n"]}