@ohayojp.com/components
Version:
Common business components of ohayojp.
448 lines (442 loc) • 15.5 kB
JavaScript
import { __decorate, __metadata } from 'tslib';
import { DOCUMENT, CommonModule } from '@angular/common';
import { Component, ChangeDetectionStrategy, ViewEncapsulation, ElementRef, NgZone, Inject, ChangeDetectorRef, ViewChild, Input, NgModule } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';
import { InputBoolean, InputNumber, OhayoUtilModule } from '@ohayojp.com/util';
import { take } from 'rxjs/operators';
import { ObserversModule } from '@angular/cdk/observers';
import { NzToolTipModule } from 'ng-zorro-antd/tooltip';
/**
* @fileoverview added by tsickle
* Generated from: ellipsis.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
class EllipsisComponent {
/**
* @param {?} el
* @param {?} ngZone
* @param {?} dom
* @param {?} doc
* @param {?} cdr
*/
constructor(el, ngZone, dom, doc, cdr) {
this.el = el;
this.ngZone = ngZone;
this.dom = dom;
this.doc = doc;
this.cdr = cdr;
// tslint:disable-next-line:no-string-literal
this.isSupportLineClamp = this.doc.body.style['webkitLineClamp'] !== undefined;
this.inited = false;
this.type = 'default';
this.cls = {};
this.text = '';
this.targetCount = 0;
// #region fields
this.tooltip = false;
this.fullWidthRecognition = false;
this.tail = '...';
}
// #endregion
/**
* @return {?}
*/
get linsWord() {
const { targetCount, text, tail } = this;
return (targetCount > 0 ? text.substring(0, targetCount) : '') + (targetCount > 0 && targetCount < text.length ? tail : '');
}
/**
* @private
* @param {?} str
* @return {?}
*/
getStrFullLength(str) {
return str.split('').reduce((/**
* @param {?} pre
* @param {?} cur
* @return {?}
*/
(pre, cur) => {
/** @type {?} */
const charCode = cur.charCodeAt(0);
if (charCode >= 0 && charCode <= 128) {
return pre + 1;
}
return pre + 2;
}), 0);
}
/**
* @private
* @param {?} str
* @param {?} maxLength
* @return {?}
*/
cutStrByFullLength(str, maxLength) {
/** @type {?} */
let showLength = 0;
return str.split('').reduce((/**
* @param {?} pre
* @param {?} cur
* @return {?}
*/
(pre, cur) => {
/** @type {?} */
const charCode = cur.charCodeAt(0);
if (charCode >= 0 && charCode <= 128) {
showLength += 1;
}
else {
showLength += 2;
}
if (showLength <= maxLength) {
return pre + cur;
}
return pre;
}), '');
}
/**
* @private
* @param {?} targetHeight
* @param {?} mid
* @param {?} begin
* @param {?} end
* @param {?} text
* @param {?} node
* @return {?}
*/
bisection(targetHeight, mid, begin, end, text, node) {
/** @type {?} */
const suffix = this.tail;
node.innerHTML = text.substring(0, mid) + suffix;
/** @type {?} */
let sh = node.offsetHeight;
if (sh <= targetHeight) {
node.innerHTML = text.substring(0, mid + 1) + suffix;
sh = node.offsetHeight;
if (sh > targetHeight || mid === begin) {
return mid;
}
begin = mid;
mid = end - begin === 1 ? begin + 1 : Math.floor((end - begin) / 2) + begin;
return this.bisection(targetHeight, mid, begin, end, text, node);
}
if (mid - 1 < 0) {
return mid;
}
node.innerHTML = text.substring(0, mid - 1) + suffix;
sh = node.offsetHeight;
if (sh <= targetHeight) {
return mid - 1;
}
end = mid;
mid = Math.floor((end - begin) / 2) + begin;
return this.bisection(targetHeight, mid, begin, end, text, node);
}
/**
* @private
* @return {?}
*/
genType() {
const { lines, length, isSupportLineClamp } = this;
this.cls = {
ellipsis: true,
ellipsis__lines: lines && !isSupportLineClamp,
'ellipsis__line-clamp': lines && isSupportLineClamp,
};
if (!lines && !length) {
this.type = 'default';
}
else if (!lines) {
this.type = 'length';
}
else if (isSupportLineClamp) {
this.type = 'line-clamp';
}
else {
this.type = 'line';
}
}
/**
* @private
* @return {?}
*/
gen() {
const { type, lines, length, fullWidthRecognition, tail, orgEl, cdr, ngZone } = this;
if (type === 'length') {
/** @type {?} */
const el = (/** @type {?} */ (orgEl.nativeElement));
if (el.children.length > 0) {
throw new Error('Ellipsis content must be string.');
}
/** @type {?} */
const lengthText = (/** @type {?} */ (el.textContent));
/** @type {?} */
const textLength = fullWidthRecognition ? this.getStrFullLength(lengthText) : lengthText.length;
if (textLength <= length || length < 0) {
this.text = lengthText;
}
else {
/** @type {?} */
let displayText;
if (length - tail.length <= 0) {
displayText = '';
}
else {
displayText = fullWidthRecognition ? this.cutStrByFullLength(lengthText, length) : lengthText.slice(0, length);
}
this.text = displayText + tail;
}
ngZone.run((/**
* @return {?}
*/
() => cdr.detectChanges()));
}
else if (type === 'line') {
const { shadowOrgEl, shadowTextEl } = this;
/** @type {?} */
const orgNode = (/** @type {?} */ (shadowOrgEl.nativeElement));
/** @type {?} */
const lineText = orgNode.innerText || (/** @type {?} */ (orgNode.textContent));
/** @type {?} */
const lineHeight = parseInt((/** @type {?} */ (getComputedStyle(this.getEl('.ellipsis')).lineHeight)), 10);
/** @type {?} */
const targetHeight = lines * lineHeight;
this.getEl('.ellipsis__handle').style.height = `${targetHeight}px`;
if (orgNode.offsetHeight <= targetHeight) {
this.text = lineText;
this.targetCount = lineText.length;
}
else {
// bisection
/** @type {?} */
const len = lineText.length;
/** @type {?} */
const mid = Math.ceil(len / 2);
/** @type {?} */
const count = this.bisection(targetHeight, mid, 0, len, lineText, shadowTextEl.nativeElement.firstChild);
this.text = lineText;
this.targetCount = count;
}
ngZone.run((/**
* @return {?}
*/
() => cdr.detectChanges()));
}
}
/**
* @private
* @param {?} cls
* @return {?}
*/
getEl(cls) {
return this.el.nativeElement.querySelector(cls);
}
/**
* @private
* @param {?} fn
* @return {?}
*/
executeOnStable(fn) {
if (this.ngZone.isStable) {
fn();
}
else {
this.ngZone.onStable.asObservable().pipe(take(1)).subscribe(fn);
}
}
/**
* @return {?}
*/
refresh() {
this.genType();
const { type, dom, orgEl, cdr } = this;
/** @type {?} */
const html = orgEl.nativeElement.innerHTML;
this.orgHtml = dom.bypassSecurityTrustHtml(html);
cdr.detectChanges();
this.executeOnStable((/**
* @return {?}
*/
() => {
this.gen();
if (type !== 'line') {
/** @type {?} */
const el = this.getEl('.ellipsis');
if (el) {
el.innerHTML = html;
}
}
}));
}
/**
* @return {?}
*/
ngAfterViewInit() {
this.inited = true;
this.refresh();
}
/**
* @return {?}
*/
ngOnChanges() {
if (this.inited) {
this.refresh();
}
}
}
EllipsisComponent.decorators = [
{
type: Component, args: [{
selector: 'ellipsis',
exportAs: 'ellipsis',
template: "<div (cdkObserveContent)=\"refresh()\" #orgEl style=\"display: none;\"><ng-content></ng-content></div>\n<ng-template #tooltipTpl let-con>\n <span *ngIf=\"tooltip; else con\" nz-tooltip [nzTooltipTitle]=\"titleTpl\" [nzTooltipOverlayStyle]=\"{ 'overflow-wrap': 'break-word', 'word-wrap': 'break-word' }\">\n <ng-container *ngTemplateOutlet=\"con\"></ng-container>\n <ng-template #titleTpl><div [innerHTML]=\"orgHtml\"></div></ng-template>\n </span>\n</ng-template>\n<ng-container [ngSwitch]=\"type\">\n <span *ngSwitchCase=\"'default'\" [ngClass]=\"cls\"></span>\n <ng-container *ngSwitchCase=\"'length'\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lengthTpl }\"></ng-template>\n <ng-template #lengthTpl>{{ text }}</ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"'line-clamp'\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lineClampTpl }\"></ng-template>\n <ng-template #lineClampTpl>\n <div [ngClass]=\"cls\" [ngStyle]=\"{ '-webkit-line-clamp': lines, '-webkit-box-orient': 'vertical' }\"></div>\n </ng-template>\n </ng-container>\n <div *ngSwitchCase=\"'line'\" [ngClass]=\"cls\">\n <div class=\"ellipsis__handle\">\n <ng-template [ngTemplateOutlet]=\"tooltipTpl\" [ngTemplateOutletContext]=\"{ $implicit: lineTpl }\"></ng-template>\n <ng-template #lineTpl>{{ linsWord }}</ng-template>\n <div class=\"ellipsis__shadow\" #shadowOrgEl [innerHTML]=\"orgHtml\"></div>\n <div class=\"ellipsis__shadow\" #shadowTextEl>\n <span>{{ text }}</span>\n </div>\n </div>\n </div>\n</ng-container>\n",
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None
}]
}
];
/** @nocollapse */
EllipsisComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: NgZone },
{ type: DomSanitizer },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: ChangeDetectorRef }
];
EllipsisComponent.propDecorators = {
orgEl: [{ type: ViewChild, args: ['orgEl', { static: false },] }],
shadowOrgEl: [{ type: ViewChild, args: ['shadowOrgEl', { static: false },] }],
shadowTextEl: [{ type: ViewChild, args: ['shadowTextEl', { static: false },] }],
tooltip: [{ type: Input }],
length: [{ type: Input }],
lines: [{ type: Input }],
fullWidthRecognition: [{ type: Input }],
tail: [{ type: Input }]
};
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], EllipsisComponent.prototype, "tooltip", void 0);
__decorate([
InputNumber(null),
__metadata("design:type", Number)
], EllipsisComponent.prototype, "length", void 0);
__decorate([
InputNumber(null),
__metadata("design:type", Number)
], EllipsisComponent.prototype, "lines", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], EllipsisComponent.prototype, "fullWidthRecognition", void 0);
if (false) {
/** @type {?} */
EllipsisComponent.ngAcceptInputType_tooltip;
/** @type {?} */
EllipsisComponent.ngAcceptInputType_length;
/** @type {?} */
EllipsisComponent.ngAcceptInputType_lines;
/** @type {?} */
EllipsisComponent.ngAcceptInputType_fullWidthRecognition;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.isSupportLineClamp;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.orgEl;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.shadowOrgEl;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.shadowTextEl;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.inited;
/** @type {?} */
EllipsisComponent.prototype.orgHtml;
/** @type {?} */
EllipsisComponent.prototype.type;
/** @type {?} */
EllipsisComponent.prototype.cls;
/** @type {?} */
EllipsisComponent.prototype.text;
/** @type {?} */
EllipsisComponent.prototype.targetCount;
/** @type {?} */
EllipsisComponent.prototype.tooltip;
/** @type {?} */
EllipsisComponent.prototype.length;
/** @type {?} */
EllipsisComponent.prototype.lines;
/** @type {?} */
EllipsisComponent.prototype.fullWidthRecognition;
/** @type {?} */
EllipsisComponent.prototype.tail;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.el;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.ngZone;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.dom;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.doc;
/**
* @type {?}
* @private
*/
EllipsisComponent.prototype.cdr;
}
/**
* @fileoverview added by tsickle
* Generated from: ellipsis.module.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @type {?} */
const COMPONENTS = [EllipsisComponent];
class EllipsisModule {
}
EllipsisModule.decorators = [
{
type: NgModule, args: [{
imports: [CommonModule, ObserversModule, OhayoUtilModule, NzToolTipModule],
declarations: [...COMPONENTS],
exports: [...COMPONENTS],
},]
}
];
/**
* @fileoverview added by tsickle
* Generated from: public_api.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* Generated from: ellipsis.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
export { EllipsisComponent, EllipsisModule };
//# sourceMappingURL=ellipsis.js.map