barsa-sap-ui 1.0.454 → 1.0.456
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/barsa-answer-card/barsa-answer-card.component.mjs +41 -0
- package/esm2020/lib/barsa-chip/barsa-chip.component.mjs +72 -0
- package/esm2020/lib/barsa-group-cartable/barsa-cartable-group.component.mjs +4 -7
- package/esm2020/lib/barsa-question-answer-comments-section/barsa-question-answer-comments-section.component.mjs +17 -0
- package/esm2020/lib/barsa-question-answer-content-actions-section/barsa-question-answer-content-actions-section.component.mjs +31 -0
- package/esm2020/lib/barsa-question-answer-creator-time-section/barsa-question-answer-creator-time-section.component.mjs +14 -0
- package/esm2020/lib/barsa-question-answer-form/barsa-question-answer-form.component.mjs +35 -0
- package/esm2020/lib/barsa-question-answer-form-add-comment/barsa-question-answer-form-add-comment.component.mjs +47 -0
- package/esm2020/lib/barsa-question-answer-vote-section/barsa-question-answer-vote-section.component.mjs +78 -0
- package/esm2020/lib/barsa-question-post/barsa-question-post.component.mjs +30 -0
- package/esm2020/lib/barsa-report-card-flex-view/barsa-report-card-flex-view.component.mjs +31 -0
- package/esm2020/lib/barsa-sap-ui.module.mjs +36 -23
- package/esm2020/lib/barsa-tag-categories/barsa-tag-categories.component.mjs +60 -0
- package/esm2020/lib/barsa-tag-chip/barsa-tag-chip.component.mjs +26 -0
- package/esm2020/lib/barsa-tags-category-row/barsa-tags-category-row.component.mjs +23 -0
- package/esm2020/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +4 -2
- package/esm2020/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +3 -3
- package/esm2020/lib/index.mjs +29 -1
- package/esm2020/lib/report-view-renderer.directive.mjs +2 -1
- package/esm2020/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +35 -14
- package/esm2020/lib/ui-report-container/ui-report-container.component.mjs +3 -3
- package/esm2020/public-api.mjs +14 -1
- package/fesm2015/barsa-sap-ui.mjs +495 -26
- package/fesm2015/barsa-sap-ui.mjs.map +1 -1
- package/fesm2020/barsa-sap-ui.mjs +493 -26
- package/fesm2020/barsa-sap-ui.mjs.map +1 -1
- package/lib/barsa-answer-card/barsa-answer-card.component.d.ts +12 -0
- package/lib/barsa-chip/barsa-chip.component.d.ts +20 -0
- package/lib/barsa-group-cartable/barsa-cartable-group.component.d.ts +2 -6
- package/lib/barsa-question-answer-comments-section/barsa-question-answer-comments-section.component.d.ts +7 -0
- package/lib/barsa-question-answer-content-actions-section/barsa-question-answer-content-actions-section.component.d.ts +13 -0
- package/lib/barsa-question-answer-creator-time-section/barsa-question-answer-creator-time-section.component.d.ts +7 -0
- package/lib/barsa-question-answer-form/barsa-question-answer-form.component.d.ts +10 -0
- package/lib/barsa-question-answer-form-add-comment/barsa-question-answer-form-add-comment.component.d.ts +13 -0
- package/lib/barsa-question-answer-vote-section/barsa-question-answer-vote-section.component.d.ts +14 -0
- package/lib/barsa-question-post/barsa-question-post.component.d.ts +10 -0
- package/lib/barsa-report-card-flex-view/barsa-report-card-flex-view.component.d.ts +9 -0
- package/lib/barsa-sap-ui.module.d.ts +46 -33
- package/lib/barsa-tag-categories/barsa-tag-categories.component.d.ts +11 -0
- package/lib/barsa-tag-chip/barsa-tag-chip.component.d.ts +10 -0
- package/lib/barsa-tags-category-row/barsa-tags-category-row.component.d.ts +9 -0
- package/lib/index.d.ts +5 -1
- package/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.d.ts +4 -3
- package/package.json +1 -1
- package/public-api.d.ts +13 -0
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { BaseViewItemPropsComponent, UploadService } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "../barsa-question-answer-content-actions-section/barsa-question-answer-content-actions-section.component";
|
|
6
|
+
import * as i3 from "../barsa-question-answer-vote-section/barsa-question-answer-vote-section.component";
|
|
7
|
+
import * as i4 from "../barsa-question-answer-creator-time-section/barsa-question-answer-creator-time-section.component";
|
|
8
|
+
import * as i5 from "../barsa-question-answer-comments-section/barsa-question-answer-comments-section.component";
|
|
9
|
+
export class BarsaAnswerCardComponent extends BaseViewItemPropsComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
this.toolbar = toolbar;
|
|
13
|
+
this.onvolumechange = onvolumechange;
|
|
14
|
+
}
|
|
15
|
+
ngOnChanges(changes) {
|
|
16
|
+
super.ngOnChanges(changes);
|
|
17
|
+
const { mo } = changes;
|
|
18
|
+
if (mo && !mo.firstChange) {
|
|
19
|
+
this.mo = mo.currentValue;
|
|
20
|
+
this._cdr.detectChanges();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
onRowCheck() {
|
|
24
|
+
if (this.mo.$IsChecked) {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
this.events.emit({ title: 'rowCheck', data: { mo: this.mo, index: this.index } });
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
onVoteChange(_) {
|
|
31
|
+
// const vote = this._controlUiPipe.transform(isPositive ? 'ثبت رای مثبت' : 'ثبت رای منفی', this.layout94);
|
|
32
|
+
// vote && vote?.FieldUi.fireEvent('click',vote.FieldUi);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
BarsaAnswerCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaAnswerCardComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
36
|
+
BarsaAnswerCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaAnswerCardComponent, selector: "bsu-barsa-answer-card", providers: [UploadService], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\r\n class=\"flex flex-col p-4 border border-gray-200 bg-white rounded-md mb-8\"\r\n [ngClass]=\"{\r\n '!bg-green-50 border-t-2 border-t-green-500': mo.CorrectAnswer\r\n }\"\r\n>\r\n <p *ngIf=\"mo.CorrectAnswer\" class=\"w-full text-green-500 mb-6\">\u0628\u0647\u062A\u0631\u06CC\u0646 \u067E\u0627\u0633\u062E</p>\r\n <div class=\"flex grow gap-8\">\r\n <div class=\"grow-0 shrink-0 flex flex-col items-center gap-8\">\r\n <img src=\"https://picsum.photos/64/64\" class=\"size-12 rounded-full\" />\r\n <bsu-barsa-question-answer-vote-section\r\n [vote]=\"mo.Post.CurrentUserVote.Vote\"\r\n [voteUps]=\"mo.Post.VoteUps\"\r\n [voteDowns]=\"mo.Post.VoteDowns\"\r\n (voteChange)=\"onVoteChange($event)\"\r\n ></bsu-barsa-question-answer-vote-section>\r\n </div>\r\n <div class=\"flex flex-col grow shrink\">\r\n <bsu-barsa-question-answer-creator-time-section\r\n [post]=\"mo.Post\"\r\n ></bsu-barsa-question-answer-creator-time-section>\r\n <bsu-barsa-question-answer-content-actions-section\r\n [mo]=\"mo\"\r\n [buttons]=\"contextMenuItems\"\r\n (btnClick)=\"onRowCheck()\"\r\n ></bsu-barsa-question-answer-content-actions-section>\r\n </div>\r\n </div>\r\n <div class=\"flex grow gap-8\">\r\n <div class=\"grow-0 shrink-0 w-12\"></div>\r\n <div class=\"flex flex-col grow shrink\">\r\n <bsu-barsa-question-answer-comments-section [post]=\"mo.Post\"></bsu-barsa-question-answer-comments-section>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":root{--sapBackgroundColor: #fdfdfd}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.BarsaQuestionAnswerContentActionsSectionComponent, selector: "bsu-barsa-question-answer-content-actions-section", inputs: ["mo", "buttons"], outputs: ["btnClick"] }, { kind: "component", type: i3.BarsaQuestionAnswerVoteSectionComponent, selector: "bsu-barsa-question-answer-vote-section", inputs: ["vote", "voteDowns", "voteUps"], outputs: ["voteChange"] }, { kind: "component", type: i4.BarsaQuestionAnswerCreatorTimeSectionComponent, selector: "bsu-barsa-question-answer-creator-time-section", inputs: ["post"] }, { kind: "component", type: i5.BarsaQuestionAnswerCommentsSectionComponent, selector: "bsu-barsa-question-answer-comments-section", inputs: ["post"] }] });
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaAnswerCardComponent, decorators: [{
|
|
38
|
+
type: Component,
|
|
39
|
+
args: [{ selector: 'bsu-barsa-answer-card', providers: [UploadService], template: "<div\r\n class=\"flex flex-col p-4 border border-gray-200 bg-white rounded-md mb-8\"\r\n [ngClass]=\"{\r\n '!bg-green-50 border-t-2 border-t-green-500': mo.CorrectAnswer\r\n }\"\r\n>\r\n <p *ngIf=\"mo.CorrectAnswer\" class=\"w-full text-green-500 mb-6\">\u0628\u0647\u062A\u0631\u06CC\u0646 \u067E\u0627\u0633\u062E</p>\r\n <div class=\"flex grow gap-8\">\r\n <div class=\"grow-0 shrink-0 flex flex-col items-center gap-8\">\r\n <img src=\"https://picsum.photos/64/64\" class=\"size-12 rounded-full\" />\r\n <bsu-barsa-question-answer-vote-section\r\n [vote]=\"mo.Post.CurrentUserVote.Vote\"\r\n [voteUps]=\"mo.Post.VoteUps\"\r\n [voteDowns]=\"mo.Post.VoteDowns\"\r\n (voteChange)=\"onVoteChange($event)\"\r\n ></bsu-barsa-question-answer-vote-section>\r\n </div>\r\n <div class=\"flex flex-col grow shrink\">\r\n <bsu-barsa-question-answer-creator-time-section\r\n [post]=\"mo.Post\"\r\n ></bsu-barsa-question-answer-creator-time-section>\r\n <bsu-barsa-question-answer-content-actions-section\r\n [mo]=\"mo\"\r\n [buttons]=\"contextMenuItems\"\r\n (btnClick)=\"onRowCheck()\"\r\n ></bsu-barsa-question-answer-content-actions-section>\r\n </div>\r\n </div>\r\n <div class=\"flex grow gap-8\">\r\n <div class=\"grow-0 shrink-0 w-12\"></div>\r\n <div class=\"flex flex-col grow shrink\">\r\n <bsu-barsa-question-answer-comments-section [post]=\"mo.Post\"></bsu-barsa-question-answer-comments-section>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":root{--sapBackgroundColor: #fdfdfd}\n"] }]
|
|
40
|
+
}] });
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtYW5zd2VyLWNhcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtYW5zd2VyLWNhcmQvYmFyc2EtYW5zd2VyLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtYW5zd2VyLWNhcmQvYmFyc2EtYW5zd2VyLWNhcmQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLDBCQUEwQixFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7Ozs7O0FBUWpGLE1BQU0sT0FBTyx3QkFBeUIsU0FBUSwwQkFBMEI7SUFOeEU7O1FBMEJ1QixZQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ2xCLG1CQUFjLEdBQUcsY0FBYyxDQUFDO0tBQ3REO0lBckJHLFdBQVcsQ0FBQyxPQUFzQjtRQUM5QixLQUFLLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzNCLE1BQU0sRUFBRSxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFDdkIsSUFBSSxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLFlBQVksQ0FBQztZQUMxQixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1NBQzdCO0lBQ0wsQ0FBQztJQUNELFVBQVU7UUFDTixJQUFJLElBQUksQ0FBQyxFQUFFLENBQUMsVUFBVSxFQUFFO1lBQ3BCLE9BQU8sS0FBSyxDQUFDO1NBQ2hCO1FBQ0QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2xGLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFDRCxZQUFZLENBQUMsQ0FBVTtRQUNuQiwyR0FBMkc7UUFDM0cseURBQXlEO0lBQzdELENBQUM7O3FIQW5CUSx3QkFBd0I7eUdBQXhCLHdCQUF3QixnREFGdEIsQ0FBQyxhQUFhLENBQUMsc0VDUDlCLDZyREFtQ0E7MkZEMUJhLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDSSx1QkFBdUIsYUFHdEIsQ0FBQyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQmFzZVZpZXdJdGVtUHJvcHNDb21wb25lbnQsIFVwbG9hZFNlcnZpY2UgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYnN1LWJhcnNhLWFuc3dlci1jYXJkJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYXJzYS1hbnN3ZXItY2FyZC5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9iYXJzYS1hbnN3ZXItY2FyZC5jb21wb25lbnQuY3NzJ10sXHJcbiAgICBwcm92aWRlcnM6IFtVcGxvYWRTZXJ2aWNlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQmFyc2FBbnN3ZXJDYXJkQ29tcG9uZW50IGV4dGVuZHMgQmFzZVZpZXdJdGVtUHJvcHNDb21wb25lbnQge1xyXG4gICAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25DaGFuZ2VzKGNoYW5nZXMpO1xyXG4gICAgICAgIGNvbnN0IHsgbW8gfSA9IGNoYW5nZXM7XHJcbiAgICAgICAgaWYgKG1vICYmICFtby5maXJzdENoYW5nZSkge1xyXG4gICAgICAgICAgICB0aGlzLm1vID0gbW8uY3VycmVudFZhbHVlO1xyXG4gICAgICAgICAgICB0aGlzLl9jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIG9uUm93Q2hlY2soKTogYm9vbGVhbiB7XHJcbiAgICAgICAgaWYgKHRoaXMubW8uJElzQ2hlY2tlZCkge1xyXG4gICAgICAgICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHRoaXMuZXZlbnRzLmVtaXQoeyB0aXRsZTogJ3Jvd0NoZWNrJywgZGF0YTogeyBtbzogdGhpcy5tbywgaW5kZXg6IHRoaXMuaW5kZXggfSB9KTtcclxuICAgICAgICByZXR1cm4gdHJ1ZTtcclxuICAgIH1cclxuICAgIG9uVm90ZUNoYW5nZShfOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICAgICAgLy8gY29uc3Qgdm90ZSA9IHRoaXMuX2NvbnRyb2xVaVBpcGUudHJhbnNmb3JtKGlzUG9zaXRpdmUgPyAn2KvYqNiqINix2KfbjCDZhdir2KjYqicgOiAn2KvYqNiqINix2KfbjCDZhdmG2YHbjCcsIHRoaXMubGF5b3V0OTQpO1xyXG4gICAgICAgIC8vIHZvdGUgJiYgdm90ZT8uRmllbGRVaS5maXJlRXZlbnQoJ2NsaWNrJyx2b3RlLkZpZWxkVWkpO1xyXG4gICAgfVxyXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHRvb2xiYXIgPSB0b29sYmFyO1xyXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IG9udm9sdW1lY2hhbmdlID0gb252b2x1bWVjaGFuZ2U7XHJcbn1cclxuIiwiPGRpdlxyXG4gICAgY2xhc3M9XCJmbGV4IGZsZXgtY29sIHAtNCBib3JkZXIgYm9yZGVyLWdyYXktMjAwIGJnLXdoaXRlIHJvdW5kZWQtbWQgbWItOFwiXHJcbiAgICBbbmdDbGFzc109XCJ7XHJcbiAgICAgICAgJyFiZy1ncmVlbi01MCBib3JkZXItdC0yIGJvcmRlci10LWdyZWVuLTUwMCc6IG1vLkNvcnJlY3RBbnN3ZXJcclxuICAgIH1cIlxyXG4+XHJcbiAgICA8cCAqbmdJZj1cIm1vLkNvcnJlY3RBbnN3ZXJcIiBjbGFzcz1cInctZnVsbCB0ZXh0LWdyZWVuLTUwMCBtYi02XCI+2KjZh9iq2LHbjNmGINm+2KfYs9iuPC9wPlxyXG4gICAgPGRpdiBjbGFzcz1cImZsZXggZ3JvdyBnYXAtOFwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJncm93LTAgc2hyaW5rLTAgZmxleCBmbGV4LWNvbCBpdGVtcy1jZW50ZXIgZ2FwLThcIj5cclxuICAgICAgICAgICAgPGltZyBzcmM9XCJodHRwczovL3BpY3N1bS5waG90b3MvNjQvNjRcIiBjbGFzcz1cInNpemUtMTIgcm91bmRlZC1mdWxsXCIgLz5cclxuICAgICAgICAgICAgPGJzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItdm90ZS1zZWN0aW9uXHJcbiAgICAgICAgICAgICAgICBbdm90ZV09XCJtby5Qb3N0LkN1cnJlbnRVc2VyVm90ZS5Wb3RlXCJcclxuICAgICAgICAgICAgICAgIFt2b3RlVXBzXT1cIm1vLlBvc3QuVm90ZVVwc1wiXHJcbiAgICAgICAgICAgICAgICBbdm90ZURvd25zXT1cIm1vLlBvc3QuVm90ZURvd25zXCJcclxuICAgICAgICAgICAgICAgICh2b3RlQ2hhbmdlKT1cIm9uVm90ZUNoYW5nZSgkZXZlbnQpXCJcclxuICAgICAgICAgICAgPjwvYnN1LWJhcnNhLXF1ZXN0aW9uLWFuc3dlci12b3RlLXNlY3Rpb24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1jb2wgZ3JvdyBzaHJpbmtcIj5cclxuICAgICAgICAgICAgPGJzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY3JlYXRvci10aW1lLXNlY3Rpb25cclxuICAgICAgICAgICAgICAgIFtwb3N0XT1cIm1vLlBvc3RcIlxyXG4gICAgICAgICAgICA+PC9ic3UtYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNyZWF0b3ItdGltZS1zZWN0aW9uPlxyXG4gICAgICAgICAgICA8YnN1LWJhcnNhLXF1ZXN0aW9uLWFuc3dlci1jb250ZW50LWFjdGlvbnMtc2VjdGlvblxyXG4gICAgICAgICAgICAgICAgW21vXT1cIm1vXCJcclxuICAgICAgICAgICAgICAgIFtidXR0b25zXT1cImNvbnRleHRNZW51SXRlbXNcIlxyXG4gICAgICAgICAgICAgICAgKGJ0bkNsaWNrKT1cIm9uUm93Q2hlY2soKVwiXHJcbiAgICAgICAgICAgID48L2JzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY29udGVudC1hY3Rpb25zLXNlY3Rpb24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJmbGV4IGdyb3cgZ2FwLThcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZ3Jvdy0wIHNocmluay0wIHctMTJcIj48L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZmxleCBmbGV4LWNvbCBncm93IHNocmlua1wiPlxyXG4gICAgICAgICAgICA8YnN1LWJhcnNhLXF1ZXN0aW9uLWFuc3dlci1jb21tZW50cy1zZWN0aW9uIFtwb3N0XT1cIm1vLlBvc3RcIj48L2JzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY29tbWVudHMtc2VjdGlvbj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostBinding, HostListener, inject, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class BarsaChipComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.title = '';
|
|
7
|
+
this.moreInfo = '';
|
|
8
|
+
this.checkedChange = new EventEmitter();
|
|
9
|
+
this._cdr = inject(ChangeDetectorRef);
|
|
10
|
+
this._isChecked = false;
|
|
11
|
+
}
|
|
12
|
+
set isChecked(value) {
|
|
13
|
+
this._isChecked = value;
|
|
14
|
+
}
|
|
15
|
+
get getClass() {
|
|
16
|
+
return 'block rounded-md whitespace-nowrap w-fit max-w-full truncate border border-transparent bg-blue-50 py-0.5 px-1.5 text-blue-800 transition-all';
|
|
17
|
+
}
|
|
18
|
+
get cursorPointer() {
|
|
19
|
+
return this.canCheck;
|
|
20
|
+
}
|
|
21
|
+
get hoverTextColor() {
|
|
22
|
+
return this.canCheck;
|
|
23
|
+
}
|
|
24
|
+
get border() {
|
|
25
|
+
return this.canCheck && this._isChecked;
|
|
26
|
+
}
|
|
27
|
+
get bgSelectedHover() {
|
|
28
|
+
return this.canCheck && this._isChecked;
|
|
29
|
+
}
|
|
30
|
+
onRowClick() {
|
|
31
|
+
this.checkedChange.emit(this.isChecked);
|
|
32
|
+
}
|
|
33
|
+
ngOnChanges(changes) {
|
|
34
|
+
this._isChecked = !!changes.isChecked?.currentValue;
|
|
35
|
+
this._cdr.detectChanges();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
BarsaChipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaChipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
39
|
+
BarsaChipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaChipComponent, selector: "bsu-barsa-chip", inputs: { title: "title", moreInfo: "moreInfo", canCheck: "canCheck", isChecked: "isChecked" }, outputs: { checkedChange: "checkedChange" }, host: { listeners: { "click": "onRowClick()" }, properties: { "class": "this.getClass", "class.cursor-pointer": "this.cursorPointer", "class.hover:text-blue-700": "this.hoverTextColor", "class.!border-blue-800": "this.border", "class.!bg-blue-100": "this.bgSelectedHover" } }, usesOnChanges: true, ngImport: i0, template: "{{ title }}\r\n<ng-container *ngIf=\"moreInfo\"> ({{ moreInfo }}) </ng-container>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaChipComponent, decorators: [{
|
|
41
|
+
type: Component,
|
|
42
|
+
args: [{ selector: 'bsu-barsa-chip', changeDetection: ChangeDetectionStrategy.OnPush, template: "{{ title }}\r\n<ng-container *ngIf=\"moreInfo\"> ({{ moreInfo }}) </ng-container>\r\n" }]
|
|
43
|
+
}], propDecorators: { title: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}], moreInfo: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], canCheck: [{
|
|
48
|
+
type: Input
|
|
49
|
+
}], checkedChange: [{
|
|
50
|
+
type: Output
|
|
51
|
+
}], isChecked: [{
|
|
52
|
+
type: Input
|
|
53
|
+
}], getClass: [{
|
|
54
|
+
type: HostBinding,
|
|
55
|
+
args: ['class']
|
|
56
|
+
}], cursorPointer: [{
|
|
57
|
+
type: HostBinding,
|
|
58
|
+
args: ['class.cursor-pointer']
|
|
59
|
+
}], hoverTextColor: [{
|
|
60
|
+
type: HostBinding,
|
|
61
|
+
args: ['class.hover:text-blue-700']
|
|
62
|
+
}], border: [{
|
|
63
|
+
type: HostBinding,
|
|
64
|
+
args: ['class.!border-blue-800']
|
|
65
|
+
}], bgSelectedHover: [{
|
|
66
|
+
type: HostBinding,
|
|
67
|
+
args: ['class.!bg-blue-100']
|
|
68
|
+
}], onRowClick: [{
|
|
69
|
+
type: HostListener,
|
|
70
|
+
args: ['click']
|
|
71
|
+
}] } });
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtY2hpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi9iYXJzYS1jaGlwL2JhcnNhLWNoaXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtY2hpcC9iYXJzYS1jaGlwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxZQUFZLEVBQ1osV0FBVyxFQUNYLFlBQVksRUFDWixNQUFNLEVBQ04sS0FBSyxFQUVMLE1BQU0sRUFDVCxNQUFNLGVBQWUsQ0FBQzs7O0FBUXZCLE1BQU0sT0FBTyxrQkFBa0I7SUFOL0I7UUFPYSxVQUFLLEdBQUcsRUFBRSxDQUFDO1FBQ1gsYUFBUSxHQUFHLEVBQUUsQ0FBQztRQUViLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUkxQyxTQUFJLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDakMsZUFBVSxHQUFHLEtBQUssQ0FBQztLQXVCOUI7SUEzQkcsSUFBYSxTQUFTLENBQUMsS0FBYztRQUNqQyxJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztJQUM1QixDQUFDO0lBR0QsSUFBMEIsUUFBUTtRQUM5QixPQUFPLDhJQUE4SSxDQUFDO0lBQzFKLENBQUM7SUFDRCxJQUF5QyxhQUFhO1FBQ2xELE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBQ0QsSUFBOEMsY0FBYztRQUN4RCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDekIsQ0FBQztJQUNELElBQTJDLE1BQU07UUFDN0MsT0FBTyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDNUMsQ0FBQztJQUNELElBQXVDLGVBQWU7UUFDbEQsT0FBTyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDNUMsQ0FBQztJQUNzQixVQUFVO1FBQzdCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBQ0QsV0FBVyxDQUFDLE9BQU87UUFDZixJQUFJLENBQUMsVUFBVSxHQUFHLENBQUMsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLFlBQVksQ0FBQztRQUNwRCxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzlCLENBQUM7OytHQS9CUSxrQkFBa0I7bUdBQWxCLGtCQUFrQiw2ZUNuQi9CLHVGQUVBOzJGRGlCYSxrQkFBa0I7a0JBTjlCLFNBQVM7K0JBQ0ksZ0JBQWdCLG1CQUdULHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0ksYUFBYTtzQkFBdEIsTUFBTTtnQkFDTSxTQUFTO3NCQUFyQixLQUFLO2dCQUtvQixRQUFRO3NCQUFqQyxXQUFXO3VCQUFDLE9BQU87Z0JBR3FCLGFBQWE7c0JBQXJELFdBQVc7dUJBQUMsc0JBQXNCO2dCQUdXLGNBQWM7c0JBQTNELFdBQVc7dUJBQUMsMkJBQTJCO2dCQUdHLE1BQU07c0JBQWhELFdBQVc7dUJBQUMsd0JBQXdCO2dCQUdFLGVBQWU7c0JBQXJELFdBQVc7dUJBQUMsb0JBQW9CO2dCQUdWLFVBQVU7c0JBQWhDLFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICAgIENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgQ29tcG9uZW50LFxyXG4gICAgRXZlbnRFbWl0dGVyLFxyXG4gICAgSG9zdEJpbmRpbmcsXHJcbiAgICBIb3N0TGlzdGVuZXIsXHJcbiAgICBpbmplY3QsXHJcbiAgICBJbnB1dCxcclxuICAgIE9uQ2hhbmdlcyxcclxuICAgIE91dHB1dFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JzdS1iYXJzYS1jaGlwJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYXJzYS1jaGlwLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2JhcnNhLWNoaXAuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCYXJzYUNoaXBDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xyXG4gICAgQElucHV0KCkgdGl0bGUgPSAnJztcclxuICAgIEBJbnB1dCgpIG1vcmVJbmZvID0gJyc7XHJcbiAgICBASW5wdXQoKSBjYW5DaGVjazogYm9vbGVhbjtcclxuICAgIEBPdXRwdXQoKSBjaGVja2VkQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICBASW5wdXQoKSBzZXQgaXNDaGVja2VkKHZhbHVlOiBib29sZWFuKSB7XHJcbiAgICAgICAgdGhpcy5faXNDaGVja2VkID0gdmFsdWU7XHJcbiAgICB9XHJcbiAgICBwcml2YXRlIF9jZHIgPSBpbmplY3QoQ2hhbmdlRGV0ZWN0b3JSZWYpO1xyXG4gICAgcHJpdmF0ZSBfaXNDaGVja2VkID0gZmFsc2U7XHJcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJykgZ2V0IGdldENsYXNzKCk6IHN0cmluZyB7XHJcbiAgICAgICAgcmV0dXJuICdibG9jayByb3VuZGVkLW1kIHdoaXRlc3BhY2Utbm93cmFwIHctZml0IG1heC13LWZ1bGwgdHJ1bmNhdGUgYm9yZGVyIGJvcmRlci10cmFuc3BhcmVudCBiZy1ibHVlLTUwIHB5LTAuNSBweC0xLjUgdGV4dC1ibHVlLTgwMCB0cmFuc2l0aW9uLWFsbCc7XHJcbiAgICB9XHJcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLmN1cnNvci1wb2ludGVyJykgZ2V0IGN1cnNvclBvaW50ZXIoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FuQ2hlY2s7XHJcbiAgICB9XHJcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLmhvdmVyOnRleHQtYmx1ZS03MDAnKSBnZXQgaG92ZXJUZXh0Q29sb3IoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FuQ2hlY2s7XHJcbiAgICB9XHJcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLiFib3JkZXItYmx1ZS04MDAnKSBnZXQgYm9yZGVyKCk6IGJvb2xlYW4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmNhbkNoZWNrICYmIHRoaXMuX2lzQ2hlY2tlZDtcclxuICAgIH1cclxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuIWJnLWJsdWUtMTAwJykgZ2V0IGJnU2VsZWN0ZWRIb3ZlcigpOiBib29sZWFuIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5jYW5DaGVjayAmJiB0aGlzLl9pc0NoZWNrZWQ7XHJcbiAgICB9XHJcbiAgICBASG9zdExpc3RlbmVyKCdjbGljaycpIG9uUm93Q2xpY2soKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5jaGVja2VkQ2hhbmdlLmVtaXQodGhpcy5pc0NoZWNrZWQpO1xyXG4gICAgfVxyXG4gICAgbmdPbkNoYW5nZXMoY2hhbmdlcyk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuX2lzQ2hlY2tlZCA9ICEhY2hhbmdlcy5pc0NoZWNrZWQ/LmN1cnJlbnRWYWx1ZTtcclxuICAgICAgICB0aGlzLl9jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gICAgfVxyXG59XHJcbiIsInt7IHRpdGxlIH19XHJcbjxuZy1jb250YWluZXIgKm5nSWY9XCJtb3JlSW5mb1wiPiAoe3sgbW9yZUluZm8gfX0pIDwvbmctY29udGFpbmVyPlxyXG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
2
|
import { BaseViewItemPropsComponent } from 'barsa-novin-ray-core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
@@ -7,7 +7,6 @@ import * as i3 from "barsa-novin-ray-core";
|
|
|
7
7
|
export class BarsaCartableGroupComponent extends BaseViewItemPropsComponent {
|
|
8
8
|
constructor() {
|
|
9
9
|
super(...arguments);
|
|
10
|
-
this.events = new EventEmitter();
|
|
11
10
|
this.isLastBuiltin = false;
|
|
12
11
|
}
|
|
13
12
|
ngOnInit() {
|
|
@@ -87,11 +86,9 @@ export class BarsaCartableGroupComponent extends BaseViewItemPropsComponent {
|
|
|
87
86
|
}
|
|
88
87
|
}
|
|
89
88
|
BarsaCartableGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaCartableGroupComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
-
BarsaCartableGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaCartableGroupComponent, selector: "bsu-barsa-cartable-group",
|
|
89
|
+
BarsaCartableGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaCartableGroupComponent, selector: "bsu-barsa-cartable-group", usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- <li\n [interactive]=\"true\"\n fd-list-item\n [selected]=\"allItemChecked ? true : false\"\n (click)=\"onRowCheckAll()\"\n *ngIf=\"allItem\"\n>\n <div class=\"title-container\">\n <div style=\"background-color: transparent; width: 0.2rem; height: 100%\"></div>\n <span fd-list-title>\n <div style=\"height: 100%; display: flex; align-items: center\">\n <span [style.fontSize]=\"allItem.unreadCount > 0 ? 'bold' : null\">{{ '\u0647\u0645\u0647 \u0645\u0648\u0627\u0631\u062F' | bbbTranslate }}</span>\n <ng-container *ngIf=\"allItem.unreadCount > 0\">\n <strong style=\"padding: 0 2px; direction: ltr\">({{ allItem.unreadCount }})</strong>\n </ng-container>\n <span style=\"padding: 0 5px\" *ngIf=\"allItem.allCount > 0\">{{ allItem.allCount }}</span>\n </div>\n </span>\n </div>\n</li> -->\n\n<ng-container>\n <ng-container *ngIf=\"allItem\">\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate;\n context: {\n $implicit: '\u0647\u0645\u0647 \u0645\u0648\u0627\u0631\u062F' | bbbTranslate,\n unreadCount: allItem.unreadCount,\n allCount: allItem.allCount,\n backColor: 'transparent',\n isAll: true,\n isChecked: allItemChecked\n }\n \"\n ></ng-container>\n </ng-container>\n\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate;\n context: {\n $implicit: parameters.CartableGroupField | rval: mo:allColumns:true,\n unreadCount: parameters.UnreadCountField | rval: mo:allColumns,\n allCount: parameters.AllCountField | rval: mo:allColumns,\n backColor: (columns[0].Caption | rval: mo:columns),\n isChecked: isChecked,\n icon: parameters.IconField | rval: mo:allColumns:true,\n isBuiltin: isBuiltin\n }\n \"\n ></ng-container>\n</ng-container>\n<ng-container *ngIf=\"isLastBuiltin\">\n <li fd-list-item class=\"space\">\n <span fd-list-title></span>\n </li>\n</ng-container>\n<!-- <ng-container *ngIf=\"last\">\n <ul fd-list>\n <li fd-list-group-header>\n <span fd-list-title style=\"background:#f7f7f7\"></span>\n </li>\n <ng-container *ngFor=\"let mo2 of moDataList\">\n <ng-container *ngIf=\"'\u0633\u06CC\u0633\u062A\u0645\u06CC' | rval: mo2:allColumns\">\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate;\n context: {\n $implicit: parameters.CartableGroupField | rval: mo2:allColumns:true,\n unreadCount: parameters.UnreadCountField | rval: mo2:allColumns,\n allCount: parameters.AllCountField | rval: mo2:allColumns,\n backColor: columns[0].Caption | rval: mo2:columns,\n isChecked: isChecked\n }\n \"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ul>\n</ng-container> -->\n\n<!-- <li fd-list-item [selected]=\"isChecked ? true : false\" (click)=\"onRowCheck()\" [interactive]=\"true\">\n <div class=\"title-container\">\n <div [style.backgroundColor]=\"columns[0].Caption | rval: mo:columns\" style=\"width: 0.2rem; height: 100%\"></div>\n <span fd-list-title>\n <div style=\"height: 100%; display: flex; align-items: center\">\n <span [style.fontSize]=\"parameters.UnreadCountField | rval: mo:allColumns:(true ? 'bold' : null)\"\n >{{ parameters.CartableGroupField | rval: mo:allColumns:true }}\n </span>\n <ng-container *ngIf=\"parameters.UnreadCountField | rval: mo:allColumns:true\">\n <strong style=\"padding: 0 2px; direction: ltr\"\n >({{ parameters.UnreadCountField | rval: mo:allColumns:true }})</strong\n >\n </ng-container>\n <span style=\"padding: 0 5px\">{{ parameters.AllCountField | rval: mo:allColumns:true }}</span>\n </div>\n </span>\n </div>\n</li> -->\n<ng-template\n #itemTemplate\n let-caption\n let-unreadCount=\"unreadCount\"\n let-allCount=\"allCount\"\n let-backColor=\"backColor\"\n let-isAll=\"isAll\"\n let-isChecked=\"isChecked\"\n let-icon=\"icon\"\n let-isBuiltin=\"isBuiltin\"\n>\n <li\n *ngIf=\"isBuiltin || allCount > 0 || isAll\"\n fd-list-item\n [selected]=\"isChecked ? true : false\"\n (click)=\"onClick(isAll)\"\n [interactive]=\"true\"\n >\n <div class=\"title-container\">\n <div [style.backgroundColor]=\"backColor\" style=\"width: 0.2rem; height: 100%\"></div>\n <i *ngIf=\"icon\" fd-list-icon [glyph]=\"icon\"></i>\n <span fd-list-title>\n <div style=\"height: 100%; display: flex; align-items: center; column-gap: 5px\">\n <ng-container *ngIf=\"unreadCount && unreadCount > 0; else spanTemplate\">\n <strong>{{ caption }}</strong>\n <strong style=\"padding: 0 2px; direction: ltr\">({{ unreadCount }})</strong>\n </ng-container>\n <ng-template #spanTemplate>\n <span>{{ caption }}</span>\n </ng-template>\n <span style=\"padding: 0 5px\" *ngIf=\"allCount && allCount > 0\">{{ allCount }}</span>\n </div>\n </span>\n </div>\n </li>\n</ng-template>\n", styles: [":host{display:contents;width:100%;height:100%;cursor:pointer}.title-container{align-items:center;display:flex;column-gap:5px;height:100%;width:100%}li{padding:0}.space{cursor:default;background-color:var(--sapBackgroundColor);pointer-events:none}.space:focus:before{border:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i2.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i2.ListIconDirective, selector: "[fdListIcon], [fd-list-icon]", inputs: ["glyph", "class", "role"] }, { kind: "pipe", type: i3.MoReportValuePipe, name: "rval" }, { kind: "pipe", type: i3.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
91
90
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaCartableGroupComponent, decorators: [{
|
|
92
91
|
type: Component,
|
|
93
92
|
args: [{ selector: 'bsu-barsa-cartable-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- <li\n [interactive]=\"true\"\n fd-list-item\n [selected]=\"allItemChecked ? true : false\"\n (click)=\"onRowCheckAll()\"\n *ngIf=\"allItem\"\n>\n <div class=\"title-container\">\n <div style=\"background-color: transparent; width: 0.2rem; height: 100%\"></div>\n <span fd-list-title>\n <div style=\"height: 100%; display: flex; align-items: center\">\n <span [style.fontSize]=\"allItem.unreadCount > 0 ? 'bold' : null\">{{ '\u0647\u0645\u0647 \u0645\u0648\u0627\u0631\u062F' | bbbTranslate }}</span>\n <ng-container *ngIf=\"allItem.unreadCount > 0\">\n <strong style=\"padding: 0 2px; direction: ltr\">({{ allItem.unreadCount }})</strong>\n </ng-container>\n <span style=\"padding: 0 5px\" *ngIf=\"allItem.allCount > 0\">{{ allItem.allCount }}</span>\n </div>\n </span>\n </div>\n</li> -->\n\n<ng-container>\n <ng-container *ngIf=\"allItem\">\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate;\n context: {\n $implicit: '\u0647\u0645\u0647 \u0645\u0648\u0627\u0631\u062F' | bbbTranslate,\n unreadCount: allItem.unreadCount,\n allCount: allItem.allCount,\n backColor: 'transparent',\n isAll: true,\n isChecked: allItemChecked\n }\n \"\n ></ng-container>\n </ng-container>\n\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate;\n context: {\n $implicit: parameters.CartableGroupField | rval: mo:allColumns:true,\n unreadCount: parameters.UnreadCountField | rval: mo:allColumns,\n allCount: parameters.AllCountField | rval: mo:allColumns,\n backColor: (columns[0].Caption | rval: mo:columns),\n isChecked: isChecked,\n icon: parameters.IconField | rval: mo:allColumns:true,\n isBuiltin: isBuiltin\n }\n \"\n ></ng-container>\n</ng-container>\n<ng-container *ngIf=\"isLastBuiltin\">\n <li fd-list-item class=\"space\">\n <span fd-list-title></span>\n </li>\n</ng-container>\n<!-- <ng-container *ngIf=\"last\">\n <ul fd-list>\n <li fd-list-group-header>\n <span fd-list-title style=\"background:#f7f7f7\"></span>\n </li>\n <ng-container *ngFor=\"let mo2 of moDataList\">\n <ng-container *ngIf=\"'\u0633\u06CC\u0633\u062A\u0645\u06CC' | rval: mo2:allColumns\">\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate;\n context: {\n $implicit: parameters.CartableGroupField | rval: mo2:allColumns:true,\n unreadCount: parameters.UnreadCountField | rval: mo2:allColumns,\n allCount: parameters.AllCountField | rval: mo2:allColumns,\n backColor: columns[0].Caption | rval: mo2:columns,\n isChecked: isChecked\n }\n \"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ul>\n</ng-container> -->\n\n<!-- <li fd-list-item [selected]=\"isChecked ? true : false\" (click)=\"onRowCheck()\" [interactive]=\"true\">\n <div class=\"title-container\">\n <div [style.backgroundColor]=\"columns[0].Caption | rval: mo:columns\" style=\"width: 0.2rem; height: 100%\"></div>\n <span fd-list-title>\n <div style=\"height: 100%; display: flex; align-items: center\">\n <span [style.fontSize]=\"parameters.UnreadCountField | rval: mo:allColumns:(true ? 'bold' : null)\"\n >{{ parameters.CartableGroupField | rval: mo:allColumns:true }}\n </span>\n <ng-container *ngIf=\"parameters.UnreadCountField | rval: mo:allColumns:true\">\n <strong style=\"padding: 0 2px; direction: ltr\"\n >({{ parameters.UnreadCountField | rval: mo:allColumns:true }})</strong\n >\n </ng-container>\n <span style=\"padding: 0 5px\">{{ parameters.AllCountField | rval: mo:allColumns:true }}</span>\n </div>\n </span>\n </div>\n</li> -->\n<ng-template\n #itemTemplate\n let-caption\n let-unreadCount=\"unreadCount\"\n let-allCount=\"allCount\"\n let-backColor=\"backColor\"\n let-isAll=\"isAll\"\n let-isChecked=\"isChecked\"\n let-icon=\"icon\"\n let-isBuiltin=\"isBuiltin\"\n>\n <li\n *ngIf=\"isBuiltin || allCount > 0 || isAll\"\n fd-list-item\n [selected]=\"isChecked ? true : false\"\n (click)=\"onClick(isAll)\"\n [interactive]=\"true\"\n >\n <div class=\"title-container\">\n <div [style.backgroundColor]=\"backColor\" style=\"width: 0.2rem; height: 100%\"></div>\n <i *ngIf=\"icon\" fd-list-icon [glyph]=\"icon\"></i>\n <span fd-list-title>\n <div style=\"height: 100%; display: flex; align-items: center; column-gap: 5px\">\n <ng-container *ngIf=\"unreadCount && unreadCount > 0; else spanTemplate\">\n <strong>{{ caption }}</strong>\n <strong style=\"padding: 0 2px; direction: ltr\">({{ unreadCount }})</strong>\n </ng-container>\n <ng-template #spanTemplate>\n <span>{{ caption }}</span>\n </ng-template>\n <span style=\"padding: 0 5px\" *ngIf=\"allCount && allCount > 0\">{{ allCount }}</span>\n </div>\n </span>\n </div>\n </li>\n</ng-template>\n", styles: [":host{display:contents;width:100%;height:100%;cursor:pointer}.title-container{align-items:center;display:flex;column-gap:5px;height:100%;width:100%}li{padding:0}.space{cursor:default;background-color:var(--sapBackgroundColor);pointer-events:none}.space:focus:before{border:none}\n"] }]
|
|
94
|
-
}]
|
|
95
|
-
type: Output
|
|
96
|
-
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-cartable-group.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-group-cartable/barsa-cartable-group.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-group-cartable/barsa-cartable-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { BaseViewItemPropsComponent, MetaobjectDataModel } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-barsa-cartable-group',\n    templateUrl: './barsa-cartable-group.component.html',\n    styleUrls: ['./barsa-cartable-group.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaCartableGroupComponent extends BaseViewItemPropsComponent implements OnInit {\n    @Output() events = new EventEmitter<{ title: string; data: any }>();\n    /**\n     *\n     */\n    allItem: { unreadCount: number; allCount: number };\n    allItemChecked: boolean;\n    builtinGroups: MetaobjectDataModel[];\n    isLastBuiltin = false;\n    isBuiltin: any;\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (this.index === 0) {\n            this._calcAll(this.moDataList);\n        }\n        this._checkSystemi();\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        let detectChanges = false;\n        const keys = ['mo', 'moDataList', 'isChecked'];\n\n        keys.forEach((key) => {\n            if (changes[key] && !changes[key].firstChange) {\n                this[key] = changes[key].currentValue;\n                detectChanges = true;\n                if (key === 'moDataList') {\n                    this._calcAll(changes[key].currentValue);\n                    this._checkSystemi();\n                }\n            }\n        });\n        if (detectChanges) {\n            this.detectChanges();\n        }\n    }\n    detectChanges(): void {\n        this._cdr.detectChanges();\n    }\n    _rowCheckAll(): void {\n        if (this.allItemChecked) {\n            return;\n        }\n        this.allItemChecked = true;\n        this.events.emit({ title: 'deselectAll', data: null });\n        this.events.emit({ title: 'rowCheck', data: { mo: { Id: '01' }, index: -1 } });\n    }\n    onClick(isAll: boolean): void {\n        if (isAll) {\n            this._rowCheckAll();\n        } else {\n            this._rowCheck();\n        }\n    }\n    _rowCheck(): void {\n        if (this.isChecked) {\n            return;\n        }\n        this.events.emit({ title: 'rowCheck', data: { mo: this.mo, index: this.index } });\n    }\n    private _checkSystemi(): void {\n        this.isBuiltin = this._reportValuePipe.transform('سیستمی', this.mo, this.allColumns);\n        if (this.index + 1 < this.moDataList.length && this.isBuiltin) {\n            this.isLastBuiltin = !this._reportValuePipe.transform(\n                'سیستمی',\n                this.moDataList[this.index + 1],\n                this.allColumns\n            );\n        }\n    }\n    private _calcAll(moDataList: MetaobjectDataModel[]): void {\n        if (this.index !== 0) {\n            return;\n        }\n        let allCount = 0;\n        let unreadCount = 0;\n        let isChecked = false;\n        moDataList.forEach((c) => {\n            if (c.$IsChecked) {\n                isChecked = true;\n            }\n            const allCountTemp = this._reportValuePipe.transform(this.parameters.AllCountField, c, this.allColumns);\n            allCount += isNaN(+allCountTemp) ? 0 : +allCountTemp;\n            const unreadCountTemp = this._reportValuePipe.transform(\n                this.parameters.UnreadCountField,\n                c,\n                this.allColumns\n            );\n            unreadCount += isNaN(+unreadCountTemp) ? 0 : +unreadCountTemp;\n        });\n        this.allItemChecked = !isChecked;\n        this.allItem = { allCount, unreadCount };\n    }\n}\n","<!-- <li\n    [interactive]=\"true\"\n    fd-list-item\n    [selected]=\"allItemChecked ? true : false\"\n    (click)=\"onRowCheckAll()\"\n    *ngIf=\"allItem\"\n>\n    <div class=\"title-container\">\n        <div style=\"background-color: transparent; width: 0.2rem; height: 100%\"></div>\n        <span fd-list-title>\n            <div style=\"height: 100%; display: flex; align-items: center\">\n                <span [style.fontSize]=\"allItem.unreadCount > 0 ? 'bold' : null\">{{ 'همه موارد' | bbbTranslate }}</span>\n                <ng-container *ngIf=\"allItem.unreadCount > 0\">\n                    <strong style=\"padding: 0 2px; direction: ltr\">({{ allItem.unreadCount }})</strong>\n                </ng-container>\n                <span style=\"padding: 0 5px\" *ngIf=\"allItem.allCount > 0\">{{ allItem.allCount }}</span>\n            </div>\n        </span>\n    </div>\n</li> -->\n\n<ng-container>\n    <ng-container *ngIf=\"allItem\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                itemTemplate;\n                context: {\n                    $implicit: 'همه موارد' | bbbTranslate,\n                    unreadCount: allItem.unreadCount,\n                    allCount: allItem.allCount,\n                    backColor: 'transparent',\n                    isAll: true,\n                    isChecked: allItemChecked\n                }\n            \"\n        ></ng-container>\n    </ng-container>\n\n    <ng-container\n        *ngTemplateOutlet=\"\n            itemTemplate;\n            context: {\n                $implicit: parameters.CartableGroupField | rval: mo:allColumns:true,\n                unreadCount: parameters.UnreadCountField | rval: mo:allColumns,\n                allCount: parameters.AllCountField | rval: mo:allColumns,\n                backColor: (columns[0].Caption | rval: mo:columns),\n                isChecked: isChecked,\n                icon: parameters.IconField | rval: mo:allColumns:true,\n                isBuiltin: isBuiltin\n            }\n        \"\n    ></ng-container>\n</ng-container>\n<ng-container *ngIf=\"isLastBuiltin\">\n    <li fd-list-item class=\"space\">\n        <span fd-list-title></span>\n    </li>\n</ng-container>\n<!-- <ng-container *ngIf=\"last\">\n    <ul fd-list>\n        <li fd-list-group-header>\n            <span fd-list-title style=\"background:#f7f7f7\"></span>\n        </li>\n        <ng-container *ngFor=\"let mo2 of moDataList\">\n            <ng-container *ngIf=\"'سیستمی' | rval: mo2:allColumns\">\n                <ng-container\n                    *ngTemplateOutlet=\"\n                        itemTemplate;\n                        context: {\n                            $implicit: parameters.CartableGroupField | rval: mo2:allColumns:true,\n                            unreadCount: parameters.UnreadCountField | rval: mo2:allColumns,\n                            allCount: parameters.AllCountField | rval: mo2:allColumns,\n                            backColor: columns[0].Caption | rval: mo2:columns,\n                            isChecked: isChecked\n                        }\n                    \"\n                ></ng-container>\n            </ng-container>\n        </ng-container>\n    </ul>\n</ng-container> -->\n\n<!-- <li fd-list-item [selected]=\"isChecked ? true : false\" (click)=\"onRowCheck()\" [interactive]=\"true\">\n    <div class=\"title-container\">\n        <div [style.backgroundColor]=\"columns[0].Caption | rval: mo:columns\" style=\"width: 0.2rem; height: 100%\"></div>\n        <span fd-list-title>\n            <div style=\"height: 100%; display: flex; align-items: center\">\n                <span [style.fontSize]=\"parameters.UnreadCountField | rval: mo:allColumns:(true ? 'bold' : null)\"\n                    >{{ parameters.CartableGroupField | rval: mo:allColumns:true }}\n                </span>\n                <ng-container *ngIf=\"parameters.UnreadCountField | rval: mo:allColumns:true\">\n                    <strong style=\"padding: 0 2px; direction: ltr\"\n                        >({{ parameters.UnreadCountField | rval: mo:allColumns:true }})</strong\n                    >\n                </ng-container>\n                <span style=\"padding: 0 5px\">{{ parameters.AllCountField | rval: mo:allColumns:true }}</span>\n            </div>\n        </span>\n    </div>\n</li> -->\n<ng-template\n    #itemTemplate\n    let-caption\n    let-unreadCount=\"unreadCount\"\n    let-allCount=\"allCount\"\n    let-backColor=\"backColor\"\n    let-isAll=\"isAll\"\n    let-isChecked=\"isChecked\"\n    let-icon=\"icon\"\n    let-isBuiltin=\"isBuiltin\"\n>\n    <li\n        *ngIf=\"isBuiltin || allCount > 0 || isAll\"\n        fd-list-item\n        [selected]=\"isChecked ? true : false\"\n        (click)=\"onClick(isAll)\"\n        [interactive]=\"true\"\n    >\n        <div class=\"title-container\">\n            <div [style.backgroundColor]=\"backColor\" style=\"width: 0.2rem; height: 100%\"></div>\n            <i *ngIf=\"icon\" fd-list-icon [glyph]=\"icon\"></i>\n            <span fd-list-title>\n                <div style=\"height: 100%; display: flex; align-items: center; column-gap: 5px\">\n                    <ng-container *ngIf=\"unreadCount && unreadCount > 0; else spanTemplate\">\n                        <strong>{{ caption }}</strong>\n                        <strong style=\"padding: 0 2px; direction: ltr\">({{ unreadCount }})</strong>\n                    </ng-container>\n                    <ng-template #spanTemplate>\n                        <span>{{ caption }}</span>\n                    </ng-template>\n                    <span style=\"padding: 0 5px\" *ngIf=\"allCount && allCount > 0\">{{ allCount }}</span>\n                </div>\n            </span>\n        </div>\n    </li>\n</ng-template>\n"]}
|
|
93
|
+
}] });
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-cartable-group.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-group-cartable/barsa-cartable-group.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-group-cartable/barsa-cartable-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit, SimpleChanges } from '@angular/core';\r\nimport { BaseViewItemPropsComponent, MetaobjectDataModel } from 'barsa-novin-ray-core';\r\n\r\n@Component({\r\n    selector: 'bsu-barsa-cartable-group',\r\n    templateUrl: './barsa-cartable-group.component.html',\r\n    styleUrls: ['./barsa-cartable-group.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class BarsaCartableGroupComponent extends BaseViewItemPropsComponent implements OnInit {\r\n    /**\r\n     *\r\n     */\r\n    allItem: { unreadCount: number; allCount: number };\r\n    allItemChecked: boolean;\r\n    builtinGroups: MetaobjectDataModel[];\r\n    isLastBuiltin = false;\r\n    isBuiltin: any;\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        if (this.index === 0) {\r\n            this._calcAll(this.moDataList);\r\n        }\r\n        this._checkSystemi();\r\n    }\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        let detectChanges = false;\r\n        const keys = ['mo', 'moDataList', 'isChecked'];\r\n\r\n        keys.forEach((key) => {\r\n            if (changes[key] && !changes[key].firstChange) {\r\n                this[key] = changes[key].currentValue;\r\n                detectChanges = true;\r\n                if (key === 'moDataList') {\r\n                    this._calcAll(changes[key].currentValue);\r\n                    this._checkSystemi();\r\n                }\r\n            }\r\n        });\r\n        if (detectChanges) {\r\n            this.detectChanges();\r\n        }\r\n    }\r\n    detectChanges(): void {\r\n        this._cdr.detectChanges();\r\n    }\r\n    _rowCheckAll(): void {\r\n        if (this.allItemChecked) {\r\n            return;\r\n        }\r\n        this.allItemChecked = true;\r\n        this.events.emit({ title: 'deselectAll', data: null });\r\n        this.events.emit({ title: 'rowCheck', data: { mo: { Id: '01' }, index: -1 } });\r\n    }\r\n    onClick(isAll: boolean): void {\r\n        if (isAll) {\r\n            this._rowCheckAll();\r\n        } else {\r\n            this._rowCheck();\r\n        }\r\n    }\r\n    _rowCheck(): void {\r\n        if (this.isChecked) {\r\n            return;\r\n        }\r\n        this.events.emit({ title: 'rowCheck', data: { mo: this.mo, index: this.index } });\r\n    }\r\n    private _checkSystemi(): void {\r\n        this.isBuiltin = this._reportValuePipe.transform('سیستمی', this.mo, this.allColumns);\r\n        if (this.index + 1 < this.moDataList.length && this.isBuiltin) {\r\n            this.isLastBuiltin = !this._reportValuePipe.transform(\r\n                'سیستمی',\r\n                this.moDataList[this.index + 1],\r\n                this.allColumns\r\n            );\r\n        }\r\n    }\r\n    private _calcAll(moDataList: MetaobjectDataModel[]): void {\r\n        if (this.index !== 0) {\r\n            return;\r\n        }\r\n        let allCount = 0;\r\n        let unreadCount = 0;\r\n        let isChecked = false;\r\n        moDataList.forEach((c) => {\r\n            if (c.$IsChecked) {\r\n                isChecked = true;\r\n            }\r\n            const allCountTemp = this._reportValuePipe.transform(this.parameters.AllCountField, c, this.allColumns);\r\n            allCount += isNaN(+allCountTemp) ? 0 : +allCountTemp;\r\n            const unreadCountTemp = this._reportValuePipe.transform(\r\n                this.parameters.UnreadCountField,\r\n                c,\r\n                this.allColumns\r\n            );\r\n            unreadCount += isNaN(+unreadCountTemp) ? 0 : +unreadCountTemp;\r\n        });\r\n        this.allItemChecked = !isChecked;\r\n        this.allItem = { allCount, unreadCount };\r\n    }\r\n}\r\n","<!-- <li\n    [interactive]=\"true\"\n    fd-list-item\n    [selected]=\"allItemChecked ? true : false\"\n    (click)=\"onRowCheckAll()\"\n    *ngIf=\"allItem\"\n>\n    <div class=\"title-container\">\n        <div style=\"background-color: transparent; width: 0.2rem; height: 100%\"></div>\n        <span fd-list-title>\n            <div style=\"height: 100%; display: flex; align-items: center\">\n                <span [style.fontSize]=\"allItem.unreadCount > 0 ? 'bold' : null\">{{ 'همه موارد' | bbbTranslate }}</span>\n                <ng-container *ngIf=\"allItem.unreadCount > 0\">\n                    <strong style=\"padding: 0 2px; direction: ltr\">({{ allItem.unreadCount }})</strong>\n                </ng-container>\n                <span style=\"padding: 0 5px\" *ngIf=\"allItem.allCount > 0\">{{ allItem.allCount }}</span>\n            </div>\n        </span>\n    </div>\n</li> -->\n\n<ng-container>\n    <ng-container *ngIf=\"allItem\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                itemTemplate;\n                context: {\n                    $implicit: 'همه موارد' | bbbTranslate,\n                    unreadCount: allItem.unreadCount,\n                    allCount: allItem.allCount,\n                    backColor: 'transparent',\n                    isAll: true,\n                    isChecked: allItemChecked\n                }\n            \"\n        ></ng-container>\n    </ng-container>\n\n    <ng-container\n        *ngTemplateOutlet=\"\n            itemTemplate;\n            context: {\n                $implicit: parameters.CartableGroupField | rval: mo:allColumns:true,\n                unreadCount: parameters.UnreadCountField | rval: mo:allColumns,\n                allCount: parameters.AllCountField | rval: mo:allColumns,\n                backColor: (columns[0].Caption | rval: mo:columns),\n                isChecked: isChecked,\n                icon: parameters.IconField | rval: mo:allColumns:true,\n                isBuiltin: isBuiltin\n            }\n        \"\n    ></ng-container>\n</ng-container>\n<ng-container *ngIf=\"isLastBuiltin\">\n    <li fd-list-item class=\"space\">\n        <span fd-list-title></span>\n    </li>\n</ng-container>\n<!-- <ng-container *ngIf=\"last\">\n    <ul fd-list>\n        <li fd-list-group-header>\n            <span fd-list-title style=\"background:#f7f7f7\"></span>\n        </li>\n        <ng-container *ngFor=\"let mo2 of moDataList\">\n            <ng-container *ngIf=\"'سیستمی' | rval: mo2:allColumns\">\n                <ng-container\n                    *ngTemplateOutlet=\"\n                        itemTemplate;\n                        context: {\n                            $implicit: parameters.CartableGroupField | rval: mo2:allColumns:true,\n                            unreadCount: parameters.UnreadCountField | rval: mo2:allColumns,\n                            allCount: parameters.AllCountField | rval: mo2:allColumns,\n                            backColor: columns[0].Caption | rval: mo2:columns,\n                            isChecked: isChecked\n                        }\n                    \"\n                ></ng-container>\n            </ng-container>\n        </ng-container>\n    </ul>\n</ng-container> -->\n\n<!-- <li fd-list-item [selected]=\"isChecked ? true : false\" (click)=\"onRowCheck()\" [interactive]=\"true\">\n    <div class=\"title-container\">\n        <div [style.backgroundColor]=\"columns[0].Caption | rval: mo:columns\" style=\"width: 0.2rem; height: 100%\"></div>\n        <span fd-list-title>\n            <div style=\"height: 100%; display: flex; align-items: center\">\n                <span [style.fontSize]=\"parameters.UnreadCountField | rval: mo:allColumns:(true ? 'bold' : null)\"\n                    >{{ parameters.CartableGroupField | rval: mo:allColumns:true }}\n                </span>\n                <ng-container *ngIf=\"parameters.UnreadCountField | rval: mo:allColumns:true\">\n                    <strong style=\"padding: 0 2px; direction: ltr\"\n                        >({{ parameters.UnreadCountField | rval: mo:allColumns:true }})</strong\n                    >\n                </ng-container>\n                <span style=\"padding: 0 5px\">{{ parameters.AllCountField | rval: mo:allColumns:true }}</span>\n            </div>\n        </span>\n    </div>\n</li> -->\n<ng-template\n    #itemTemplate\n    let-caption\n    let-unreadCount=\"unreadCount\"\n    let-allCount=\"allCount\"\n    let-backColor=\"backColor\"\n    let-isAll=\"isAll\"\n    let-isChecked=\"isChecked\"\n    let-icon=\"icon\"\n    let-isBuiltin=\"isBuiltin\"\n>\n    <li\n        *ngIf=\"isBuiltin || allCount > 0 || isAll\"\n        fd-list-item\n        [selected]=\"isChecked ? true : false\"\n        (click)=\"onClick(isAll)\"\n        [interactive]=\"true\"\n    >\n        <div class=\"title-container\">\n            <div [style.backgroundColor]=\"backColor\" style=\"width: 0.2rem; height: 100%\"></div>\n            <i *ngIf=\"icon\" fd-list-icon [glyph]=\"icon\"></i>\n            <span fd-list-title>\n                <div style=\"height: 100%; display: flex; align-items: center; column-gap: 5px\">\n                    <ng-container *ngIf=\"unreadCount && unreadCount > 0; else spanTemplate\">\n                        <strong>{{ caption }}</strong>\n                        <strong style=\"padding: 0 2px; direction: ltr\">({{ unreadCount }})</strong>\n                    </ng-container>\n                    <ng-template #spanTemplate>\n                        <span>{{ caption }}</span>\n                    </ng-template>\n                    <span style=\"padding: 0 5px\" *ngIf=\"allCount && allCount > 0\">{{ allCount }}</span>\n                </div>\n            </span>\n        </div>\n    </li>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { UploadService } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@fundamental-ngx/core/link";
|
|
6
|
+
import * as i3 from "../barsa-question-answer-form-add-comment/barsa-question-answer-form-add-comment.component";
|
|
7
|
+
export class BarsaQuestionAnswerCommentsSectionComponent {
|
|
8
|
+
}
|
|
9
|
+
BarsaQuestionAnswerCommentsSectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerCommentsSectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
+
BarsaQuestionAnswerCommentsSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaQuestionAnswerCommentsSectionComponent, selector: "bsu-barsa-question-answer-comments-section", inputs: { post: "post" }, providers: [UploadService], ngImport: i0, template: "<div class=\"flex w-full flex-col items-start\">\r\n <div class=\"border-b border-gray-300 w-full mt-2\"></div>\r\n <ng-container *ngIf=\"post.Comments.MoDataList.length > 2 && !post.showAllCommnets; else OneOrTwoComments\">\r\n <ng-container\r\n *ngTemplateOutlet=\"CommentRows; context: { $implicit: post.Comments.MoDataList.slice(0, 2) }\"\r\n ></ng-container>\r\n </ng-container>\r\n <ng-template #OneOrTwoComments>\r\n <ng-container *ngTemplateOutlet=\"CommentRows; context: { $implicit: post.Comments.MoDataList }\"></ng-container>\r\n </ng-template>\r\n <ng-template #CommentRows let-comments>\r\n <div *ngFor=\"let comment of comments\" class=\"py-2 border-b border-gray-200 text-sm w-full\">\r\n <p>\r\n <a fd-link class=\"inline\">{{ comment.CreatorUser$Caption.trim() }}</a>\r\n <span class=\"text-gray-500\">({{ comment.CreationDate$Caption.trim() }}):</span>\r\n {{ comment.$Caption.trim() }}\r\n <span\r\n class=\"italic text-gray-500\"\r\n *ngIf=\"\r\n comment.LastUpdateDate && comment.LastUpdateDate.getTime() !== comment.CreationDate.getTime()\r\n \"\r\n >\r\n -\r\n {{ comment.LastUpdateDate$Caption }}\r\n \u0648\u06CC\u0631\u0627\u06CC\u0634 \u0634\u062F\u0647\r\n </span>\r\n </p>\r\n </div>\r\n </ng-template>\r\n <bsu-barsa-question-answer-form-add-comment\r\n [postId]=\"post.Id\"\r\n (onAddComment)=\"post.Comments.MoDataList.push($event); post.showAllCommnets = true\"\r\n >\r\n <ng-container *ngIf=\"post.Comments.MoDataList.length > 2 && !post.showAllCommnets\">\r\n <span>|</span>\r\n <a fd-link aria-label=\"Emphasized\" class=\"hover:cursor-pointer\" (click)=\"post.showAllCommnets = true\">\r\n \u0646\u0645\u0627\u06CC\u0634\r\n {{ post.Comments.MoDataList.length - 2 }}\r\n \u0646\u0638\u0631 \u062F\u06CC\u06AF\u0631\r\n </a>\r\n </ng-container>\r\n </bsu-barsa-question-answer-form-add-comment>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.LinkComponent, selector: "[fdLink], [fd-link], [fd-breadcrumb-link]", inputs: ["class", "emphasized", "disabled", "inverted", "subtle", "undecorated"] }, { kind: "component", type: i3.BarsaQuestionAnswerFormAddCommentComponent, selector: "bsu-barsa-question-answer-form-add-comment", inputs: ["postId"], outputs: ["onAddComment"] }] });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerCommentsSectionComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'bsu-barsa-question-answer-comments-section', providers: [UploadService], template: "<div class=\"flex w-full flex-col items-start\">\r\n <div class=\"border-b border-gray-300 w-full mt-2\"></div>\r\n <ng-container *ngIf=\"post.Comments.MoDataList.length > 2 && !post.showAllCommnets; else OneOrTwoComments\">\r\n <ng-container\r\n *ngTemplateOutlet=\"CommentRows; context: { $implicit: post.Comments.MoDataList.slice(0, 2) }\"\r\n ></ng-container>\r\n </ng-container>\r\n <ng-template #OneOrTwoComments>\r\n <ng-container *ngTemplateOutlet=\"CommentRows; context: { $implicit: post.Comments.MoDataList }\"></ng-container>\r\n </ng-template>\r\n <ng-template #CommentRows let-comments>\r\n <div *ngFor=\"let comment of comments\" class=\"py-2 border-b border-gray-200 text-sm w-full\">\r\n <p>\r\n <a fd-link class=\"inline\">{{ comment.CreatorUser$Caption.trim() }}</a>\r\n <span class=\"text-gray-500\">({{ comment.CreationDate$Caption.trim() }}):</span>\r\n {{ comment.$Caption.trim() }}\r\n <span\r\n class=\"italic text-gray-500\"\r\n *ngIf=\"\r\n comment.LastUpdateDate && comment.LastUpdateDate.getTime() !== comment.CreationDate.getTime()\r\n \"\r\n >\r\n -\r\n {{ comment.LastUpdateDate$Caption }}\r\n \u0648\u06CC\u0631\u0627\u06CC\u0634 \u0634\u062F\u0647\r\n </span>\r\n </p>\r\n </div>\r\n </ng-template>\r\n <bsu-barsa-question-answer-form-add-comment\r\n [postId]=\"post.Id\"\r\n (onAddComment)=\"post.Comments.MoDataList.push($event); post.showAllCommnets = true\"\r\n >\r\n <ng-container *ngIf=\"post.Comments.MoDataList.length > 2 && !post.showAllCommnets\">\r\n <span>|</span>\r\n <a fd-link aria-label=\"Emphasized\" class=\"hover:cursor-pointer\" (click)=\"post.showAllCommnets = true\">\r\n \u0646\u0645\u0627\u06CC\u0634\r\n {{ post.Comments.MoDataList.length - 2 }}\r\n \u0646\u0638\u0631 \u062F\u06CC\u06AF\u0631\r\n </a>\r\n </ng-container>\r\n </bsu-barsa-question-answer-form-add-comment>\r\n</div>\r\n" }]
|
|
14
|
+
}], propDecorators: { post: [{
|
|
15
|
+
type: Input
|
|
16
|
+
}] } });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbW1lbnRzLXNlY3Rpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbW1lbnRzLXNlY3Rpb24vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbW1lbnRzLXNlY3Rpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbW1lbnRzLXNlY3Rpb24vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbW1lbnRzLXNlY3Rpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUF1QixhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7QUFRMUUsTUFBTSxPQUFPLDJDQUEyQzs7d0lBQTNDLDJDQUEyQzs0SEFBM0MsMkNBQTJDLCtGQUZ6QyxDQUFDLGFBQWEsQ0FBQywwQkNQOUIsNHVFQTJDQTsyRkRsQ2EsMkNBQTJDO2tCQU52RCxTQUFTOytCQUNJLDRDQUE0QyxhQUczQyxDQUFDLGFBQWEsQ0FBQzs4QkFHakIsSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNZXRhb2JqZWN0RGF0YU1vZGVsLCBVcGxvYWRTZXJ2aWNlIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY29tbWVudHMtc2VjdGlvbicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbW1lbnRzLXNlY3Rpb24uY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbW1lbnRzLXNlY3Rpb24uY29tcG9uZW50LmNzcyddLFxyXG4gICAgcHJvdmlkZXJzOiBbVXBsb2FkU2VydmljZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIEJhcnNhUXVlc3Rpb25BbnN3ZXJDb21tZW50c1NlY3Rpb25Db21wb25lbnQge1xyXG4gICAgQElucHV0KCkgcG9zdDogTWV0YW9iamVjdERhdGFNb2RlbDtcclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiZmxleCB3LWZ1bGwgZmxleC1jb2wgaXRlbXMtc3RhcnRcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJib3JkZXItYiBib3JkZXItZ3JheS0zMDAgdy1mdWxsIG10LTJcIj48L2Rpdj5cclxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJwb3N0LkNvbW1lbnRzLk1vRGF0YUxpc3QubGVuZ3RoID4gMiAmJiAhcG9zdC5zaG93QWxsQ29tbW5ldHM7IGVsc2UgT25lT3JUd29Db21tZW50c1wiPlxyXG4gICAgICAgIDxuZy1jb250YWluZXJcclxuICAgICAgICAgICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJDb21tZW50Um93czsgY29udGV4dDogeyAkaW1wbGljaXQ6IHBvc3QuQ29tbWVudHMuTW9EYXRhTGlzdC5zbGljZSgwLCAyKSB9XCJcclxuICAgICAgICA+PC9uZy1jb250YWluZXI+XHJcbiAgICA8L25nLWNvbnRhaW5lcj5cclxuICAgIDxuZy10ZW1wbGF0ZSAjT25lT3JUd29Db21tZW50cz5cclxuICAgICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiQ29tbWVudFJvd3M7IGNvbnRleHQ6IHsgJGltcGxpY2l0OiBwb3N0LkNvbW1lbnRzLk1vRGF0YUxpc3QgfVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgIDxuZy10ZW1wbGF0ZSAjQ29tbWVudFJvd3MgbGV0LWNvbW1lbnRzPlxyXG4gICAgICAgIDxkaXYgKm5nRm9yPVwibGV0IGNvbW1lbnQgb2YgY29tbWVudHNcIiBjbGFzcz1cInB5LTIgYm9yZGVyLWIgYm9yZGVyLWdyYXktMjAwIHRleHQtc20gdy1mdWxsXCI+XHJcbiAgICAgICAgICAgIDxwPlxyXG4gICAgICAgICAgICAgICAgPGEgZmQtbGluayBjbGFzcz1cImlubGluZVwiPnt7IGNvbW1lbnQuQ3JlYXRvclVzZXIkQ2FwdGlvbi50cmltKCkgfX08L2E+XHJcbiAgICAgICAgICAgICAgICAmbmJzcDs8c3BhbiBjbGFzcz1cInRleHQtZ3JheS01MDBcIj4oe3sgY29tbWVudC5DcmVhdGlvbkRhdGUkQ2FwdGlvbi50cmltKCkgfX0pOjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgIHt7IGNvbW1lbnQuJENhcHRpb24udHJpbSgpIH19XHJcbiAgICAgICAgICAgICAgICA8c3BhblxyXG4gICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiaXRhbGljIHRleHQtZ3JheS01MDBcIlxyXG4gICAgICAgICAgICAgICAgICAgICpuZ0lmPVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbW1lbnQuTGFzdFVwZGF0ZURhdGUgJiYgY29tbWVudC5MYXN0VXBkYXRlRGF0ZS5nZXRUaW1lKCkgIT09IGNvbW1lbnQuQ3JlYXRpb25EYXRlLmdldFRpbWUoKVxyXG4gICAgICAgICAgICAgICAgICAgIFwiXHJcbiAgICAgICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgICAgICAgLVxyXG4gICAgICAgICAgICAgICAgICAgIHt7IGNvbW1lbnQuTGFzdFVwZGF0ZURhdGUkQ2FwdGlvbiB9fVxyXG4gICAgICAgICAgICAgICAgICAgINmI24zYsdin24zYtCDYtNiv2YdcclxuICAgICAgICAgICAgICAgIDwvc3Bhbj5cclxuICAgICAgICAgICAgPC9wPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgIDxic3UtYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0tYWRkLWNvbW1lbnRcclxuICAgICAgICBbcG9zdElkXT1cInBvc3QuSWRcIlxyXG4gICAgICAgIChvbkFkZENvbW1lbnQpPVwicG9zdC5Db21tZW50cy5Nb0RhdGFMaXN0LnB1c2goJGV2ZW50KTsgcG9zdC5zaG93QWxsQ29tbW5ldHMgPSB0cnVlXCJcclxuICAgID5cclxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwicG9zdC5Db21tZW50cy5Nb0RhdGFMaXN0Lmxlbmd0aCA+IDIgJiYgIXBvc3Quc2hvd0FsbENvbW1uZXRzXCI+XHJcbiAgICAgICAgICAgIDxzcGFuPnw8L3NwYW4+XHJcbiAgICAgICAgICAgIDxhIGZkLWxpbmsgYXJpYS1sYWJlbD1cIkVtcGhhc2l6ZWRcIiBjbGFzcz1cImhvdmVyOmN1cnNvci1wb2ludGVyXCIgKGNsaWNrKT1cInBvc3Quc2hvd0FsbENvbW1uZXRzID0gdHJ1ZVwiPlxyXG4gICAgICAgICAgICAgICAg2YbZhdin24zYtFxyXG4gICAgICAgICAgICAgICAge3sgcG9zdC5Db21tZW50cy5Nb0RhdGFMaXN0Lmxlbmd0aCAtIDIgfX1cclxuICAgICAgICAgICAgICAgINmG2LjYsSDYr9uM2q/YsVxyXG4gICAgICAgICAgICA8L2E+XHJcbiAgICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgICA8L2JzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItZm9ybS1hZGQtY29tbWVudD5cclxuPC9kaXY+XHJcbiJdfQ==
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Component, EventEmitter, inject, Input, Output } from '@angular/core';
|
|
2
|
+
import { UploadService } from 'barsa-novin-ray-core';
|
|
3
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@fundamental-ngx/core/link";
|
|
7
|
+
import * as i3 from "../barsa-chip/barsa-chip.component";
|
|
8
|
+
export class BarsaQuestionAnswerContentActionsSectionComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.btnClick = new EventEmitter();
|
|
11
|
+
this._domSanitizer = inject(DomSanitizer);
|
|
12
|
+
}
|
|
13
|
+
safeHtml(html) {
|
|
14
|
+
return this._domSanitizer.bypassSecurityTrustHtml(html ?? '');
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
BarsaQuestionAnswerContentActionsSectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerContentActionsSectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
BarsaQuestionAnswerContentActionsSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaQuestionAnswerContentActionsSectionComponent, selector: "bsu-barsa-question-answer-content-actions-section", inputs: { mo: "mo", buttons: "buttons" }, outputs: { btnClick: "btnClick" }, host: { classAttribute: "w-full flex grow shrink flex-col" }, providers: [UploadService], ngImport: i0, template: "<div class=\"my-4 [&_*]:!bg-transparent\" [innerHTML]=\"safeHtml(mo.Post.Content)\"></div>\r\n<div class=\"grow shrink\"></div>\r\n<div class=\"flex justify-between items-center\">\r\n <div *ngIf=\"mo.Tags?.MoDataList\" class=\"flex gap-3\">\r\n <bsu-barsa-chip *ngFor=\"let tag of mo.Tags.MoDataList\" [title]=\"tag.$Caption\"></bsu-barsa-chip>\r\n </div>\r\n <div class=\"flex gap-3\">\r\n <ng-container *ngFor=\"let item of buttons\">\r\n <a\r\n *ngIf=\"!item.hidden && !item.isBuiltin\"\r\n fd-link\r\n aria-label=\"Emphasized\"\r\n class=\"!hover:cursor-pointer !no-underline\"\r\n (click)=\"btnClick.emit(); item.handler(item, item)\"\r\n [disabled]=\"item.disabled\"\r\n >{{ item.text }}</a\r\n >\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.LinkComponent, selector: "[fdLink], [fd-link], [fd-breadcrumb-link]", inputs: ["class", "emphasized", "disabled", "inverted", "subtle", "undecorated"] }, { kind: "component", type: i3.BarsaChipComponent, selector: "bsu-barsa-chip", inputs: ["title", "moreInfo", "canCheck", "isChecked"], outputs: ["checkedChange"] }] });
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerContentActionsSectionComponent, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{ selector: 'bsu-barsa-question-answer-content-actions-section', providers: [UploadService], host: {
|
|
22
|
+
class: 'w-full flex grow shrink flex-col'
|
|
23
|
+
}, template: "<div class=\"my-4 [&_*]:!bg-transparent\" [innerHTML]=\"safeHtml(mo.Post.Content)\"></div>\r\n<div class=\"grow shrink\"></div>\r\n<div class=\"flex justify-between items-center\">\r\n <div *ngIf=\"mo.Tags?.MoDataList\" class=\"flex gap-3\">\r\n <bsu-barsa-chip *ngFor=\"let tag of mo.Tags.MoDataList\" [title]=\"tag.$Caption\"></bsu-barsa-chip>\r\n </div>\r\n <div class=\"flex gap-3\">\r\n <ng-container *ngFor=\"let item of buttons\">\r\n <a\r\n *ngIf=\"!item.hidden && !item.isBuiltin\"\r\n fd-link\r\n aria-label=\"Emphasized\"\r\n class=\"!hover:cursor-pointer !no-underline\"\r\n (click)=\"btnClick.emit(); item.handler(item, item)\"\r\n [disabled]=\"item.disabled\"\r\n >{{ item.text }}</a\r\n >\r\n </ng-container>\r\n </div>\r\n</div>\r\n" }]
|
|
24
|
+
}], propDecorators: { mo: [{
|
|
25
|
+
type: Input
|
|
26
|
+
}], buttons: [{
|
|
27
|
+
type: Input
|
|
28
|
+
}], btnClick: [{
|
|
29
|
+
type: Output
|
|
30
|
+
}] } });
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbnRlbnQtYWN0aW9ucy1zZWN0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLXNhcC11aS9zcmMvbGliL2JhcnNhLXF1ZXN0aW9uLWFuc3dlci1jb250ZW50LWFjdGlvbnMtc2VjdGlvbi9iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY29udGVudC1hY3Rpb25zLXNlY3Rpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbnRlbnQtYWN0aW9ucy1zZWN0aW9uL2JhcnNhLXF1ZXN0aW9uLWFuc3dlci1jb250ZW50LWFjdGlvbnMtc2VjdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQXVCLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzFFLE9BQU8sRUFBRSxZQUFZLEVBQVksTUFBTSwyQkFBMkIsQ0FBQzs7Ozs7QUFXbkUsTUFBTSxPQUFPLGlEQUFpRDtJQVQ5RDtRQVljLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRWhDLGtCQUFhLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO0tBSWhEO0lBSEcsUUFBUSxDQUFDLElBQUk7UUFDVCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsdUJBQXVCLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7OzhJQVJRLGlEQUFpRDtrSUFBakQsaURBQWlELHVOQUwvQyxDQUFDLGFBQWEsQ0FBQywwQkNSOUIsODRCQW9CQTsyRkRQYSxpREFBaUQ7a0JBVDdELFNBQVM7K0JBQ0ksbURBQW1ELGFBR2xELENBQUMsYUFBYSxDQUFDLFFBQ3BCO3dCQUNGLEtBQUssRUFBRSxrQ0FBa0M7cUJBQzVDOzhCQUdRLEVBQUU7c0JBQVYsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0ksUUFBUTtzQkFBakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBpbmplY3QsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWV0YW9iamVjdERhdGFNb2RlbCwgVXBsb2FkU2VydmljZSB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuaW1wb3J0IHsgRG9tU2FuaXRpemVyLCBTYWZlSHRtbCB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY29udGVudC1hY3Rpb25zLXNlY3Rpb24nLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2JhcnNhLXF1ZXN0aW9uLWFuc3dlci1jb250ZW50LWFjdGlvbnMtc2VjdGlvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY29udGVudC1hY3Rpb25zLXNlY3Rpb24uY29tcG9uZW50LmNzcyddLFxyXG4gICAgcHJvdmlkZXJzOiBbVXBsb2FkU2VydmljZV0sXHJcbiAgICBob3N0OiB7XHJcbiAgICAgICAgY2xhc3M6ICd3LWZ1bGwgZmxleCBncm93IHNocmluayBmbGV4LWNvbCdcclxuICAgIH1cclxufSlcclxuZXhwb3J0IGNsYXNzIEJhcnNhUXVlc3Rpb25BbnN3ZXJDb250ZW50QWN0aW9uc1NlY3Rpb25Db21wb25lbnQge1xyXG4gICAgQElucHV0KCkgbW86IE1ldGFvYmplY3REYXRhTW9kZWw7XHJcbiAgICBASW5wdXQoKSBidXR0b25zOiBhbnlbXTtcclxuICAgIEBPdXRwdXQoKSBidG5DbGljayA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuXHJcbiAgICBwcml2YXRlIF9kb21TYW5pdGl6ZXIgPSBpbmplY3QoRG9tU2FuaXRpemVyKTtcclxuICAgIHNhZmVIdG1sKGh0bWwpOiBTYWZlSHRtbCB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX2RvbVNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbChodG1sID8/ICcnKTtcclxuICAgIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwibXktNCBbJl8qXTohYmctdHJhbnNwYXJlbnRcIiBbaW5uZXJIVE1MXT1cInNhZmVIdG1sKG1vLlBvc3QuQ29udGVudClcIj48L2Rpdj5cclxuPGRpdiBjbGFzcz1cImdyb3cgc2hyaW5rXCI+PC9kaXY+XHJcbjxkaXYgY2xhc3M9XCJmbGV4IGp1c3RpZnktYmV0d2VlbiBpdGVtcy1jZW50ZXJcIj5cclxuICAgIDxkaXYgKm5nSWY9XCJtby5UYWdzPy5Nb0RhdGFMaXN0XCIgY2xhc3M9XCJmbGV4IGdhcC0zXCI+XHJcbiAgICAgICAgPGJzdS1iYXJzYS1jaGlwICpuZ0Zvcj1cImxldCB0YWcgb2YgbW8uVGFncy5Nb0RhdGFMaXN0XCIgW3RpdGxlXT1cInRhZy4kQ2FwdGlvblwiPjwvYnN1LWJhcnNhLWNoaXA+XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJmbGV4IGdhcC0zXCI+XHJcbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgaXRlbSBvZiBidXR0b25zXCI+XHJcbiAgICAgICAgICAgIDxhXHJcbiAgICAgICAgICAgICAgICAqbmdJZj1cIiFpdGVtLmhpZGRlbiAmJiAhaXRlbS5pc0J1aWx0aW5cIlxyXG4gICAgICAgICAgICAgICAgZmQtbGlua1xyXG4gICAgICAgICAgICAgICAgYXJpYS1sYWJlbD1cIkVtcGhhc2l6ZWRcIlxyXG4gICAgICAgICAgICAgICAgY2xhc3M9XCIhaG92ZXI6Y3Vyc29yLXBvaW50ZXIgIW5vLXVuZGVybGluZVwiXHJcbiAgICAgICAgICAgICAgICAoY2xpY2spPVwiYnRuQ2xpY2suZW1pdCgpOyBpdGVtLmhhbmRsZXIoaXRlbSwgaXRlbSlcIlxyXG4gICAgICAgICAgICAgICAgW2Rpc2FibGVkXT1cIml0ZW0uZGlzYWJsZWRcIlxyXG4gICAgICAgICAgICAgICAgPnt7IGl0ZW0udGV4dCB9fTwvYVxyXG4gICAgICAgICAgICA+XHJcbiAgICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgICA8L2Rpdj5cclxuPC9kaXY+XHJcbiJdfQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { UploadService } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class BarsaQuestionAnswerCreatorTimeSectionComponent {
|
|
5
|
+
}
|
|
6
|
+
BarsaQuestionAnswerCreatorTimeSectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerCreatorTimeSectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
7
|
+
BarsaQuestionAnswerCreatorTimeSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaQuestionAnswerCreatorTimeSectionComponent, selector: "bsu-barsa-question-answer-creator-time-section", inputs: { post: "post" }, providers: [UploadService], ngImport: i0, template: "<p>\r\n {{ post.CreatorUser$Caption }}\r\n</p>\r\n<p>\r\n {{ post.CreationDate$Caption }}\r\n</p>\r\n", styles: [""] });
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerCreatorTimeSectionComponent, decorators: [{
|
|
9
|
+
type: Component,
|
|
10
|
+
args: [{ selector: 'bsu-barsa-question-answer-creator-time-section', providers: [UploadService], template: "<p>\r\n {{ post.CreatorUser$Caption }}\r\n</p>\r\n<p>\r\n {{ post.CreationDate$Caption }}\r\n</p>\r\n" }]
|
|
11
|
+
}], propDecorators: { post: [{
|
|
12
|
+
type: Input
|
|
13
|
+
}] } });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNyZWF0b3ItdGltZS1zZWN0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLXNhcC11aS9zcmMvbGliL2JhcnNhLXF1ZXN0aW9uLWFuc3dlci1jcmVhdG9yLXRpbWUtc2VjdGlvbi9iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY3JlYXRvci10aW1lLXNlY3Rpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNyZWF0b3ItdGltZS1zZWN0aW9uL2JhcnNhLXF1ZXN0aW9uLWFuc3dlci1jcmVhdG9yLXRpbWUtc2VjdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQXVCLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQVExRSxNQUFNLE9BQU8sOENBQThDOzsySUFBOUMsOENBQThDOytIQUE5Qyw4Q0FBOEMsbUdBRjVDLENBQUMsYUFBYSxDQUFDLDBCQ1A5Qiw2R0FNQTsyRkRHYSw4Q0FBOEM7a0JBTjFELFNBQVM7K0JBQ0ksZ0RBQWdELGFBRy9DLENBQUMsYUFBYSxDQUFDOzhCQUdqQixJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1ldGFvYmplY3REYXRhTW9kZWwsIFVwbG9hZFNlcnZpY2UgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYnN1LWJhcnNhLXF1ZXN0aW9uLWFuc3dlci1jcmVhdG9yLXRpbWUtc2VjdGlvbicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNyZWF0b3ItdGltZS1zZWN0aW9uLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2JhcnNhLXF1ZXN0aW9uLWFuc3dlci1jcmVhdG9yLXRpbWUtc2VjdGlvbi5jb21wb25lbnQuY3NzJ10sXHJcbiAgICBwcm92aWRlcnM6IFtVcGxvYWRTZXJ2aWNlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQmFyc2FRdWVzdGlvbkFuc3dlckNyZWF0b3JUaW1lU2VjdGlvbkNvbXBvbmVudCB7XHJcbiAgICBASW5wdXQoKSBwb3N0OiBNZXRhb2JqZWN0RGF0YU1vZGVsO1xyXG59XHJcbiIsIjxwPlxyXG4gICAge3sgcG9zdC5DcmVhdG9yVXNlciRDYXB0aW9uIH19XHJcbjwvcD5cclxuPHA+XHJcbiAgICB7eyBwb3N0LkNyZWF0aW9uRGF0ZSRDYXB0aW9uIH19XHJcbjwvcD5cclxuIl19
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { FormPropsBaseComponent, UploadService } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "../layout-control/layout-control.component";
|
|
6
|
+
import * as i3 from "../barsa-question-answer-content-actions-section/barsa-question-answer-content-actions-section.component";
|
|
7
|
+
import * as i4 from "../barsa-question-answer-vote-section/barsa-question-answer-vote-section.component";
|
|
8
|
+
import * as i5 from "../barsa-question-answer-creator-time-section/barsa-question-answer-creator-time-section.component";
|
|
9
|
+
import * as i6 from "../barsa-question-answer-comments-section/barsa-question-answer-comments-section.component";
|
|
10
|
+
import * as i7 from "barsa-novin-ray-core";
|
|
11
|
+
export class BarsaQuestionAnswerFormComponent extends FormPropsBaseComponent {
|
|
12
|
+
constructor() {
|
|
13
|
+
super(...arguments);
|
|
14
|
+
this.toolbar = toolbar;
|
|
15
|
+
}
|
|
16
|
+
ngOnChanges(changes) {
|
|
17
|
+
super.ngOnChanges(changes);
|
|
18
|
+
const { mo } = changes;
|
|
19
|
+
if (mo && !mo.firstChange) {
|
|
20
|
+
this.mo = mo.currentValue;
|
|
21
|
+
this._cdr.detectChanges();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
onVoteChange(isPositive) {
|
|
25
|
+
const vote = this._controlUiPipe.transform(isPositive ? 'ثبت رای مثبت' : 'ثبت رای منفی', this.layout94);
|
|
26
|
+
vote && vote?.FieldUi.fireEvent('click', vote.FieldUi);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
BarsaQuestionAnswerFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerFormComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
+
BarsaQuestionAnswerFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaQuestionAnswerFormComponent, selector: "bsu-barsa-question-answer-form", providers: [UploadService], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"absolute z-0 bg-white w-screen top-0 left-0\"></div>\r\n<div class=\"w-full py-8 relative\">\r\n <div class=\"w-full max-w-[80rem] mx-auto grid grid-cols-4 gap-12\">\r\n <div class=\"col-span-3 flex flex-col gap-8\">\r\n <div class=\"flex gap-8 pb-8\">\r\n <div class=\"grow-0 shrink-0 flex flex-col items-center gap-6\">\r\n <img src=\"https://picsum.photos/64/64\" class=\"size-12 rounded-full\" />\r\n <bsu-barsa-question-answer-vote-section\r\n [vote]=\"mo.Post.CurrentUserVote.Vote\"\r\n [voteUps]=\"mo.Post.VoteUps\"\r\n [voteDowns]=\"mo.Post.VoteDowns\"\r\n (voteChange)=\"onVoteChange($event)\"\r\n ></bsu-barsa-question-answer-vote-section>\r\n </div>\r\n <div class=\"grow shrink\">\r\n <bsu-barsa-question-answer-creator-time-section\r\n [post]=\"mo.Post\"\r\n ></bsu-barsa-question-answer-creator-time-section>\r\n <p class=\"text-2xl mt-4\">\r\n {{ mo.Title }}\r\n </p>\r\n <bsu-barsa-question-answer-content-actions-section\r\n [mo]=\"mo\"\r\n [buttons]=\"toolbarItems\"\r\n ></bsu-barsa-question-answer-content-actions-section>\r\n <bsu-barsa-question-answer-comments-section\r\n [post]=\"mo.Post\"\r\n ></bsu-barsa-question-answer-comments-section>\r\n </div>\r\n </div>\r\n <p class=\"z-10 text-2xl pb-4 border-b border-gray-200 relative\">\r\n {{ mo.Answers.MoDataList.length }}\r\n \u067E\u0627\u0633\u062E\r\n </p>\r\n <div class=\"flex flex-col gap-8 z-10 relative\">\r\n <ng-container *ngIf=\"mo.Answers.MoDataList.length\">\r\n <ng-container *ngIf=\"'\u067E\u0627\u0633\u062E \u0647\u0627' | controlUi: layout94 as answers\">\r\n <bsu-layout-control [config]=\"answers\"></bsu-layout-control>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"col-span-1\">\r\n <ng-container *ngIf=\"'\u0633\u0648\u0627\u0644\u0627\u062A \u0645\u0631\u062A\u0628\u0637' | controlUi: layout94 as relevantQuestions\">\r\n <bsu-layout-control [config]=\"relevantQuestions\"></bsu-layout-control>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"w-full max-w-[80rem] mx-auto grid grid-cols-4 mt-4\">\r\n <div class=\"col-span-4 flex flex-col gap-4 p-4 border border-gray-200 rounded-md bg-white\">\r\n <span class=\"text-xl\">\u0627\u0631\u0633\u0627\u0644 \u067E\u0627\u0633\u062E</span>\r\n <ng-container *ngIf=\"'\u067E\u0627\u0633\u062E \u062C\u062F\u06CC\u062F' | controlUi: layout94 as newAnswerText\">\r\n <bsu-layout-control [config]=\"newAnswerText\"></bsu-layout-control>\r\n </ng-container>\r\n <div class=\"flex justify-end\">\r\n <ng-container *ngIf=\"'\u0627\u0631\u0633\u0627\u0644 \u067E\u0627\u0633\u062E \u062C\u062F\u06CC\u062F' | controlUi: layout94 as newAnswerSubmit\">\r\n <bsu-layout-control\r\n class=\"w-fit min-w-fit max-w-fit\"\r\n [config]=\"newAnswerSubmit\"\r\n ></bsu-layout-control>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":root{--sapBackgroundColor: #fdfdfd}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.LayoutControlComponent, selector: "bsu-layout-control", inputs: ["inlineEdit", "caption", "focusControl", "showLabel", "maxLabelWidth", "hasHorizontalText", "contentDensity", "flex", "RefreshLabel", "SetVisible"] }, { kind: "component", type: i3.BarsaQuestionAnswerContentActionsSectionComponent, selector: "bsu-barsa-question-answer-content-actions-section", inputs: ["mo", "buttons"], outputs: ["btnClick"] }, { kind: "component", type: i4.BarsaQuestionAnswerVoteSectionComponent, selector: "bsu-barsa-question-answer-vote-section", inputs: ["vote", "voteDowns", "voteUps"], outputs: ["voteChange"] }, { kind: "component", type: i5.BarsaQuestionAnswerCreatorTimeSectionComponent, selector: "bsu-barsa-question-answer-creator-time-section", inputs: ["post"] }, { kind: "component", type: i6.BarsaQuestionAnswerCommentsSectionComponent, selector: "bsu-barsa-question-answer-comments-section", inputs: ["post"] }, { kind: "pipe", type: i7.ControlUiPipe, name: "controlUi" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerFormComponent, decorators: [{
|
|
32
|
+
type: Component,
|
|
33
|
+
args: [{ selector: 'bsu-barsa-question-answer-form', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], template: "<div class=\"absolute z-0 bg-white w-screen top-0 left-0\"></div>\r\n<div class=\"w-full py-8 relative\">\r\n <div class=\"w-full max-w-[80rem] mx-auto grid grid-cols-4 gap-12\">\r\n <div class=\"col-span-3 flex flex-col gap-8\">\r\n <div class=\"flex gap-8 pb-8\">\r\n <div class=\"grow-0 shrink-0 flex flex-col items-center gap-6\">\r\n <img src=\"https://picsum.photos/64/64\" class=\"size-12 rounded-full\" />\r\n <bsu-barsa-question-answer-vote-section\r\n [vote]=\"mo.Post.CurrentUserVote.Vote\"\r\n [voteUps]=\"mo.Post.VoteUps\"\r\n [voteDowns]=\"mo.Post.VoteDowns\"\r\n (voteChange)=\"onVoteChange($event)\"\r\n ></bsu-barsa-question-answer-vote-section>\r\n </div>\r\n <div class=\"grow shrink\">\r\n <bsu-barsa-question-answer-creator-time-section\r\n [post]=\"mo.Post\"\r\n ></bsu-barsa-question-answer-creator-time-section>\r\n <p class=\"text-2xl mt-4\">\r\n {{ mo.Title }}\r\n </p>\r\n <bsu-barsa-question-answer-content-actions-section\r\n [mo]=\"mo\"\r\n [buttons]=\"toolbarItems\"\r\n ></bsu-barsa-question-answer-content-actions-section>\r\n <bsu-barsa-question-answer-comments-section\r\n [post]=\"mo.Post\"\r\n ></bsu-barsa-question-answer-comments-section>\r\n </div>\r\n </div>\r\n <p class=\"z-10 text-2xl pb-4 border-b border-gray-200 relative\">\r\n {{ mo.Answers.MoDataList.length }}\r\n \u067E\u0627\u0633\u062E\r\n </p>\r\n <div class=\"flex flex-col gap-8 z-10 relative\">\r\n <ng-container *ngIf=\"mo.Answers.MoDataList.length\">\r\n <ng-container *ngIf=\"'\u067E\u0627\u0633\u062E \u0647\u0627' | controlUi: layout94 as answers\">\r\n <bsu-layout-control [config]=\"answers\"></bsu-layout-control>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"col-span-1\">\r\n <ng-container *ngIf=\"'\u0633\u0648\u0627\u0644\u0627\u062A \u0645\u0631\u062A\u0628\u0637' | controlUi: layout94 as relevantQuestions\">\r\n <bsu-layout-control [config]=\"relevantQuestions\"></bsu-layout-control>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"w-full max-w-[80rem] mx-auto grid grid-cols-4 mt-4\">\r\n <div class=\"col-span-4 flex flex-col gap-4 p-4 border border-gray-200 rounded-md bg-white\">\r\n <span class=\"text-xl\">\u0627\u0631\u0633\u0627\u0644 \u067E\u0627\u0633\u062E</span>\r\n <ng-container *ngIf=\"'\u067E\u0627\u0633\u062E \u062C\u062F\u06CC\u062F' | controlUi: layout94 as newAnswerText\">\r\n <bsu-layout-control [config]=\"newAnswerText\"></bsu-layout-control>\r\n </ng-container>\r\n <div class=\"flex justify-end\">\r\n <ng-container *ngIf=\"'\u0627\u0631\u0633\u0627\u0644 \u067E\u0627\u0633\u062E \u062C\u062F\u06CC\u062F' | controlUi: layout94 as newAnswerSubmit\">\r\n <bsu-layout-control\r\n class=\"w-fit min-w-fit max-w-fit\"\r\n [config]=\"newAnswerSubmit\"\r\n ></bsu-layout-control>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":root{--sapBackgroundColor: #fdfdfd}\n"] }]
|
|
34
|
+
}] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDbEYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7Ozs7Ozs7QUFTN0UsTUFBTSxPQUFPLGdDQUFpQyxTQUFRLHNCQUFzQjtJQVA1RTs7UUFvQnVCLFlBQU8sR0FBRyxPQUFPLENBQUM7S0FDeEM7SUFiRyxXQUFXLENBQUMsT0FBc0I7UUFDOUIsS0FBSyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMzQixNQUFNLEVBQUUsRUFBRSxFQUFFLEdBQUcsT0FBTyxDQUFDO1FBQ3ZCLElBQUksRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLFdBQVcsRUFBRTtZQUN2QixJQUFJLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUM7WUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztTQUM3QjtJQUNMLENBQUM7SUFDRCxZQUFZLENBQUMsVUFBbUI7UUFDNUIsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLGNBQWMsRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDeEcsSUFBSSxJQUFJLElBQUksRUFBRSxPQUFPLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0QsQ0FBQzs7NkhBWlEsZ0NBQWdDO2lIQUFoQyxnQ0FBZ0MseURBRjlCLENBQUMsYUFBYSxDQUFDLHNFQ1I5Qixnc0hBaUVBOzJGRHZEYSxnQ0FBZ0M7a0JBUDVDLFNBQVM7K0JBQ0ksZ0NBQWdDLG1CQUd6Qix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDLENBQUMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3JtUHJvcHNCYXNlQ29tcG9uZW50LCBVcGxvYWRTZXJ2aWNlIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItZm9ybScsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0uY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0uY29tcG9uZW50LmNzcyddLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgICBwcm92aWRlcnM6IFtVcGxvYWRTZXJ2aWNlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQmFyc2FRdWVzdGlvbkFuc3dlckZvcm1Db21wb25lbnQgZXh0ZW5kcyBGb3JtUHJvcHNCYXNlQ29tcG9uZW50IHtcclxuICAgIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgICAgICBzdXBlci5uZ09uQ2hhbmdlcyhjaGFuZ2VzKTtcclxuICAgICAgICBjb25zdCB7IG1vIH0gPSBjaGFuZ2VzO1xyXG4gICAgICAgIGlmIChtbyAmJiAhbW8uZmlyc3RDaGFuZ2UpIHtcclxuICAgICAgICAgICAgdGhpcy5tbyA9IG1vLmN1cnJlbnRWYWx1ZTtcclxuICAgICAgICAgICAgdGhpcy5fY2RyLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICBvblZvdGVDaGFuZ2UoaXNQb3NpdGl2ZTogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgICAgIGNvbnN0IHZvdGUgPSB0aGlzLl9jb250cm9sVWlQaXBlLnRyYW5zZm9ybShpc1Bvc2l0aXZlID8gJ9ir2KjYqiDYsdin24wg2YXYq9io2KonIDogJ9ir2KjYqiDYsdin24wg2YXZhtmB24wnLCB0aGlzLmxheW91dDk0KTtcclxuICAgICAgICB2b3RlICYmIHZvdGU/LkZpZWxkVWkuZmlyZUV2ZW50KCdjbGljaycsIHZvdGUuRmllbGRVaSk7XHJcbiAgICB9XHJcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgdG9vbGJhciA9IHRvb2xiYXI7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImFic29sdXRlIHotMCBiZy13aGl0ZSB3LXNjcmVlbiB0b3AtMCBsZWZ0LTBcIj48L2Rpdj5cclxuPGRpdiBjbGFzcz1cInctZnVsbCBweS04IHJlbGF0aXZlXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwidy1mdWxsIG1heC13LVs4MHJlbV0gbXgtYXV0byBncmlkIGdyaWQtY29scy00IGdhcC0xMlwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtc3Bhbi0zIGZsZXggZmxleC1jb2wgZ2FwLThcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImZsZXggZ2FwLTggcGItOFwiPlxyXG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImdyb3ctMCBzaHJpbmstMCBmbGV4IGZsZXgtY29sIGl0ZW1zLWNlbnRlciBnYXAtNlwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxpbWcgc3JjPVwiaHR0cHM6Ly9waWNzdW0ucGhvdG9zLzY0LzY0XCIgY2xhc3M9XCJzaXplLTEyIHJvdW5kZWQtZnVsbFwiIC8+XHJcbiAgICAgICAgICAgICAgICAgICAgPGJzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItdm90ZS1zZWN0aW9uXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFt2b3RlXT1cIm1vLlBvc3QuQ3VycmVudFVzZXJWb3RlLlZvdGVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbdm90ZVVwc109XCJtby5Qb3N0LlZvdGVVcHNcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbdm90ZURvd25zXT1cIm1vLlBvc3QuVm90ZURvd25zXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgKHZvdGVDaGFuZ2UpPVwib25Wb3RlQ2hhbmdlKCRldmVudClcIlxyXG4gICAgICAgICAgICAgICAgICAgID48L2JzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItdm90ZS1zZWN0aW9uPlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZ3JvdyBzaHJpbmtcIj5cclxuICAgICAgICAgICAgICAgICAgICA8YnN1LWJhcnNhLXF1ZXN0aW9uLWFuc3dlci1jcmVhdG9yLXRpbWUtc2VjdGlvblxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbcG9zdF09XCJtby5Qb3N0XCJcclxuICAgICAgICAgICAgICAgICAgICA+PC9ic3UtYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNyZWF0b3ItdGltZS1zZWN0aW9uPlxyXG4gICAgICAgICAgICAgICAgICAgIDxwIGNsYXNzPVwidGV4dC0yeGwgbXQtNFwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICB7eyBtby5UaXRsZSB9fVxyXG4gICAgICAgICAgICAgICAgICAgIDwvcD5cclxuICAgICAgICAgICAgICAgICAgICA8YnN1LWJhcnNhLXF1ZXN0aW9uLWFuc3dlci1jb250ZW50LWFjdGlvbnMtc2VjdGlvblxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbbW9dPVwibW9cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbYnV0dG9uc109XCJ0b29sYmFySXRlbXNcIlxyXG4gICAgICAgICAgICAgICAgICAgID48L2JzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY29udGVudC1hY3Rpb25zLXNlY3Rpb24+XHJcbiAgICAgICAgICAgICAgICAgICAgPGJzdS1iYXJzYS1xdWVzdGlvbi1hbnN3ZXItY29tbWVudHMtc2VjdGlvblxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbcG9zdF09XCJtby5Qb3N0XCJcclxuICAgICAgICAgICAgICAgICAgICA+PC9ic3UtYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWNvbW1lbnRzLXNlY3Rpb24+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDxwIGNsYXNzPVwiei0xMCB0ZXh0LTJ4bCBwYi00IGJvcmRlci1iIGJvcmRlci1ncmF5LTIwMCByZWxhdGl2ZVwiPlxyXG4gICAgICAgICAgICAgICAge3sgbW8uQW5zd2Vycy5Nb0RhdGFMaXN0Lmxlbmd0aCB9fVxyXG4gICAgICAgICAgICAgICAg2b7Yp9iz2K5cclxuICAgICAgICAgICAgPC9wPlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZmxleCBmbGV4LWNvbCBnYXAtOCB6LTEwIHJlbGF0aXZlXCI+XHJcbiAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwibW8uQW5zd2Vycy5Nb0RhdGFMaXN0Lmxlbmd0aFwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIn2b7Yp9iz2K4g2YfYpycgfCBjb250cm9sVWk6IGxheW91dDk0IGFzIGFuc3dlcnNcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPGJzdS1sYXlvdXQtY29udHJvbCBbY29uZmlnXT1cImFuc3dlcnNcIj48L2JzdS1sYXlvdXQtY29udHJvbD5cclxuICAgICAgICAgICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cclxuICAgICAgICAgICAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLXNwYW4tMVwiPlxyXG4gICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiJ9iz2YjYp9mE2KfYqiDZhdix2KrYqNi3JyB8IGNvbnRyb2xVaTogbGF5b3V0OTQgYXMgcmVsZXZhbnRRdWVzdGlvbnNcIj5cclxuICAgICAgICAgICAgICAgIDxic3UtbGF5b3V0LWNvbnRyb2wgW2NvbmZpZ109XCJyZWxldmFudFF1ZXN0aW9uc1wiPjwvYnN1LWxheW91dC1jb250cm9sPlxyXG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cInctZnVsbCBtYXgtdy1bODByZW1dIG14LWF1dG8gZ3JpZCBncmlkLWNvbHMtNCBtdC00XCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1zcGFuLTQgZmxleCBmbGV4LWNvbCBnYXAtNCBwLTQgYm9yZGVyIGJvcmRlci1ncmF5LTIwMCByb3VuZGVkLW1kIGJnLXdoaXRlXCI+XHJcbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwidGV4dC14bFwiPtin2LHYs9in2YQg2b7Yp9iz2K48L3NwYW4+XHJcbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIn2b7Yp9iz2K4g2KzYr9uM2K8nIHwgY29udHJvbFVpOiBsYXlvdXQ5NCBhcyBuZXdBbnN3ZXJUZXh0XCI+XHJcbiAgICAgICAgICAgICAgICA8YnN1LWxheW91dC1jb250cm9sIFtjb25maWddPVwibmV3QW5zd2VyVGV4dFwiPjwvYnN1LWxheW91dC1jb250cm9sPlxyXG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImZsZXgganVzdGlmeS1lbmRcIj5cclxuICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIn2KfYsdiz2KfZhCDZvtin2LPYriDYrNiv24zYrycgfCBjb250cm9sVWk6IGxheW91dDk0IGFzIG5ld0Fuc3dlclN1Ym1pdFwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxic3UtbGF5b3V0LWNvbnRyb2xcclxuICAgICAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJ3LWZpdCBtaW4tdy1maXQgbWF4LXctZml0XCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW2NvbmZpZ109XCJuZXdBbnN3ZXJTdWJtaXRcIlxyXG4gICAgICAgICAgICAgICAgICAgID48L2JzdS1sYXlvdXQtY29udHJvbD5cclxuICAgICAgICAgICAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ChangeDetectorRef, Component, EventEmitter, inject, Input, Output } from '@angular/core';
|
|
2
|
+
import { BarsaApi } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@angular/forms";
|
|
6
|
+
import * as i3 from "@fundamental-ngx/core/link";
|
|
7
|
+
import * as i4 from "@fundamental-ngx/core/button";
|
|
8
|
+
export class BarsaQuestionAnswerFormAddCommentComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.onAddComment = new EventEmitter();
|
|
11
|
+
this._cdr = inject(ChangeDetectorRef);
|
|
12
|
+
this.newCommentText = '';
|
|
13
|
+
this.showAddCommentTextArea = false;
|
|
14
|
+
this.sending = false;
|
|
15
|
+
}
|
|
16
|
+
addComment() {
|
|
17
|
+
this.sending = true;
|
|
18
|
+
BarsaApi.Bw.RunBlMethodAsync({
|
|
19
|
+
Method: 'SabteNazar',
|
|
20
|
+
Parameters: [this.postId, this.newCommentText],
|
|
21
|
+
SuccessFn: (res) => {
|
|
22
|
+
this.onAddComment.emit(res);
|
|
23
|
+
this.sending = false;
|
|
24
|
+
this.showAddCommentTextArea = false;
|
|
25
|
+
this.newCommentText = '';
|
|
26
|
+
this._cdr.markForCheck();
|
|
27
|
+
},
|
|
28
|
+
FailedFn: () => {
|
|
29
|
+
this.sending = false;
|
|
30
|
+
this._cdr.markForCheck();
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
BarsaQuestionAnswerFormAddCommentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerFormAddCommentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
36
|
+
BarsaQuestionAnswerFormAddCommentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaQuestionAnswerFormAddCommentComponent, selector: "bsu-barsa-question-answer-form-add-comment", inputs: { postId: "postId" }, outputs: { onAddComment: "onAddComment" }, host: { classAttribute: "w-full" }, ngImport: i0, template: "<div *ngIf=\"!showAddCommentTextArea\" class=\"w-full mt-2 flex gap-3\">\r\n <a\r\n fd-link\r\n aria-label=\"Emphasized\"\r\n class=\"hover:cursor-pointer\"\r\n (click)=\"showAddCommentTextArea = true; newCommentText = ''\"\r\n >\u0627\u0631\u0633\u0627\u0644 \u0646\u0638\u0631</a\r\n >\r\n <ng-content></ng-content>\r\n</div>\r\n<div [class.!flex]=\"showAddCommentTextArea\" class=\"hidden items-end w-full gap-4\">\r\n <textarea\r\n rows=\"3\"\r\n class=\"block p-2.5 w-full text-sm text-gray-900 bg-gray-50 rounded-lg border border-gray-300\"\r\n placeholder=\"\u0646\u0638\u0631 \u0634\u0645\u0627...\"\r\n [disabled]=\"sending\"\r\n [(ngModel)]=\"newCommentText\"\r\n ></textarea>\r\n <div class=\"flex justify-end\">\r\n <button fd-button fdType=\"standard\" [disabled]=\"sending || newCommentText.length < 3\" (click)=\"addComment()\">\r\n \u0627\u0631\u0633\u0627\u0644\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.LinkComponent, selector: "[fdLink], [fd-link], [fd-breadcrumb-link]", inputs: ["class", "emphasized", "disabled", "inverted", "subtle", "undecorated"] }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }] });
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaQuestionAnswerFormAddCommentComponent, decorators: [{
|
|
38
|
+
type: Component,
|
|
39
|
+
args: [{ selector: 'bsu-barsa-question-answer-form-add-comment', host: {
|
|
40
|
+
class: 'w-full'
|
|
41
|
+
}, template: "<div *ngIf=\"!showAddCommentTextArea\" class=\"w-full mt-2 flex gap-3\">\r\n <a\r\n fd-link\r\n aria-label=\"Emphasized\"\r\n class=\"hover:cursor-pointer\"\r\n (click)=\"showAddCommentTextArea = true; newCommentText = ''\"\r\n >\u0627\u0631\u0633\u0627\u0644 \u0646\u0638\u0631</a\r\n >\r\n <ng-content></ng-content>\r\n</div>\r\n<div [class.!flex]=\"showAddCommentTextArea\" class=\"hidden items-end w-full gap-4\">\r\n <textarea\r\n rows=\"3\"\r\n class=\"block p-2.5 w-full text-sm text-gray-900 bg-gray-50 rounded-lg border border-gray-300\"\r\n placeholder=\"\u0646\u0638\u0631 \u0634\u0645\u0627...\"\r\n [disabled]=\"sending\"\r\n [(ngModel)]=\"newCommentText\"\r\n ></textarea>\r\n <div class=\"flex justify-end\">\r\n <button fd-button fdType=\"standard\" [disabled]=\"sending || newCommentText.length < 3\" (click)=\"addComment()\">\r\n \u0627\u0631\u0633\u0627\u0644\r\n </button>\r\n </div>\r\n</div>\r\n" }]
|
|
42
|
+
}], propDecorators: { postId: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}], onAddComment: [{
|
|
45
|
+
type: Output
|
|
46
|
+
}] } });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0tYWRkLWNvbW1lbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0tYWRkLWNvbW1lbnQvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0tYWRkLWNvbW1lbnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0tYWRkLWNvbW1lbnQvYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0tYWRkLWNvbW1lbnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEcsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7Ozs7QUFVaEQsTUFBTSxPQUFPLDBDQUEwQztJQVJ2RDtRQVVjLGlCQUFZLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUN6QyxTQUFJLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDekMsbUJBQWMsR0FBRyxFQUFFLENBQUM7UUFDcEIsMkJBQXNCLEdBQUcsS0FBSyxDQUFDO1FBQy9CLFlBQU8sR0FBRyxLQUFLLENBQUM7S0FtQm5CO0lBbEJHLFVBQVU7UUFDTixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztRQUNwQixRQUFRLENBQUMsRUFBRSxDQUFDLGdCQUFnQixDQUFDO1lBQ3pCLE1BQU0sRUFBRSxZQUFZO1lBQ3BCLFVBQVUsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLGNBQWMsQ0FBQztZQUM5QyxTQUFTLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRTtnQkFDZixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDNUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7Z0JBQ3JCLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxLQUFLLENBQUM7Z0JBQ3BDLElBQUksQ0FBQyxjQUFjLEdBQUcsRUFBRSxDQUFDO2dCQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQzdCLENBQUM7WUFDRCxRQUFRLEVBQUUsR0FBRyxFQUFFO2dCQUNYLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO2dCQUNyQixJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQzdCLENBQUM7U0FDSixDQUFDLENBQUM7SUFDUCxDQUFDOzt1SUF4QlEsMENBQTBDOzJIQUExQywwQ0FBMEMsK0xDWHZELDJnQ0F3QkE7MkZEYmEsMENBQTBDO2tCQVJ0RCxTQUFTOytCQUNJLDRDQUE0QyxRQUdoRDt3QkFDRixLQUFLLEVBQUUsUUFBUTtxQkFDbEI7OEJBR1EsTUFBTTtzQkFBZCxLQUFLO2dCQUNJLFlBQVk7c0JBQXJCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIGluamVjdCwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCYXJzYUFwaSB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdic3UtYmFyc2EtcXVlc3Rpb24tYW5zd2VyLWZvcm0tYWRkLWNvbW1lbnQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2JhcnNhLXF1ZXN0aW9uLWFuc3dlci1mb3JtLWFkZC1jb21tZW50LmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2JhcnNhLXF1ZXN0aW9uLWFuc3dlci1mb3JtLWFkZC1jb21tZW50LmNvbXBvbmVudC5jc3MnXSxcclxuICAgIGhvc3Q6IHtcclxuICAgICAgICBjbGFzczogJ3ctZnVsbCdcclxuICAgIH1cclxufSlcclxuZXhwb3J0IGNsYXNzIEJhcnNhUXVlc3Rpb25BbnN3ZXJGb3JtQWRkQ29tbWVudENvbXBvbmVudCB7XHJcbiAgICBASW5wdXQoKSBwb3N0SWQ6IHN0cmluZztcclxuICAgIEBPdXRwdXQoKSBvbkFkZENvbW1lbnQgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICAgIHByaXZhdGUgX2NkciA9IGluamVjdChDaGFuZ2VEZXRlY3RvclJlZik7XHJcbiAgICBuZXdDb21tZW50VGV4dCA9ICcnO1xyXG4gICAgc2hvd0FkZENvbW1lbnRUZXh0QXJlYSA9IGZhbHNlO1xyXG4gICAgc2VuZGluZyA9IGZhbHNlO1xyXG4gICAgYWRkQ29tbWVudCgpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnNlbmRpbmcgPSB0cnVlO1xyXG4gICAgICAgIEJhcnNhQXBpLkJ3LlJ1bkJsTWV0aG9kQXN5bmMoe1xyXG4gICAgICAgICAgICBNZXRob2Q6ICdTYWJ0ZU5hemFyJyxcclxuICAgICAgICAgICAgUGFyYW1ldGVyczogW3RoaXMucG9zdElkLCB0aGlzLm5ld0NvbW1lbnRUZXh0XSxcclxuICAgICAgICAgICAgU3VjY2Vzc0ZuOiAocmVzKSA9PiB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLm9uQWRkQ29tbWVudC5lbWl0KHJlcyk7XHJcbiAgICAgICAgICAgICAgICB0aGlzLnNlbmRpbmcgPSBmYWxzZTtcclxuICAgICAgICAgICAgICAgIHRoaXMuc2hvd0FkZENvbW1lbnRUZXh0QXJlYSA9IGZhbHNlO1xyXG4gICAgICAgICAgICAgICAgdGhpcy5uZXdDb21tZW50VGV4dCA9ICcnO1xyXG4gICAgICAgICAgICAgICAgdGhpcy5fY2RyLm1hcmtGb3JDaGVjaygpO1xyXG4gICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICBGYWlsZWRGbjogKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5zZW5kaW5nID0gZmFsc2U7XHJcbiAgICAgICAgICAgICAgICB0aGlzLl9jZHIubWFya0ZvckNoZWNrKCk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9KTtcclxuICAgIH1cclxufVxyXG4iLCI8ZGl2ICpuZ0lmPVwiIXNob3dBZGRDb21tZW50VGV4dEFyZWFcIiBjbGFzcz1cInctZnVsbCBtdC0yIGZsZXggZ2FwLTNcIj5cclxuICAgIDxhXHJcbiAgICAgICAgZmQtbGlua1xyXG4gICAgICAgIGFyaWEtbGFiZWw9XCJFbXBoYXNpemVkXCJcclxuICAgICAgICBjbGFzcz1cImhvdmVyOmN1cnNvci1wb2ludGVyXCJcclxuICAgICAgICAoY2xpY2spPVwic2hvd0FkZENvbW1lbnRUZXh0QXJlYSA9IHRydWU7IG5ld0NvbW1lbnRUZXh0ID0gJydcIlxyXG4gICAgICAgID7Yp9ix2LPYp9mEINmG2LjYsTwvYVxyXG4gICAgPlxyXG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG48L2Rpdj5cclxuPGRpdiBbY2xhc3MuIWZsZXhdPVwic2hvd0FkZENvbW1lbnRUZXh0QXJlYVwiIGNsYXNzPVwiaGlkZGVuIGl0ZW1zLWVuZCB3LWZ1bGwgZ2FwLTRcIj5cclxuICAgIDx0ZXh0YXJlYVxyXG4gICAgICAgIHJvd3M9XCIzXCJcclxuICAgICAgICBjbGFzcz1cImJsb2NrIHAtMi41IHctZnVsbCB0ZXh0LXNtIHRleHQtZ3JheS05MDAgYmctZ3JheS01MCByb3VuZGVkLWxnIGJvcmRlciBib3JkZXItZ3JheS0zMDBcIlxyXG4gICAgICAgIHBsYWNlaG9sZGVyPVwi2YbYuNixINi02YXYpy4uLlwiXHJcbiAgICAgICAgW2Rpc2FibGVkXT1cInNlbmRpbmdcIlxyXG4gICAgICAgIFsobmdNb2RlbCldPVwibmV3Q29tbWVudFRleHRcIlxyXG4gICAgPjwvdGV4dGFyZWE+XHJcbiAgICA8ZGl2IGNsYXNzPVwiZmxleCBqdXN0aWZ5LWVuZFwiPlxyXG4gICAgICAgIDxidXR0b24gZmQtYnV0dG9uIGZkVHlwZT1cInN0YW5kYXJkXCIgW2Rpc2FibGVkXT1cInNlbmRpbmcgfHwgbmV3Q29tbWVudFRleHQubGVuZ3RoIDwgM1wiIChjbGljayk9XCJhZGRDb21tZW50KClcIj5cclxuICAgICAgICAgICAg2KfYsdiz2KfZhFxyXG4gICAgICAgIDwvYnV0dG9uPlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
|