book-picker
Version:
<p align="center"> <img width="409" height="331" src="https://raw.githubusercontent.com/ymxk/book-picker/master/book-picker.gif"> </p>
458 lines • 32.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter } from '@angular/core';
import moment from 'moment';
import { HoursOfDay } from './hours-of-day';
import { TimeClass } from './time-class.enum';
import jspath from "jspath";
var TimePickerComponent = /** @class */ (function () {
function TimePickerComponent() {
this.timeCells = [];
this.nowTime = moment();
this.bookeds = new Array();
this.hours = new Array();
this.selected = new EventEmitter();
this.onerror = new EventEmitter();
}
/**
* @return {?}
*/
TimePickerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.initBooksOrHours();
this.getHoursForDays();
};
/**
* @return {?}
*/
TimePickerComponent.prototype.initBooksOrHours = /**
* @return {?}
*/
function () {
if (!this.bookeds) {
this.bookeds = new Array();
}
if (!this.hours) {
this.hours = new Array();
}
};
/**
* @return {?}
*/
TimePickerComponent.prototype.onClear = /**
* @return {?}
*/
function () {
this.start = null;
this.end = null;
};
/**
* @return {?}
*/
TimePickerComponent.prototype.emitSelected = /**
* @return {?}
*/
function () {
this.selected.emit({ start: this.start, end: this.addHalfHour(this.end) });
};
/**
* @param {?} v
* @return {?}
*/
TimePickerComponent.prototype.addHalfHour = /**
* @param {?} v
* @return {?}
*/
function (v) {
return v ? v.clone().add(30, 'm') : null;
};
/**
* @return {?}
*/
TimePickerComponent.prototype.emitError = /**
* @return {?}
*/
function () {
this.onerror.emit();
};
/**
* @param {?} value
* @return {?}
*/
TimePickerComponent.prototype.onSelected = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (this.start && this.end && this.start.isSame(value, 'm') && this.end.isSame(value, 'm')) {
this.onClear();
this.emitSelected();
return false;
}
if (this.start && this.end && this.start.isSame(value, 'm')) {
this.start = this.end;
this.emitSelected();
return false;
}
if (this.start && this.end && this.end.isSame(value, 'm')) {
this.end = this.start;
this.emitSelected();
return false;
}
if (!this.start && !this.end) {
/** @type {?} */
var x = this.includesDisable(value.clone(), value.clone());
if (x) {
this.emitError();
return false;
}
this.start = value;
this.end = value;
this.emitSelected();
return false;
}
if (value.isBefore(this.start)) {
/** @type {?} */
var x = this.includesDisable(value.clone(), this.start.clone());
if (x) {
this.emitError();
return false;
}
this.end = this.start;
this.start = value;
}
if (value.isAfter(this.start)) {
/** @type {?} */
var x = this.includesDisable(this.start.clone(), value.clone());
if (x) {
this.emitError();
return false;
}
this.end = value;
}
this.emitSelected();
};
/**
* @param {?} start
* @param {?} end
* @return {?}
*/
TimePickerComponent.prototype.includesDisable = /**
* @param {?} start
* @param {?} end
* @return {?}
*/
function (start, end) {
var _this = this;
/** @type {?} */
var range = [];
for (var item = start; item.isBefore(end) || item.isSame(end); item.add(30, 'm')) {
range.push(item.clone());
}
return range.filter((/**
* @param {?} e
* @return {?}
*/
function (e) { return _this.includesBooked(e) || _this.includesCloses(e); })).length > 0;
};
/**
* @param {?} v
* @return {?}
*/
TimePickerComponent.prototype.includesBooked = /**
* @param {?} v
* @return {?}
*/
function (v) {
var _this = this;
return this.bookeds.filter((/**
* @param {?} e
* @return {?}
*/
function (e) { return _this.isBetweenDate(v, e.start, e.end); })).length > 0;
};
/**
* @param {?} v
* @return {?}
*/
TimePickerComponent.prototype.includesCloses = /**
* @param {?} v
* @return {?}
*/
function (v) {
var _this = this;
/** @type {?} */
var ph = this.getOpenHoursOnDated();
if (ph && ph.length == 0) {
return true;
}
return ph.filter((/**
* @param {?} e
* @return {?}
*/
function (e) { return _this.isBetweenNotEnd(v, e.opens, e.closes); })).length == 0;
};
/**
* @param {?} v
* @param {?} s
* @param {?} e
* @return {?}
*/
TimePickerComponent.prototype.isBetweenNotEnd = /**
* @param {?} v
* @param {?} s
* @param {?} e
* @return {?}
*/
function (v, s, e) {
/** @type {?} */
var vs = this.setHourMinuteIgnorDate(v);
/** @type {?} */
var ss = this.setHourMinuteIgnorDate(s);
/** @type {?} */
var es = this.setHourMinuteIgnorDate(e);
return (vs.isBetween(ss, es, 'm') || vs.isSame(ss, 'm')) ? true : false;
};
/**
* @param {?} v
* @param {?} s
* @param {?} e
* @return {?}
*/
TimePickerComponent.prototype.isBetweenDate = /**
* @param {?} v
* @param {?} s
* @param {?} e
* @return {?}
*/
function (v, s, e) {
return v.isBetween(s, e) || v.isSame(s) || v.isSame(e);
};
/**
* @param {?} v
* @param {?} s
* @param {?} e
* @return {?}
*/
TimePickerComponent.prototype.isBetweenM = /**
* @param {?} v
* @param {?} s
* @param {?} e
* @return {?}
*/
function (v, s, e) {
return v.isBetween(s, e, 'm') || v.isSame(s, 'm') || v.isSame(e, 'm');
};
/**
* @param {?} value
* @return {?}
*/
TimePickerComponent.prototype.getClassBy = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (this.includesBooked(value)) {
return TimeClass.BOOKED;
}
if (this.includesCloses(value)) {
return TimeClass.DISABLE;
}
if (this.isBetweenM(value, this.start, this.end)) {
return TimeClass.SELECTED;
}
return TimeClass.NORMAL;
};
/**
* @param {?} v
* @return {?}
*/
TimePickerComponent.prototype.isSameDay = /**
* @param {?} v
* @return {?}
*/
function (v) {
return moment().isSame(v, 'month') && moment().isSame(v, 'day');
};
/**
* @return {?}
*/
TimePickerComponent.prototype.getDefaultOpenHours = /**
* @return {?}
*/
function () {
return new HoursOfDay(this.nowTime.clone().startOf('day'), this.nowTime.clone().endOf('day'));
};
/**
* @return {?}
*/
TimePickerComponent.prototype.nextHalfHourInNow = /**
* @return {?}
*/
function () {
/** @type {?} */
var y = parseFloat(this.nowTime.clone().format('mm')) % 30;
return this.addHalfHour(this.nowTime.clone().subtract(y, 'm'));
};
/**
* @param {?} oh
* @return {?}
*/
TimePickerComponent.prototype.replaceStartByNow = /**
* @param {?} oh
* @return {?}
*/
function (oh) {
/** @type {?} */
var start = this.setHourMinuteIgnorDate(oh.start);
if (this.isSameDay(start)) {
return new HoursOfDay(this.nextHalfHourInNow(), oh.end);
}
return oh;
};
/**
* @return {?}
*/
TimePickerComponent.prototype.getHoursForDays = /**
* @return {?}
*/
function () {
/** @type {?} */
var oh = this.getOpenHoursOnDated();
if (oh && oh.length > 0) {
this.createHours(this.toHoursOfDayFrom(oh));
}
else {
this.createHours(this.getDefaultOpenHours());
}
};
/**
* @param {?} v
* @return {?}
*/
TimePickerComponent.prototype.setHourMinuteIgnorDate = /**
* @param {?} v
* @return {?}
*/
function (v) {
return this.nowTime.clone().hour(v.hour()).minute(v.minute());
};
/**
* @param {?} oh
* @return {?}
*/
TimePickerComponent.prototype.createHours = /**
* @param {?} oh
* @return {?}
*/
function (oh) {
/** @type {?} */
var t = this.replaceStartByNow(oh);
/** @type {?} */
var start = t.start.clone();
/** @type {?} */
var end = t.end.clone();
this.timeCells = [];
for (var item = start; item.isBefore(end); item.add(30, 'm')) {
this.timeCells.push(item.clone());
}
};
/**
* @return {?}
*/
TimePickerComponent.prototype.getOpenHoursOnDated = /**
* @return {?}
*/
function () {
var _this = this;
return this.hours.filter((/**
* @param {?} e
* @return {?}
*/
function (e) {
return e.weeks.includes(_this.nowTime.day());
}));
};
;
/**
* @param {?} ts
* @return {?}
*/
TimePickerComponent.prototype.toHoursOfDayFrom = /**
* @param {?} ts
* @return {?}
*/
function (ts) {
/** @type {?} */
var opens = jspath.apply(".opens", ts);
/** @type {?} */
var closes = jspath.apply(".closes", ts);
return new HoursOfDay(this.setHourMinuteIgnorDate(moment.min(opens)), this.setHourMinuteIgnorDate(moment.max(closes)));
};
/**
* @param {?} changes
* @return {?}
*/
TimePickerComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
/** @type {?} */
var log = [];
for (var propName in changes) {
/** @type {?} */
var changedProp = changes[propName];
if (changedProp.isFirstChange()) {
this.nowTime = moment();
}
else {
this.onClear();
this.nowTime = changedProp.currentValue;
this.getHoursForDays();
}
}
};
TimePickerComponent.decorators = [
{ type: Component, args: [{
selector: 'app-time-picker',
template: "<section class=\"card\">\n\n\t<div *ngFor=\"let c of timeCells\" [ngClass]=\"getClassBy(c)\">\n\t\t<div (click)=\"onSelected(c)\">{{c | amDateFormat: 'HH:mm'}}</div>\n\t</div>\n</section>",
styles: ["@charset \"UTF-8\";.card{display:-webkit-flex;display:flex;min-width:100%;min-height:54px;overflow-x:auto;border-top:1px solid #e9e9e9;border-bottom:1px solid #e9e9e9}.card>div{min-width:55px;height:54px;background-color:#fff;text-align:center;border-left:1px solid #e9e9e9}.card>div>div:first-child{font-size:13px;font-family:PingFangSC-Regular;font-weight:400;color:#242424;line-height:54px}.card>div:last-child{border-right:1px solid #e9e9e9}.card::-webkit-scrollbar{display:none}.time-disable div{background:#fbfbfb;color:#c4c4c4!important;line-height:14px!important;padding:20px 0 0 2px}.time-disable ::after{content:\"\\a\u672A\u8425\u4E1A\";white-space:pre-wrap;font-size:10px;color:#c4c4c4}.time-selected div{background:#e5f2ff!important;color:#007aff!important;border-left:0!important}.time-booked div{background:#fbfbfb;color:#c4c4c4!important;line-height:14px!important;padding:20px 0 0 2px}.time-booked ::after{content:\"\\a\u5DF2\u9884\u8BA2\";white-space:pre-wrap;font-size:10px;color:#c4c4c4}"]
}] }
];
/** @nocollapse */
TimePickerComponent.ctorParameters = function () { return []; };
TimePickerComponent.propDecorators = {
nowTime: [{ type: Input }],
bookeds: [{ type: Input }],
hours: [{ type: Input }],
selected: [{ type: Output }],
onerror: [{ type: Output }]
};
return TimePickerComponent;
}());
export { TimePickerComponent };
if (false) {
/** @type {?} */
TimePickerComponent.prototype.timeCells;
/** @type {?} */
TimePickerComponent.prototype.nowTime;
/** @type {?} */
TimePickerComponent.prototype.bookeds;
/** @type {?} */
TimePickerComponent.prototype.hours;
/** @type {?} */
TimePickerComponent.prototype.selected;
/** @type {?} */
TimePickerComponent.prototype.onerror;
/** @type {?} */
TimePickerComponent.prototype.start;
/** @type {?} */
TimePickerComponent.prototype.end;
/* Skipping unhandled member: ;*/
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"ng://book-picker/","sources":["time-picker/time-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, OnChanges, SimpleChange, EventEmitter } from '@angular/core';\nimport moment from 'moment';\nimport { TimeRange } from '../time-range';\nimport { Booked } from '../booked';\nimport { Hours } from '../hours';\nimport { HoursOfDay } from './hours-of-day';\nimport { TimeClass } from './time-class.enum';\nimport jspath from \"jspath\";\n\n@Component({\n  selector: 'app-time-picker',\n  templateUrl: './time-picker.component.html',\n  styleUrls: ['./time-picker.component.scss']\n})\nexport class TimePickerComponent implements OnInit {\n  timeCells: moment.Moment[] = [];\n  @Input() nowTime: moment.Moment = moment();\n  @Input() bookeds: Booked[] = new Array();\n  @Input() hours: Hours[] = new Array();\n  @Output() selected = new EventEmitter<TimeRange>();\n  @Output() onerror = new EventEmitter<TimeRange>();\n  start: moment.Moment;\n  end: moment.Moment;\n\n  constructor() { }\n\n  ngOnInit() {\n    this.initBooksOrHours();\n    this.getHoursForDays();\n  }\n\n  initBooksOrHours() {\n    if (!this.bookeds) {\n      this.bookeds = new Array();\n    }\n    if (!this.hours) {\n      this.hours = new Array();\n    }\n  }\n\n  onClear() {\n    this.start = null;\n    this.end = null;\n  }\n\n  emitSelected() {\n    this.selected.emit({ start: this.start, end: this.addHalfHour(this.end) });\n  }\n\n  addHalfHour(v: moment.Moment) {\n    return v ? v.clone().add(30, 'm') : null;\n  }\n\n  emitError() {\n    this.onerror.emit();\n  }\n\n  onSelected(value: moment.Moment) {\n    if (this.start && this.end && this.start.isSame(value, 'm') && this.end.isSame(value, 'm')) {\n      this.onClear();\n      this.emitSelected();\n      return false;\n    }\n    if (this.start && this.end && this.start.isSame(value, 'm')) {\n      this.start = this.end;\n      this.emitSelected();\n      return false;\n    }\n    if (this.start && this.end && this.end.isSame(value, 'm')) {\n      this.end = this.start;\n      this.emitSelected();\n      return false;\n    }\n    if (!this.start && !this.end) {\n      let x = this.includesDisable(value.clone(), value.clone());\n      if (x) {\n        this.emitError();\n        return false;\n      }\n      this.start = value;\n      this.end = value;\n      this.emitSelected();\n      return false;\n    }\n    if (value.isBefore(this.start)) {\n      let x = this.includesDisable(value.clone(), this.start.clone());\n      if (x) {\n        this.emitError();\n        return false;\n      }\n      this.end = this.start;\n      this.start = value;\n    }\n    if (value.isAfter(this.start)) {\n      let x = this.includesDisable(this.start.clone(), value.clone());\n      if (x) {\n        this.emitError();\n        return false;\n      }\n      this.end = value;\n    }\n    this.emitSelected();\n  }\n\n  includesDisable(start: moment.Moment, end: moment.Moment) {\n    let range = [];\n    for (let item = start; item.isBefore(end) || item.isSame(end); item.add(30, 'm')) {\n      range.push(item.clone());\n    }\n    return range.filter(e => { return this.includesBooked(e) || this.includesCloses(e); }).length > 0;\n  }\n\n  includesBooked(v: moment.Moment) {\n    return this.bookeds.filter(e => { return this.isBetweenDate(v, e.start, e.end) }).length > 0;\n  }\n\n  includesCloses(v: moment.Moment) {\n    let ph = this.getOpenHoursOnDated();\n    if (ph && ph.length == 0) {\n      return true;\n    }\n    return ph.filter(e => { return this.isBetweenNotEnd(v, e.opens, e.closes); }).length == 0;\n  }\n\n  isBetweenNotEnd(v: moment.Moment, s: moment.Moment, e: moment.Moment) {\n    let vs = this.setHourMinuteIgnorDate(v);\n    let ss = this.setHourMinuteIgnorDate(s);\n    let es = this.setHourMinuteIgnorDate(e);\n    return (vs.isBetween(ss, es, 'm') || vs.isSame(ss, 'm')) ? true : false;\n  }\n\n  isBetweenDate(v: moment.Moment, s: moment.Moment, e: moment.Moment) {\n    return v.isBetween(s, e) || v.isSame(s) || v.isSame(e);\n  }\n\n  isBetweenM(v: moment.Moment, s: moment.Moment, e: moment.Moment) {\n    return v.isBetween(s, e, 'm') || v.isSame(s, 'm') || v.isSame(e, 'm');\n  }\n\n  getClassBy(value: moment.Moment) {\n    if (this.includesBooked(value)) {\n      return TimeClass.BOOKED;\n    }\n    if (this.includesCloses(value)) {\n      return TimeClass.DISABLE;\n    }\n    if (this.isBetweenM(value, this.start, this.end)) {\n      return TimeClass.SELECTED;\n    }\n    return TimeClass.NORMAL;\n  }\n\n  isSameDay(v: moment.Moment) {\n    return moment().isSame(v, 'month') && moment().isSame(v, 'day');\n  }\n\n  getDefaultOpenHours() {\n    return new HoursOfDay(this.nowTime.clone().startOf('day'), this.nowTime.clone().endOf('day'));\n  }\n\n  nextHalfHourInNow() {\n    const y = parseFloat(this.nowTime.clone().format('mm')) % 30;\n    return this.addHalfHour(this.nowTime.clone().subtract(y, 'm'));\n  }\n\n  replaceStartByNow(oh: HoursOfDay) {\n    let start = this.setHourMinuteIgnorDate(oh.start);\n    if (this.isSameDay(start)) {\n\n      return new HoursOfDay(this.nextHalfHourInNow(), oh.end);\n    }\n    return oh;\n  }\n\n  getHoursForDays() {\n    let oh = this.getOpenHoursOnDated();\n    if (oh && oh.length > 0) {\n      this.createHours(this.toHoursOfDayFrom(oh));\n    } else {\n      this.createHours(this.getDefaultOpenHours());\n    }\n  }\n\n  setHourMinuteIgnorDate(v: moment.Moment) {\n    return this.nowTime.clone().hour(v.hour()).minute(v.minute());\n  }\n\n  createHours(oh: HoursOfDay) {\n    let t = this.replaceStartByNow(oh);\n    let start = t.start.clone();\n    let end = t.end.clone();\n    this.timeCells = [];\n    for (let item = start; item.isBefore(end); item.add(30, 'm')) {\n      this.timeCells.push(item.clone());\n    }\n  }\n\n  getOpenHoursOnDated() {\n    return this.hours.filter((e: Hours) => {\n      return e.weeks.includes(this.nowTime.day()); \n    })\n  };\n\n  toHoursOfDayFrom(ts: Hours[]) {\n    const opens = jspath.apply(`.opens`, ts);\n    const closes = jspath.apply(`.closes`, ts);\n    return new HoursOfDay(this.setHourMinuteIgnorDate(moment.min(opens)), this.setHourMinuteIgnorDate(moment.max(closes)));\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    let log: string[] = [];\n    for (let propName in changes) {\n      let changedProp = changes[propName];\n      if (changedProp.isFirstChange()) {\n        this.nowTime = moment();\n      } else {\n        this.onClear();\n        this.nowTime = changedProp.currentValue;\n        this.getHoursForDays();\n      }\n    }\n  }\n}"]}