@mescius/inputman.comment.angular
Version:
このパッケージには、Angular用の[InputManJS](https://developer.mescius.jp/inputmanjs)コンポーネントが含まれます。
288 lines • 37.3 kB
JavaScript
import { ElementRef, Input, Output, EventEmitter, Component, } from "@angular/core";
import { GC } from "../inputman";
import { MethodType, isEmpty, getMethodPrefix, IMCommentCtrl, } from "./common";
import * as i0 from "@angular/core";
export class GcCommentComponent {
constructor(ref) {
this.editorCreated = new EventEmitter();
this.preprocessError = new EventEmitter();
this.beforeExecuteCommand = new EventEmitter();
this.afterExecuteCommand = new EventEmitter();
this.beforeFirstLoad = new EventEmitter();
this.afterFirstLoad = new EventEmitter();
this.onInitialized = new EventEmitter();
this._container = ref.nativeElement;
}
ngOnChanges(changes) {
if (!this._imGcComment) {
return;
}
Object.keys(changes).forEach((key) => {
let currentValue = changes[key].currentValue;
this.setValueToIMControl(key, currentValue);
});
}
setValueToIMControl(key, value) {
if (value === undefined) {
return;
}
if (this.isSetAccessor(key)) {
this._imGcComment[key] = value;
return;
}
let setter = this.tryGetPropertyOperator(key, MethodType.setter);
if (this.hasRealMethod(setter)) {
if (this.propDic &&
this.propDic[key] &&
this.propDic[key].isPramArr === true) {
this._imGcComment[setter].apply(this._imGcComment, value);
}
else {
this._imGcComment[setter](value);
}
}
}
hasRealMethod(methodName) {
return (this._imGcComment &&
typeof this._imGcComment[methodName] === "function");
}
isSetAccessor(key) {
let descriptor = Object.getOwnPropertyDescriptor(this._imGcComment.constructor.prototype, key);
if (descriptor && descriptor.set) {
return true;
}
return false;
}
tryGetPropertyOperator(propertyName, methodType) {
let method = "";
if (this.propDic && this.propDic[propertyName]) {
method =
methodType === MethodType.getter
? this.propDic[propertyName].getter
: this.propDic[propertyName].setter;
if (!isEmpty(method)) {
return method;
}
}
return (getMethodPrefix(methodType) +
propertyName[0].toUpperCase() +
propertyName.slice(1));
}
ngAfterContentInit() {
this.initGcComment();
this.bindEvent();
if (this.propDic) {
var unSupportWithinConfigProps = Object.keys(this.propDic).filter((p) => this.propDic[p] &&
this.propDic[p].supportWithinConfig === false);
unSupportWithinConfigProps.sort((p1, p2) => {
return this.propDic[p1].order - this.propDic[p2].order;
});
unSupportWithinConfigProps.forEach((p) => {
this.setValueToIMControl(p, this[p]);
});
}
this._container[IMCommentCtrl] = this._imGcComment;
}
bindEvent() {
if (!this._imGcComment) {
return;
}
this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.EditorCreated, (e) => {
this.editorCreated.emit(e);
});
this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.PreprocessError, (e) => {
this.preprocessError.emit(e);
});
this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.BeforeExecuteCommand, (e) => {
this.beforeExecuteCommand.emit(e);
});
this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.AfterExecuteCommand, (e) => {
this.afterExecuteCommand.emit(e);
});
this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.BeforeFirstLoad, () => {
this.beforeFirstLoad.emit();
});
this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.AfterFirstLoad, () => {
this.afterFirstLoad.emit();
});
}
ngOnDestroy() {
if (this._container != null) {
this._container.remove();
this._imGcComment?.destroy?.();
this._imGcComment = null;
}
}
initGcComment() {
let element = document.createElement('div');
this.createTemplate(element);
this._imGcComment = new GC.InputMan.GcComment(element, this);
if (Array.isArray(this.comments)) {
this._imGcComment.comments = this.comments;
}
if (this.stickedComment) {
this._imGcComment.stickedComment = this.stickedComment;
}
this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.CreateEditor, this.createEditor);
this.onInitialized.emit(this._imGcComment);
}
createTemplate(element) {
this._container.innerHTML = "";
this._container.appendChild(element);
}
getNestedIMControl() {
return this._imGcComment;
}
}
GcCommentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GcCommentComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
GcCommentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GcCommentComponent, selector: "gc-comment", inputs: { userInfo: "userInfo", candidateReactionList: "candidateReactionList", candidateReactionListColumns: "candidateReactionListColumns", postTimeFormatter: "postTimeFormatter", updateTimeFormatter: "updateTimeFormatter", showIcon: "showIcon", addCommentEditorPosition: "addCommentEditorPosition", commentMode: "commentMode", header: "header", footer: "footer", headerFooterItems: "headerFooterItems", commentAction: "commentAction", commentInfoAction: "commentInfoAction", commentActionItem: "commentActionItem", commentInfoActionItem: "commentInfoActionItem", commentActionButtonType: "commentActionButtonType", pageSize: "pageSize", loadOnDemand: "loadOnDemand", allowAnonymous: "allowAnonymous", anonymousUserInfo: "anonymousUserInfo", warningMessage: "warningMessage", watermark: "watermark", commentFormatter: "commentFormatter", editorConfig: "editorConfig", avatarType: "avatarType", loadUsersInfoHandler: "loadUsersInfoHandler", loadComments: "loadComments", addNewCommentTo: "addNewCommentTo", keepDraft: "keepDraft", dataSource: "dataSource", loadCommentCount: "loadCommentCount", commentCountFormatter: "commentCountFormatter", loadReactionCount: "loadReactionCount", reactionCountFormatter: "reactionCountFormatter", sortInfo: "sortInfo", createEditor: "createEditor", loadRepliesOnDemand: "loadRepliesOnDemand", replyLevel: "replyLevel", collapseRepliesMode: "collapseRepliesMode", showCurrentUserName: "showCurrentUserName", contextToolbar: "contextToolbar", contextToolbarItem: "contextToolbarItem", loadCommentReplies: "loadCommentReplies", comments: "comments", stickedComment: "stickedComment", copiedLinkDisplayTextFormatter: "copiedLinkDisplayTextFormatter", copiedLinkFormatter: "copiedLinkFormatter", copiedLinkSearchParams: "copiedLinkSearchParams", pastedLinkType: "pastedLinkType", showLinkTypeContextToolbar: "showLinkTypeContextToolbar", loadCommentByLink: "loadCommentByLink", openLinkMode: "openLinkMode", loadStickedComment: "loadStickedComment", showZeroReaction: "showZeroReaction", showOpenReactionListButton: "showOpenReactionListButton", readOnly: "readOnly", enabled: "enabled", height: "height", width: "width", maxHeight: "maxHeight", maxWidth: "maxWidth", minHeight: "minHeight", minWidth: "minWidth", banner: "banner" }, outputs: { editorCreated: "editorCreated", preprocessError: "preprocessError", beforeExecuteCommand: "beforeExecuteCommand", afterExecuteCommand: "afterExecuteCommand", beforeFirstLoad: "beforeFirstLoad", afterFirstLoad: "afterFirstLoad", onInitialized: "onInitialized" }, usesOnChanges: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GcCommentComponent, decorators: [{
type: Component,
args: [{
selector: "gc-comment",
template: `<ng-content></ng-content>`,
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { userInfo: [{
type: Input
}], candidateReactionList: [{
type: Input
}], candidateReactionListColumns: [{
type: Input
}], postTimeFormatter: [{
type: Input
}], updateTimeFormatter: [{
type: Input
}], showIcon: [{
type: Input
}], addCommentEditorPosition: [{
type: Input
}], commentMode: [{
type: Input
}], header: [{
type: Input
}], footer: [{
type: Input
}], headerFooterItems: [{
type: Input
}], commentAction: [{
type: Input
}], commentInfoAction: [{
type: Input
}], commentActionItem: [{
type: Input
}], commentInfoActionItem: [{
type: Input
}], commentActionButtonType: [{
type: Input
}], pageSize: [{
type: Input
}], loadOnDemand: [{
type: Input
}], allowAnonymous: [{
type: Input
}], anonymousUserInfo: [{
type: Input
}], warningMessage: [{
type: Input
}], watermark: [{
type: Input
}], commentFormatter: [{
type: Input
}], editorConfig: [{
type: Input
}], avatarType: [{
type: Input
}], loadUsersInfoHandler: [{
type: Input
}], loadComments: [{
type: Input
}], addNewCommentTo: [{
type: Input
}], keepDraft: [{
type: Input
}], dataSource: [{
type: Input
}], loadCommentCount: [{
type: Input
}], commentCountFormatter: [{
type: Input
}], loadReactionCount: [{
type: Input
}], reactionCountFormatter: [{
type: Input
}], sortInfo: [{
type: Input
}], createEditor: [{
type: Input
}], loadRepliesOnDemand: [{
type: Input
}], replyLevel: [{
type: Input
}], collapseRepliesMode: [{
type: Input
}], showCurrentUserName: [{
type: Input
}], contextToolbar: [{
type: Input
}], contextToolbarItem: [{
type: Input
}], loadCommentReplies: [{
type: Input
}], comments: [{
type: Input
}], stickedComment: [{
type: Input
}], copiedLinkDisplayTextFormatter: [{
type: Input
}], copiedLinkFormatter: [{
type: Input
}], copiedLinkSearchParams: [{
type: Input
}], pastedLinkType: [{
type: Input
}], showLinkTypeContextToolbar: [{
type: Input
}], loadCommentByLink: [{
type: Input
}], openLinkMode: [{
type: Input
}], loadStickedComment: [{
type: Input
}], showZeroReaction: [{
type: Input
}], showOpenReactionListButton: [{
type: Input
}], readOnly: [{
type: Input
}], enabled: [{
type: Input
}], height: [{
type: Input
}], width: [{
type: Input
}], maxHeight: [{
type: Input
}], maxWidth: [{
type: Input
}], minHeight: [{
type: Input
}], minWidth: [{
type: Input
}], banner: [{
type: Input
}], editorCreated: [{
type: Output
}], preprocessError: [{
type: Output
}], beforeExecuteCommand: [{
type: Output
}], afterExecuteCommand: [{
type: Output
}], beforeFirstLoad: [{
type: Output
}], afterFirstLoad: [{
type: Output
}], onInitialized: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GcComment.js","sourceRoot":"","sources":["../../../comment/GcComment.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    OnChanges,\n    OnDestroy,\n    AfterContentInit,\n    ElementRef,\n    SimpleChanges,\n    Input,\n    Output,\n    EventEmitter,\n    Component,\n} from \"@angular/core\";\nimport { GC } from \"../inputman\";\nimport {\n    MethodType,\n    isEmpty,\n    getMethodPrefix,\n    PropertyDictionary,\n    IMCommentCtrl,\n} from \"./common\";\n\n@Component({\n    selector: \"gc-comment\",\n    template: `<ng-content></ng-content>`,\n})\nexport class GcCommentComponent\n    implements OnChanges, AfterContentInit, OnDestroy\n{\n    protected _container: Element;\n    protected _imGcComment: GC.InputMan.GcComment;\n    protected propDic: PropertyDictionary;\n\n    constructor(ref: ElementRef) {\n        this._container = ref.nativeElement;\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (!this._imGcComment) {\n            return;\n        }\n\n        Object.keys(changes).forEach((key: string) => {\n            let currentValue = changes[key].currentValue;\n            this.setValueToIMControl(key, currentValue);\n        });\n    }\n\n    protected setValueToIMControl(key: string, value: any): void {\n        if (value === undefined) {\n            return;\n        }\n\n        if (this.isSetAccessor(key)) {\n            this._imGcComment[key] = value;\n            return;\n        }\n\n        let setter = this.tryGetPropertyOperator(key, MethodType.setter);\n        if (this.hasRealMethod(setter)) {\n            if (\n                this.propDic &&\n                this.propDic[key] &&\n                this.propDic[key].isPramArr === true\n            ) {\n                this._imGcComment[setter].apply(this._imGcComment, value);\n            } else {\n                this._imGcComment[setter](value);\n            }\n        }\n    }\n\n    private hasRealMethod(methodName: string): boolean {\n        return (\n            this._imGcComment &&\n            typeof this._imGcComment[methodName] === \"function\"\n        );\n    }\n\n    private isSetAccessor(key: string) {\n        let descriptor = Object.getOwnPropertyDescriptor(\n            this._imGcComment.constructor.prototype,\n            key\n        );\n        if (descriptor && descriptor.set) {\n            return true;\n        }\n        return false;\n    }\n\n    private tryGetPropertyOperator(\n        propertyName: string,\n        methodType: MethodType\n    ): string {\n        let method: string = \"\";\n        if (this.propDic && this.propDic[propertyName]) {\n            method =\n                methodType === MethodType.getter\n                    ? this.propDic[propertyName].getter\n                    : this.propDic[propertyName].setter;\n            if (!isEmpty(method)) {\n                return method;\n            }\n        }\n        return (\n            getMethodPrefix(methodType) +\n            propertyName[0].toUpperCase() +\n            propertyName.slice(1)\n        );\n    }\n\n    public ngAfterContentInit(): void {\n        this.initGcComment();\n        this.bindEvent();\n        if (this.propDic) {\n            var unSupportWithinConfigProps = Object.keys(this.propDic).filter(\n                (p) =>\n                    this.propDic[p] &&\n                    this.propDic[p].supportWithinConfig === false\n            );\n            unSupportWithinConfigProps.sort((p1, p2) => {\n                return this.propDic[p1].order - this.propDic[p2].order;\n            });\n\n            unSupportWithinConfigProps.forEach((p) => {\n                this.setValueToIMControl(p, this[p]);\n            });\n        }\n        this._container[IMCommentCtrl] = this._imGcComment;\n    }\n\n    protected bindEvent(): void {\n        if (!this._imGcComment) {\n            return;\n        }\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.EditorCreated,\n            (e) => {\n                this.editorCreated.emit(e);\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.PreprocessError,\n            (e) => {\n                this.preprocessError.emit(e);\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.BeforeExecuteCommand,\n            (e) => {\n                this.beforeExecuteCommand.emit(e);\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.AfterExecuteCommand,\n            (e) => {\n                this.afterExecuteCommand.emit(e);\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.BeforeFirstLoad,\n            () => {\n                this.beforeFirstLoad.emit();\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.AfterFirstLoad,\n            () => {\n                this.afterFirstLoad.emit();\n            }\n        );\n    }\n\n    public ngOnDestroy(): void {\n        if (this._container != null) {\n            this._container.remove();\n            this._imGcComment?.destroy?.();\n            this._imGcComment = null;\n        }\n    }\n\n    private initGcComment(): void {\n        let element = document.createElement('div');\n        this.createTemplate(element);\n        this._imGcComment = new GC.InputMan.GcComment(element, this as any);\n        if (Array.isArray(this.comments)) {\n            this._imGcComment.comments = this.comments;\n        }\n        if (this.stickedComment) {\n            this._imGcComment.stickedComment = this.stickedComment;\n        }\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.CreateEditor,\n            this.createEditor\n        );\n        this.onInitialized.emit(this._imGcComment);\n    }\n\n    private createTemplate(element: HTMLElement) {\n        this._container.innerHTML = \"\";\n        this._container.appendChild(element);\n    }\n\n    public getNestedIMControl(): GC.InputMan.GcComment {\n        return this._imGcComment;\n    }\n\n    @Input()\n    userInfo?: GC.InputMan.UserInfo;\n    @Input()\n    candidateReactionList?: (string| GC.InputMan.CandidateReactionItem)[];\n    @Input()\n    candidateReactionListColumns?: number;\n    @Input()\n    postTimeFormatter?: GC.InputMan.DateFormatter;\n    @Input()\n    updateTimeFormatter?: GC.InputMan.DateFormatter;\n    @Input()\n    showIcon?: boolean;\n    @Input()\n    addCommentEditorPosition?: GC.InputMan.GcCommentEditorPosition;\n    @Input()\n    commentMode?: GC.InputMan.GcCommentMode;\n    @Input()\n    header?: (string | GC.InputMan.GcCommentHeaderFooterItem)[];\n    @Input()\n    footer?: (string | GC.InputMan.GcCommentHeaderFooterItem)[];\n    @Input()\n    headerFooterItems?: { [key: string]: (gcComment: GC.InputMan.GcComment) => GC.InputMan.IHeaderFooterItem };\n    @Input()\n    commentAction?: (string | GC.InputMan.GcCommentCommentActionItem)[];\n    @Input()\n    commentInfoAction?: (string | GC.InputMan.GcCommentCommentInfoActionItem)[];\n    @Input()\n    commentActionItem?: { [key: string]: GC.InputMan.ICommentActionItem };\n    @Input()\n    commentInfoActionItem?: { [key: string]: GC.InputMan.ICommentInfoActionItem };\n    @Input()\n    commentActionButtonType?: GC.InputMan.GcCommentActionButtonType;\n    @Input()\n    pageSize?: number;\n    @Input()\n    loadOnDemand?: boolean;\n    @Input()\n    allowAnonymous?: boolean;\n    @Input()\n    anonymousUserInfo?: GC.InputMan.UserInfo;\n    @Input()\n    warningMessage?: GC.InputMan.IWarningMessage;\n    @Input()\n    watermark?: GC.InputMan.IWaterMark;\n    @Input()\n    commentFormatter?: GC.InputMan.CommentFormatter;\n    @Input()\n    editorConfig?: GC.InputMan.EditorConfig;\n    @Input()\n    avatarType?: GC.InputMan.GcCommentUserIconType;\n    @Input()\n    loadUsersInfoHandler?: GC.InputMan.LoadUsersCallback;\n    @Input()\n    loadComments?: (args: GC.InputMan.LoadMoreCommentsInfo) => GC.InputMan.LoadCommentsResult;\n    @Input()\n    addNewCommentTo?: GC.InputMan.AddNewCommentPosition;\n    @Input()\n    keepDraft?: boolean;\n    @Input()\n    dataSource?: GC.InputMan.IGcCommentDataSource;\n    @Input()\n    loadCommentCount?: () => number | Promise<number>;\n    @Input()\n    commentCountFormatter?: (n: number) => string | HTMLElement;\n    @Input()\n    loadReactionCount?: () => number | Promise<number>;\n    @Input()\n    reactionCountFormatter?: (n: number) => string | HTMLElement;\n    @Input()\n    sortInfo?: GC.InputMan.GcCommentSortInfo;\n    @Input()\n    createEditor?: (args: GC.InputMan.CreateEditorArgs) => GC.InputMan.ICommentEditor;\n    @Input()\n    loadRepliesOnDemand?: boolean;\n    @Input()\n    replyLevel?: number;\n    @Input()\n    collapseRepliesMode?: GC.InputMan.GcCommentCollapseRepliesMode;\n    @Input()\n    showCurrentUserName?: boolean;\n    @Input()\n    contextToolbar?: (string | GC.InputMan.GcCommentContextToolbar | GC.InputMan.ContextToolbarOption)[];\n    @Input()\n    contextToolbarItem?: { [key: string]: GC.InputMan.ICommentContextToolbarItem };\n    @Input()\n    loadCommentReplies?: (comment: GC.InputMan.IComment, loadedCount: number) => GC.InputMan.LoadCommentsResult;\n    @Input()\n    comments?: GC.InputMan.IComment[];\n    @Input()\n    stickedComment?: GC.InputMan.IComment;\n    @Input()\n    copiedLinkDisplayTextFormatter?: (comment: GC.InputMan.IComment) => GC.InputMan.ICopiedLinkDisplayTextConfig;\n    @Input()\n    copiedLinkFormatter?: (comment: GC.InputMan.IComment) => string;\n    @Input()\n    copiedLinkSearchParams?: (GC.InputMan.GcCommentLinkSearchParams | GC.InputMan.CustomLinkSearchParam)[];\n    @Input()\n    pastedLinkType?: GC.InputMan.GcCommentPasteLinkType;\n    @Input()\n    showLinkTypeContextToolbar?: boolean;\n    @Input()\n    loadCommentByLink?: (link: string) => Promise<GC.InputMan.LoadCommentByLinkResult>;\n    @Input()\n    openLinkMode?: GC.InputMan.OpenLinkMode;\n    @Input()\n    loadStickedComment?: () => GC.InputMan.IComment | null;\n    @Input()\n    showZeroReaction?: boolean;\n    @Input()\n    showOpenReactionListButton?: boolean;\n    @Input()\n    readOnly?: boolean;\n    @Input()\n    enabled?: boolean;\n    @Input()\n    height?: number | string; \n    @Input()\n    width?: number | string;\n    @Input()\n    maxHeight?: number | string; \n    @Input()\n    maxWidth?: number | string;\n    @Input()\n    minHeight?: number | string;\n    @Input()\n    minWidth?: number | string;\n    @Input()\n    banner?: string;\n\n    @Output()\n    public editorCreated: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public preprocessError: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public beforeExecuteCommand: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public afterExecuteCommand: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public beforeFirstLoad: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public afterFirstLoad: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public onInitialized: EventEmitter<object> = new EventEmitter();\n}\n"]}