nuxeo-development-framework 4.0.8 → 4.0.9
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/bundles/nuxeo-development-framework.umd.js +33 -22
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.js +2 -2
- package/esm2015/lib/components/vocabulary/services/vocabulary-api.service.js +14 -13
- package/esm2015/lib/components/vocabulary/translated-vocabulary-select/translated-vocabulary-select.component.js +18 -8
- package/fesm2015/nuxeo-development-framework.js +28 -17
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/vocabulary/services/vocabulary-api.service.d.ts +6 -5
- package/lib/components/vocabulary/translated-vocabulary-select/translated-vocabulary-select.component.d.ts +2 -1
- package/package.json +1 -1
|
@@ -166,7 +166,7 @@ export class DynamicFieldsRendererComponent {
|
|
|
166
166
|
}
|
|
167
167
|
}
|
|
168
168
|
DynamicFieldsRendererComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DynamicFieldsRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
169
|
-
DynamicFieldsRendererComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DynamicFieldsRendererComponent, selector: "app-dynamic-fields-renderer", inputs: { form: "form", agencyNameFilter: "agencyNameFilter", countryNameFilter: "countryNameFilter", mode: "mode", fields: "fields" }, ngImport: i0, template: "<div [formGroup]=\"form\" *ngIf=\"form\">\r\n
|
|
169
|
+
DynamicFieldsRendererComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DynamicFieldsRendererComponent, selector: "app-dynamic-fields-renderer", inputs: { form: "form", agencyNameFilter: "agencyNameFilter", countryNameFilter: "countryNameFilter", mode: "mode", fields: "fields" }, ngImport: i0, template: "<div [formGroup]=\"form\" *ngIf=\"form\">\r\n <div class=\"renderer-container\">\r\n <div class=\"field-container\" *ngFor=\"let field of fields\">\r\n <ng-container\r\n *permission=\"{ name: field.permission, entity: field.formControlName }\"\r\n >\r\n <div class=\"single-field mb-3\" *ngIf=\"field.type === 'text'\">\r\n <div class=\"label-style\">\r\n {{ field.label | translate }}\r\n <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n </div>\r\n <input\r\n class=\"field-style\"\r\n [formControlName]=\"field.formControlName\"\r\n placeholder=\" {{ field.placeholder | translate }}\"\r\n />\r\n </div>\r\n <div class=\"single-field mb-3\" *ngIf=\"field.type === 'number'\">\r\n <div class=\"label-style\">\r\n {{ field.label | translate }}\r\n <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n </div>\r\n <input\r\n min=\"1\"\r\n type=\"number\"\r\n class=\"field-style\"\r\n [formControlName]=\"field.formControlName\"\r\n placeholder=\" {{ field.placeholder | translate }}\"\r\n />\r\n </div>\r\n <div class=\"single-field mb-3\" *ngIf=\"field.type === 'date'\">\r\n <cts-dynamic-form-hijri-dateitem\r\n [formControlName]=\"field.formControlName\"\r\n [label]=\"field.label\"\r\n >\r\n </cts-dynamic-form-hijri-dateitem>\r\n </div>\r\n\r\n <div\r\n class=\"single-field mb-3\"\r\n *ngIf=\"field.type === 'dynamic-vocabulary'\"\r\n >\r\n <app-dynamic-form-vocabulary-item\r\n [label]=\"field.label\"\r\n [bindLabel]=\"field.bindLabel\"\r\n [bindValue]=\"field.bindValue\"\r\n placeholder=\"{{ field.placeholder | translate }}\"\r\n [multiple]=\"field.multiple\"\r\n [searchable]=\"field.searchable\"\r\n [closeOnSelect]=\"field.closeOnSelect\"\r\n [disabled]=\"field.disabled\"\r\n [hideSelectedItems]=\"field.hideSelectedItems\"\r\n [vocabularyType]=\"field.vocabularyType\"\r\n [formControlName]=\"field.formControlName\"\r\n >\r\n </app-dynamic-form-vocabulary-item>\r\n </div>\r\n\r\n <!-- <div class=\"single-field mb-3\" *ngIf=\"field.type === 'department-selector'\">\r\n <div class=\"label-style\">\r\n {{ field.label | translate }}\r\n <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n </div>\r\n <app-dynamic-form-department\r\n [formControlName]=\"field.formControlName\"\r\n [placeholder]=\"field.placeholder\"\r\n [pp_departmentNestedTree]=\"field.pp_departmentNestedTree\"\r\n [pp_departmentTree]=\"field.pp_departmentTree\"\r\n [customPrefix]=\"field.customPrefix\"\r\n [customParentProperty]=\"field.customParentProperty\"\r\n [useCustomAddEditAction]=\"field.useCustomAddEditAction\"\r\n >\r\n </app-dynamic-form-department>\r\n </div> -->\r\n\r\n <div\r\n class=\"single-field mb-3\"\r\n *ngIf=\"field.type === 'translated-vocabulary'\"\r\n >\r\n <app-translated-vocabulary-select\r\n [label]=\"field.label\"\r\n [arbBindLabel]=\"field.arbBindLabel\"\r\n [engBindLabel]=\"field.engBindLabel\"\r\n [bindValue]=\"field.bindValue\"\r\n placeholder=\"{{ field.placeholder | translate }}\"\r\n [multiple]=\"field.multiple\"\r\n [searchable]=\"field.searchable\"\r\n [closeOnSelect]=\"field.closeOnSelect\"\r\n [hideSelectedItems]=\"field.hideSelectedItems\"\r\n [formControlName]=\"field.formControlName\"\r\n [vocbularyId]=\"field.vocbularyId\"\r\n [useFilter]=\"field.useFilter\"\r\n [filter]=\"\r\n field.filter === 'agencyName'\r\n ? agencyNameFilter\r\n : field.filter === 'countryName'\r\n ? countryNameFilter\r\n : {}\r\n \"\r\n [params]=\"field.params || {}\"\r\n [getByDirectorySuggestion]=\"field.getByDirectorySuggestion\"\r\n >\r\n </app-translated-vocabulary-select>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [""], components: [{ type: i1.DynamicFormHijriDateitemComponent, selector: "cts-dynamic-form-hijri-dateitem", inputs: ["minHijri", "maxHijri", "minGreg", "maxGreg", "label", "isDisabled", "range", "vertical", "isReadOnly", "placeholder"], outputs: ["valueChanged"] }, { type: i2.DynamicFormVocabularyItemComponent, selector: "app-dynamic-form-vocabulary-item", inputs: ["bindValue", "bindLabel", "placeholder", "multiple", "searchable", "closeOnSelect", "hideSelectedItems", "disabled", "vocabularyType", "label", "cacheable", "shwoAllValues"], outputs: ["onSelecting"] }, { type: i3.TranslatedVocabularySelectComponent, selector: "app-translated-vocabulary-select", inputs: ["label", "bindValue", "arbBindLabel", "engBindLabel", "placeholder", "multiple", "searchable", "closeOnSelect", "hideSelectedItems", "disabled", "clear", "filter", "useFilter", "vocbularyId", "mapingResponse", "params", "getByDirectorySuggestion"], outputs: ["onSelectItems"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.PermissionsDirective, selector: "[permission]", inputs: ["permission"] }, { type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i5.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { type: i5.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }], pipes: { "translate": i7.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
170
170
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DynamicFieldsRendererComponent, decorators: [{
|
|
171
171
|
type: Component,
|
|
172
172
|
args: [{
|
|
@@ -186,4 +186,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
186
186
|
}], fields: [{
|
|
187
187
|
type: Input
|
|
188
188
|
}] } });
|
|
189
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-fields-renderer.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewEncapsulation , Input } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'app-dynamic-fields-renderer',\r\n  templateUrl: './dynamic-fields-renderer.component.html',\r\n  styleUrls: ['./dynamic-fields-renderer.component.scss'],\r\n  encapsulation : ViewEncapsulation.None\r\n})\r\nexport class DynamicFieldsRendererComponent implements OnInit {\r\n  @Input() form;\r\n  @Input() agencyNameFilter;\r\n  @Input() countryNameFilter;\r\n  @Input() mode = \"add\";\r\n  @Input() fields = [\r\n    {\r\n      type : 'text',\r\n      label : \"CREATE.DOCUMENT_SUBJECT\",\r\n      formControlName : \"subject\",\r\n      placeholder : \"CREATE.DOCUMENT_SUBJECT\",\r\n      required : true,\r\n      permission : 'isHiddenField',\r\n    },\r\n    {\r\n      type : 'text',\r\n      label : \"CREATE.DOCUMENT_NUMBER\",\r\n      formControlName : \"documentNumber\",\r\n      placeholder : \"CREATE.DOCUMENT_NUMBER\",\r\n      required : false,\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'date',\r\n      label : \"CREATE.DOCUMENT_DATE\",\r\n      formControlName : \"gdocumentDate\",\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'dynamic-vocabulary',\r\n      label : \"CREATE.SCRECY_LEVEL\",\r\n      bindLabel : 'label',\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : false,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      disabled : false,\r\n      vocabularyType : 'VOC_SecrecyLevel',\r\n      formControlName : \"secrecyLevel\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'dynamic-vocabulary',\r\n      label : \"CREATE.IMPORTANCE_LEVEL\",\r\n      bindLabel : 'label',\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : false,\r\n      closeOnSelect : true, \r\n      disabled : false,\r\n      hideSelectedItems : false,\r\n      vocabularyType : 'VOC_Importance',\r\n      formControlName : \"importanceLevel\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'department-selector',\r\n      label : \"CREATE.DEPARTMENT_CODE\",\r\n      formControlName : \"departmentCode\",\r\n      placeholder : \"please select department\",\r\n      pp_departmentNestedTree : \"PP_OS_Departments\",\r\n      pp_departmentTree : \"PP_OS_Departments\",\r\n      customPrefix : \"osdept\",\r\n      customParentProperty : \"osdepartment_parentDepartmentCode\",\r\n      useCustomAddEditAction : true,\r\n      required : false,\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'translated-vocabulary',\r\n      label : \"CREATE.AGENCY_CATEGORY_CODE\",\r\n      arbBindLabel : 'label_ar',\r\n      engBindLabel : \"label_en\",\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : false,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      vocbularyId : 'VOC_AgencyCategory',\r\n      formControlName : \"agencyCategoryCode\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      useFilter: false,\r\n      filter : '',\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'translated-vocabulary',\r\n      label : \"CREATE.AGENCY_NAME\",\r\n      arbBindLabel : 'label_ar',\r\n      engBindLabel : \"label_en\",\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : true,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      vocbularyId : 'VOC_Agency',\r\n      formControlName : \"agencyName\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      useFilter: true,\r\n      filter : 'agencyName',\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'translated-vocabulary',\r\n      label : \"CREATE.COUNTRY_CATEGORY_CODE\",\r\n      arbBindLabel : 'label_ar',\r\n      engBindLabel : \"label_en\",\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : true,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      vocbularyId : 'VOC_CountryCategory',\r\n      formControlName : \"countryCategoryCode\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      useFilter: false,\r\n      filter : '',\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'translated-vocabulary',\r\n      label : \"CREATE.COUNTRY_NAME\",\r\n      arbBindLabel : 'label_ar',\r\n      engBindLabel : \"label_en\",\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : true,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      vocbularyId : 'VOC_Country',\r\n      formControlName : \"countryName\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      useFilter: true,\r\n      filter : 'countryName',\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'text',\r\n      label : \"CREATE.REMARKS\",\r\n      formControlName : \"remarks\",\r\n      placeholder : \"CREATE.REMARKS\",\r\n      required : false,\r\n      permission : 'isHiddenField'\r\n    }\r\n  ];\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    if(this.fields.length && this.form) {\r\n      if (this.mode === \"add\") {\r\n        this.form.get(\"secrecyLevel\").patchValue(\"Normal\");\r\n      } else if (this.mode === \"edit\") {\r\n        this.form.get(\"secrecyLevel\").patchValue(this.form.value.secrecyLevel);\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div [formGroup]=\"form\" *ngIf=\"form\">\r\n    <div class=\"renderer-container\">\r\n        <div class=\"field-container\" *ngFor=\"let field of fields\">\r\n            <ng-container *permission=\"{name: field.permission, entity: field.formControlName}\">\r\n                <div class=\"single-field mb-3\" *ngIf=\"field.type === 'text'\">\r\n                    <div class=\"label-style\">\r\n                        {{ field.label | translate}}\r\n                        <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n                    </div>\r\n                    <input class=\"field-style\" [formControlName]=\"field.formControlName\" \r\n                        placeholder=\" {{ field.placeholder | translate}}\"/>\r\n                </div>\r\n                <div class=\"single-field mb-3\" *ngIf=\"field.type === 'number'\">\r\n                    <div class=\"label-style\">\r\n                        {{ field.label | translate}}\r\n                        <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n                    </div>\r\n                    <input min=\"1\" type=\"number\" class=\"field-style\" [formControlName]=\"field.formControlName\" \r\n                        placeholder=\" {{ field.placeholder | translate}}\"/>\r\n                </div>\r\n                <div class=\"single-field mb-3\" *ngIf=\"field.type === 'date'\">             \r\n                    <cts-dynamic-form-hijri-dateitem\r\n                    [formControlName]=\"field.formControlName\"\r\n                    [label]=\"field.label\"\r\n                  >\r\n                  </cts-dynamic-form-hijri-dateitem>\r\n                </div>\r\n            \r\n                <div class=\"single-field mb-3\" *ngIf=\"field.type === 'dynamic-vocabulary'\">\r\n                    <app-dynamic-form-vocabulary-item [label]=\"field.label\" [bindLabel]=\"field.bindLabel\"\r\n                    [bindValue]=\"field.bindValue\" placeholder=\"{{ field.placeholder | translate }}\" [multiple]=\"field.multiple\"\r\n                    [searchable]=\"field.searchable\" [closeOnSelect]=\"field.closeOnSelect\" [disabled]=\"field.disabled\" [hideSelectedItems]=\"field.hideSelectedItems\"\r\n                    [vocabularyType]=\"field.vocabularyType\" \r\n                    [formControlName]=\"field.formControlName\">\r\n                  </app-dynamic-form-vocabulary-item>\r\n                </div>\r\n            \r\n                <!-- <div class=\"single-field mb-3\" *ngIf=\"field.type === 'department-selector'\">\r\n                    <div class=\"label-style\">\r\n                        {{ field.label | translate }}\r\n                        <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n                    </div>\r\n                    <app-dynamic-form-department\r\n                    [formControlName]=\"field.formControlName\"\r\n                    [placeholder]=\"field.placeholder\"\r\n                    [pp_departmentNestedTree]=\"field.pp_departmentNestedTree\"\r\n                    [pp_departmentTree]=\"field.pp_departmentTree\"\r\n                    [customPrefix]=\"field.customPrefix\"\r\n                    [customParentProperty]=\"field.customParentProperty\"\r\n                    [useCustomAddEditAction]=\"field.useCustomAddEditAction\"\r\n                  >\r\n                  </app-dynamic-form-department>\r\n                </div> -->\r\n        \r\n                <div class=\"single-field mb-3\" *ngIf=\"field.type === 'translated-vocabulary'\">\r\n                    <app-translated-vocabulary-select [label]=\"field.label\" [arbBindLabel]=\"field.arbBindLabel\" [engBindLabel]=\"field.engBindLabel\"\r\n                    [bindValue]=\"field.bindValue\" placeholder=\"{{ field.placeholder | translate }}\" [multiple]=\"field.multiple\"\r\n                    [searchable]=\"field.searchable\" [closeOnSelect]=\"field.closeOnSelect\" [hideSelectedItems]=\"field.hideSelectedItems\" [formControlName]=\"field.formControlName\"\r\n                    [vocbularyId]=\"field.vocbularyId\" [useFilter]=\"field.useFilter\" [filter]=\"field.filter === 'agencyName' ? agencyNameFilter : (field.filter === 'countryName' ? countryNameFilter : {})\"\r\n                    [params]=\"field.params || {}\">\r\n                    </app-translated-vocabulary-select>\r\n                </div>\r\n            </ng-container>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-fields-renderer.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewEncapsulation , Input } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'app-dynamic-fields-renderer',\r\n  templateUrl: './dynamic-fields-renderer.component.html',\r\n  styleUrls: ['./dynamic-fields-renderer.component.scss'],\r\n  encapsulation : ViewEncapsulation.None\r\n})\r\nexport class DynamicFieldsRendererComponent implements OnInit {\r\n  @Input() form;\r\n  @Input() agencyNameFilter;\r\n  @Input() countryNameFilter;\r\n  @Input() mode = \"add\";\r\n  @Input() fields = [\r\n    {\r\n      type : 'text',\r\n      label : \"CREATE.DOCUMENT_SUBJECT\",\r\n      formControlName : \"subject\",\r\n      placeholder : \"CREATE.DOCUMENT_SUBJECT\",\r\n      required : true,\r\n      permission : 'isHiddenField',\r\n    },\r\n    {\r\n      type : 'text',\r\n      label : \"CREATE.DOCUMENT_NUMBER\",\r\n      formControlName : \"documentNumber\",\r\n      placeholder : \"CREATE.DOCUMENT_NUMBER\",\r\n      required : false,\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'date',\r\n      label : \"CREATE.DOCUMENT_DATE\",\r\n      formControlName : \"gdocumentDate\",\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'dynamic-vocabulary',\r\n      label : \"CREATE.SCRECY_LEVEL\",\r\n      bindLabel : 'label',\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : false,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      disabled : false,\r\n      vocabularyType : 'VOC_SecrecyLevel',\r\n      formControlName : \"secrecyLevel\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'dynamic-vocabulary',\r\n      label : \"CREATE.IMPORTANCE_LEVEL\",\r\n      bindLabel : 'label',\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : false,\r\n      closeOnSelect : true, \r\n      disabled : false,\r\n      hideSelectedItems : false,\r\n      vocabularyType : 'VOC_Importance',\r\n      formControlName : \"importanceLevel\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'department-selector',\r\n      label : \"CREATE.DEPARTMENT_CODE\",\r\n      formControlName : \"departmentCode\",\r\n      placeholder : \"please select department\",\r\n      pp_departmentNestedTree : \"PP_OS_Departments\",\r\n      pp_departmentTree : \"PP_OS_Departments\",\r\n      customPrefix : \"osdept\",\r\n      customParentProperty : \"osdepartment_parentDepartmentCode\",\r\n      useCustomAddEditAction : true,\r\n      required : false,\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'translated-vocabulary',\r\n      label : \"CREATE.AGENCY_CATEGORY_CODE\",\r\n      arbBindLabel : 'label_ar',\r\n      engBindLabel : \"label_en\",\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : false,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      vocbularyId : 'VOC_AgencyCategory',\r\n      formControlName : \"agencyCategoryCode\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      useFilter: false,\r\n      filter : '',\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'translated-vocabulary',\r\n      label : \"CREATE.AGENCY_NAME\",\r\n      arbBindLabel : 'label_ar',\r\n      engBindLabel : \"label_en\",\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : true,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      vocbularyId : 'VOC_Agency',\r\n      formControlName : \"agencyName\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      useFilter: true,\r\n      filter : 'agencyName',\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'translated-vocabulary',\r\n      label : \"CREATE.COUNTRY_CATEGORY_CODE\",\r\n      arbBindLabel : 'label_ar',\r\n      engBindLabel : \"label_en\",\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : true,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      vocbularyId : 'VOC_CountryCategory',\r\n      formControlName : \"countryCategoryCode\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      useFilter: false,\r\n      filter : '',\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'translated-vocabulary',\r\n      label : \"CREATE.COUNTRY_NAME\",\r\n      arbBindLabel : 'label_ar',\r\n      engBindLabel : \"label_en\",\r\n      bindValue : 'id',\r\n      multiple : false,\r\n      searchable : true,\r\n      closeOnSelect : true, \r\n      hideSelectedItems : false,\r\n      vocbularyId : 'VOC_Country',\r\n      formControlName : \"countryName\",\r\n      placeholder : \"VOCABULARY.SELECT_ITEM\",\r\n      useFilter: true,\r\n      filter : 'countryName',\r\n      permission : 'isHiddenField'\r\n    },\r\n    {\r\n      type : 'text',\r\n      label : \"CREATE.REMARKS\",\r\n      formControlName : \"remarks\",\r\n      placeholder : \"CREATE.REMARKS\",\r\n      required : false,\r\n      permission : 'isHiddenField'\r\n    }\r\n  ];\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    if(this.fields.length && this.form) {\r\n      if (this.mode === \"add\") {\r\n        this.form.get(\"secrecyLevel\").patchValue(\"Normal\");\r\n      } else if (this.mode === \"edit\") {\r\n        this.form.get(\"secrecyLevel\").patchValue(this.form.value.secrecyLevel);\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div [formGroup]=\"form\" *ngIf=\"form\">\r\n  <div class=\"renderer-container\">\r\n    <div class=\"field-container\" *ngFor=\"let field of fields\">\r\n      <ng-container\r\n        *permission=\"{ name: field.permission, entity: field.formControlName }\"\r\n      >\r\n        <div class=\"single-field mb-3\" *ngIf=\"field.type === 'text'\">\r\n          <div class=\"label-style\">\r\n            {{ field.label | translate }}\r\n            <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n          </div>\r\n          <input\r\n            class=\"field-style\"\r\n            [formControlName]=\"field.formControlName\"\r\n            placeholder=\" {{ field.placeholder | translate }}\"\r\n          />\r\n        </div>\r\n        <div class=\"single-field mb-3\" *ngIf=\"field.type === 'number'\">\r\n          <div class=\"label-style\">\r\n            {{ field.label | translate }}\r\n            <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n          </div>\r\n          <input\r\n            min=\"1\"\r\n            type=\"number\"\r\n            class=\"field-style\"\r\n            [formControlName]=\"field.formControlName\"\r\n            placeholder=\" {{ field.placeholder | translate }}\"\r\n          />\r\n        </div>\r\n        <div class=\"single-field mb-3\" *ngIf=\"field.type === 'date'\">\r\n          <cts-dynamic-form-hijri-dateitem\r\n            [formControlName]=\"field.formControlName\"\r\n            [label]=\"field.label\"\r\n          >\r\n          </cts-dynamic-form-hijri-dateitem>\r\n        </div>\r\n\r\n        <div\r\n          class=\"single-field mb-3\"\r\n          *ngIf=\"field.type === 'dynamic-vocabulary'\"\r\n        >\r\n          <app-dynamic-form-vocabulary-item\r\n            [label]=\"field.label\"\r\n            [bindLabel]=\"field.bindLabel\"\r\n            [bindValue]=\"field.bindValue\"\r\n            placeholder=\"{{ field.placeholder | translate }}\"\r\n            [multiple]=\"field.multiple\"\r\n            [searchable]=\"field.searchable\"\r\n            [closeOnSelect]=\"field.closeOnSelect\"\r\n            [disabled]=\"field.disabled\"\r\n            [hideSelectedItems]=\"field.hideSelectedItems\"\r\n            [vocabularyType]=\"field.vocabularyType\"\r\n            [formControlName]=\"field.formControlName\"\r\n          >\r\n          </app-dynamic-form-vocabulary-item>\r\n        </div>\r\n\r\n        <!-- <div class=\"single-field mb-3\" *ngIf=\"field.type === 'department-selector'\">\r\n                    <div class=\"label-style\">\r\n                        {{ field.label | translate }}\r\n                        <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n                    </div>\r\n                    <app-dynamic-form-department\r\n                    [formControlName]=\"field.formControlName\"\r\n                    [placeholder]=\"field.placeholder\"\r\n                    [pp_departmentNestedTree]=\"field.pp_departmentNestedTree\"\r\n                    [pp_departmentTree]=\"field.pp_departmentTree\"\r\n                    [customPrefix]=\"field.customPrefix\"\r\n                    [customParentProperty]=\"field.customParentProperty\"\r\n                    [useCustomAddEditAction]=\"field.useCustomAddEditAction\"\r\n                  >\r\n                  </app-dynamic-form-department>\r\n                </div> -->\r\n\r\n        <div\r\n          class=\"single-field mb-3\"\r\n          *ngIf=\"field.type === 'translated-vocabulary'\"\r\n        >\r\n          <app-translated-vocabulary-select\r\n            [label]=\"field.label\"\r\n            [arbBindLabel]=\"field.arbBindLabel\"\r\n            [engBindLabel]=\"field.engBindLabel\"\r\n            [bindValue]=\"field.bindValue\"\r\n            placeholder=\"{{ field.placeholder | translate }}\"\r\n            [multiple]=\"field.multiple\"\r\n            [searchable]=\"field.searchable\"\r\n            [closeOnSelect]=\"field.closeOnSelect\"\r\n            [hideSelectedItems]=\"field.hideSelectedItems\"\r\n            [formControlName]=\"field.formControlName\"\r\n            [vocbularyId]=\"field.vocbularyId\"\r\n            [useFilter]=\"field.useFilter\"\r\n            [filter]=\"\r\n              field.filter === 'agencyName'\r\n                ? agencyNameFilter\r\n                : field.filter === 'countryName'\r\n                ? countryNameFilter\r\n                : {}\r\n            \"\r\n            [params]=\"field.params || {}\"\r\n            [getByDirectorySuggestion]=\"field.getByDirectorySuggestion\"\r\n          >\r\n          </app-translated-vocabulary-select>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
2
|
import { from } from 'rxjs';
|
|
3
3
|
import { catchError } from 'rxjs/operators';
|
|
4
|
+
import { BaseService } from '../../../shared/services/base/base.service';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "../../../core/services/nuxeo/nuxeo.service";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
7
|
+
export class VocabularyApiService extends BaseService {
|
|
8
|
+
constructor(nuxeoService, injector) {
|
|
9
|
+
super(injector);
|
|
9
10
|
this.nuxeoService = nuxeoService;
|
|
10
|
-
this.
|
|
11
|
-
this.environment = environment;
|
|
11
|
+
this.injector = injector;
|
|
12
12
|
this.vocabular = {};
|
|
13
13
|
}
|
|
14
14
|
getVocabularyList(listName) {
|
|
@@ -20,7 +20,7 @@ export class VocabularyApiService {
|
|
|
20
20
|
actualGetVocabularyList(listName, extraParams = {}) {
|
|
21
21
|
return from(this.nuxeoService.nuxeoClient
|
|
22
22
|
.operation('Directory.SuggestEntries', {})
|
|
23
|
-
.params(Object.assign({ directoryName: listName, dbl10n: false, localize: true, lang: this.
|
|
23
|
+
.params(Object.assign({ directoryName: listName, dbl10n: false, localize: true, lang: this.translateService.currentLang }, extraParams))
|
|
24
24
|
.execute());
|
|
25
25
|
}
|
|
26
26
|
vocabularyOperations(opName, body) {
|
|
@@ -34,16 +34,17 @@ export class VocabularyApiService {
|
|
|
34
34
|
throw err;
|
|
35
35
|
}));
|
|
36
36
|
}
|
|
37
|
+
getVocListByVocName(vocName) {
|
|
38
|
+
const url = `${this.environment.nuxeo}/api/v1/directory/${vocName}`;
|
|
39
|
+
return this.get({ endpoint: url, headers: { properties: '*' } });
|
|
40
|
+
}
|
|
37
41
|
}
|
|
38
|
-
VocabularyApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VocabularyApiService, deps: [{ token: i1.NuxeoService }, { token:
|
|
42
|
+
VocabularyApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VocabularyApiService, deps: [{ token: i1.NuxeoService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
39
43
|
VocabularyApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VocabularyApiService, providedIn: 'root' });
|
|
40
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VocabularyApiService, decorators: [{
|
|
41
45
|
type: Injectable,
|
|
42
46
|
args: [{
|
|
43
47
|
providedIn: 'root',
|
|
44
48
|
}]
|
|
45
|
-
}], ctorParameters: function () { return [{ type: i1.NuxeoService }, { type:
|
|
46
|
-
|
|
47
|
-
args: ['environment']
|
|
48
|
-
}] }]; } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm9jYWJ1bGFyeS1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvdm9jYWJ1bGFyeS9zZXJ2aWNlcy92b2NhYnVsYXJ5LWFwaS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5ELE9BQU8sRUFBRSxJQUFJLEVBQWtCLE1BQU0sTUFBTSxDQUFDO0FBQzVDLE9BQU8sRUFBRSxVQUFVLEVBQU8sTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQU1qRCxNQUFNLE9BQU8sb0JBQW9CO0lBRS9CLFlBQ1UsWUFBMEIsRUFDMUIsU0FBMkIsRUFBaUMsV0FBVztRQUR2RSxpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUMxQixjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQUFpQyxnQkFBVyxHQUFYLFdBQVcsQ0FBQTtRQUhqRixjQUFTLEdBQUcsRUFBRSxDQUFDO0lBSVosQ0FBQztJQUVKLGlCQUFpQixDQUFDLFFBQVE7UUFDeEIsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDL0MsQ0FBQztJQUVELDBCQUEwQixDQUFDLFFBQVEsRUFBRSxNQUFNLEdBQUcsRUFBRSxFQUFDLE1BQU0sR0FBRyxFQUFFLEVBQUUsUUFBUSxHQUFHLElBQUk7UUFDM0UsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUMsUUFBUSxrQkFDMUMsT0FBTyxFQUFFLE1BQU0sRUFDZixVQUFVLEVBQUUsUUFBUSxJQUNqQixNQUFNLEVBQ1QsQ0FBQztJQUNMLENBQUM7SUFFRCx1QkFBdUIsQ0FBQyxRQUFRLEVBQUUsV0FBVyxHQUFHLEVBQUU7UUFDaEQsT0FBTyxJQUFJLENBQ1QsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXO2FBQzFCLFNBQVMsQ0FBQywwQkFBMEIsRUFBRSxFQUFFLENBQUM7YUFDekMsTUFBTSxpQkFDTCxhQUFhLEVBQUUsUUFBUSxFQUN2QixNQUFNLEVBQUUsS0FBSyxFQUNiLFFBQVEsRUFBRSxJQUFJLEVBQ2QsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxJQUM3QixXQUFXLEVBQ2Q7YUFDRCxPQUFPLEVBQUUsQ0FDYixDQUFDO0lBQ0osQ0FBQztJQUVELG9CQUFvQixDQUFDLE1BQWMsRUFBRSxJQUFJO1FBQ3ZDLE9BQU8sSUFBSSxDQUNULElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVzthQUMxQixTQUFTLENBQUMsTUFBTSxFQUFFO1lBQ2pCLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLEVBQUU7U0FDckUsQ0FBQzthQUNELE9BQU8sQ0FBQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsQ0FBQzthQUM3QixPQUFPLEVBQUUsQ0FDYixDQUFDLElBQUksQ0FDSixVQUFVLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUNqQixPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2pCLE1BQU0sR0FBRyxDQUFDO1FBQ1osQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7O2tIQWhEVSxvQkFBb0IsOEVBSWdCLGFBQWE7c0hBSmpELG9CQUFvQixjQUZuQixNQUFNOzRGQUVQLG9CQUFvQjtrQkFIaEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQUt5QyxNQUFNOzJCQUFDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5pbXBvcnQgeyBmcm9tLCBPYnNlcnZhYmxlLCBvZiB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBjYXRjaEVycm9yLCBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcbmltcG9ydCB7IE51eGVvU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL2NvcmUvc2VydmljZXMvbnV4ZW8vbnV4ZW8uc2VydmljZSc7XHJcbmltcG9ydCB7IG9wVHlwZSB9IGZyb20gJy4uL2ludGVyZmFjZXMvb3AtdHlwZS5pbnRlcmZhY2UnO1xyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVm9jYWJ1bGFyeUFwaVNlcnZpY2Uge1xyXG4gIHZvY2FidWxhciA9IHt9O1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBudXhlb1NlcnZpY2U6IE51eGVvU2VydmljZSxcclxuICAgIHByaXZhdGUgdHJhbnNsYXRlOiBUcmFuc2xhdGVTZXJ2aWNlLCBASW5qZWN0KCdlbnZpcm9ubWVudCcpIHByaXZhdGUgZW52aXJvbm1lbnRcclxuICApIHt9XHJcblxyXG4gIGdldFZvY2FidWxhcnlMaXN0KGxpc3ROYW1lKTogT2JzZXJ2YWJsZTxhbnk+IHtcclxuICAgIHJldHVybiB0aGlzLmFjdHVhbEdldFZvY2FidWxhcnlMaXN0KGxpc3ROYW1lKVxyXG4gIH1cclxuXHJcbiAgZ2V0Vm9jYWJ1bGFyeUxpc3RCeUZpbHRlcnMobGlzdE5hbWUsIHBhcmFtcyA9IHt9LGZpbHRlciA9IHt9LCBmdWxsVGV4dCA9IG51bGwpOiBPYnNlcnZhYmxlPGFueT4ge1xyXG4gICAgcmV0dXJuIHRoaXMuYWN0dWFsR2V0Vm9jYWJ1bGFyeUxpc3QobGlzdE5hbWUsIHtcclxuICAgICAgZmlsdGVyczogZmlsdGVyLFxyXG4gICAgICBzZWFyY2hUZXJtOiBmdWxsVGV4dCxcclxuICAgICAgLi4ucGFyYW1zXHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGFjdHVhbEdldFZvY2FidWxhcnlMaXN0KGxpc3ROYW1lLCBleHRyYVBhcmFtcyA9IHt9KTogT2JzZXJ2YWJsZTxhbnk+IHtcclxuICAgIHJldHVybiBmcm9tKFxyXG4gICAgICB0aGlzLm51eGVvU2VydmljZS5udXhlb0NsaWVudFxyXG4gICAgICAgIC5vcGVyYXRpb24oJ0RpcmVjdG9yeS5TdWdnZXN0RW50cmllcycsIHt9KVxyXG4gICAgICAgIC5wYXJhbXMoe1xyXG4gICAgICAgICAgZGlyZWN0b3J5TmFtZTogbGlzdE5hbWUsXHJcbiAgICAgICAgICBkYmwxMG46IGZhbHNlLFxyXG4gICAgICAgICAgbG9jYWxpemU6IHRydWUsXHJcbiAgICAgICAgICBsYW5nOiB0aGlzLnRyYW5zbGF0ZS5jdXJyZW50TGFuZyxcclxuICAgICAgICAgIC4uLmV4dHJhUGFyYW1zXHJcbiAgICAgICAgfSlcclxuICAgICAgICAuZXhlY3V0ZSgpXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgdm9jYWJ1bGFyeU9wZXJhdGlvbnMob3BOYW1lOiBvcFR5cGUsIGJvZHkpIHtcclxuICAgIHJldHVybiBmcm9tKFxyXG4gICAgICB0aGlzLm51eGVvU2VydmljZS5udXhlb0NsaWVudFxyXG4gICAgICAgIC5vcGVyYXRpb24ob3BOYW1lLCB7XHJcbiAgICAgICAgICB1cmw6IGAke3RoaXMuZW52aXJvbm1lbnQubnV4ZW99JHt0aGlzLmVudmlyb25tZW50LmN1c3RvbUF1dG9tYXRpb259YCxcclxuICAgICAgICB9KVxyXG4gICAgICAgIC5jb250ZXh0KHsgdm9jYWJ1bGFyeTogYm9keSB9KVxyXG4gICAgICAgIC5leGVjdXRlKClcclxuICAgICkucGlwZShcclxuICAgICAgY2F0Y2hFcnJvcigoZXJyKSA9PiB7XHJcbiAgICAgICAgY29uc29sZS5sb2coZXJyKTtcclxuICAgICAgICB0aHJvdyBlcnI7XHJcbiAgICAgIH0pXHJcbiAgICApO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
49
|
+
}], ctorParameters: function () { return [{ type: i1.NuxeoService }, { type: i0.Injector }]; } });
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm9jYWJ1bGFyeS1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvdm9jYWJ1bGFyeS9zZXJ2aWNlcy92b2NhYnVsYXJ5LWFwaS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBVSxVQUFVLEVBQVksTUFBTSxlQUFlLENBQUM7QUFFN0QsT0FBTyxFQUFFLElBQUksRUFBa0IsTUFBTSxNQUFNLENBQUM7QUFDNUMsT0FBTyxFQUFFLFVBQVUsRUFBTyxNQUFNLGdCQUFnQixDQUFDO0FBR2pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQzs7O0FBSXpFLE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxXQUFXO0lBRW5ELFlBQ1UsWUFBMEIsRUFDMUIsUUFBa0I7UUFFMUIsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBSFIsaUJBQVksR0FBWixZQUFZLENBQWM7UUFDMUIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUg1QixjQUFTLEdBQUcsRUFBRSxDQUFDO0lBTWYsQ0FBQztJQUVELGlCQUFpQixDQUFDLFFBQVE7UUFDeEIsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDL0MsQ0FBQztJQUVELDBCQUEwQixDQUFDLFFBQVEsRUFBRSxNQUFNLEdBQUcsRUFBRSxFQUFFLE1BQU0sR0FBRyxFQUFFLEVBQUUsUUFBUSxHQUFHLElBQUk7UUFDNUUsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUMsUUFBUSxrQkFDMUMsT0FBTyxFQUFFLE1BQU0sRUFDZixVQUFVLEVBQUUsUUFBUSxJQUNqQixNQUFNLEVBQ1QsQ0FBQztJQUNMLENBQUM7SUFFRCx1QkFBdUIsQ0FBQyxRQUFRLEVBQUUsV0FBVyxHQUFHLEVBQUU7UUFDaEQsT0FBTyxJQUFJLENBQ1QsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXO2FBQzFCLFNBQVMsQ0FBQywwQkFBMEIsRUFBRSxFQUFFLENBQUM7YUFDekMsTUFBTSxpQkFDTCxhQUFhLEVBQUUsUUFBUSxFQUN2QixNQUFNLEVBQUUsS0FBSyxFQUNiLFFBQVEsRUFBRSxJQUFJLEVBQ2QsSUFBSSxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxXQUFXLElBQ3BDLFdBQVcsRUFDZDthQUNELE9BQU8sRUFBRSxDQUNiLENBQUM7SUFDSixDQUFDO0lBRUQsb0JBQW9CLENBQUMsTUFBYyxFQUFFLElBQUk7UUFDdkMsT0FBTyxJQUFJLENBQ1QsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXO2FBQzFCLFNBQVMsQ0FBQyxNQUFNLEVBQUU7WUFDakIsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxnQkFBZ0IsRUFBRTtTQUNyRSxDQUFDO2FBQ0QsT0FBTyxDQUFDLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxDQUFDO2FBQzdCLE9BQU8sRUFBRSxDQUNiLENBQUMsSUFBSSxDQUNKLFVBQVUsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ2pCLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDakIsTUFBTSxHQUFHLENBQUM7UUFDWixDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQztJQUNELG1CQUFtQixDQUFDLE9BQU87UUFDekIsTUFBTSxHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUsscUJBQXFCLE9BQU8sRUFBRSxDQUFDO1FBQ3BFLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsT0FBTyxFQUFFLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN4RSxDQUFDOztrSEF0RFUsb0JBQW9CO3NIQUFwQixvQkFBb0IsY0FGbkIsTUFBTTs0RkFFUCxvQkFBb0I7a0JBSGhDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IGZyb20sIE9ic2VydmFibGUsIG9mIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IGNhdGNoRXJyb3IsIG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgTnV4ZW9TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vY29yZS9zZXJ2aWNlcy9udXhlby9udXhlby5zZXJ2aWNlJztcclxuaW1wb3J0IHsgb3BUeXBlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9vcC10eXBlLmludGVyZmFjZSc7XHJcbmltcG9ydCB7IEJhc2VTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2hhcmVkL3NlcnZpY2VzL2Jhc2UvYmFzZS5zZXJ2aWNlJztcclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIFZvY2FidWxhcnlBcGlTZXJ2aWNlIGV4dGVuZHMgQmFzZVNlcnZpY2Uge1xyXG4gIHZvY2FidWxhciA9IHt9O1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBudXhlb1NlcnZpY2U6IE51eGVvU2VydmljZSxcclxuICAgIHByaXZhdGUgaW5qZWN0b3I6IEluamVjdG9yXHJcbiAgKSB7XHJcbiAgICBzdXBlcihpbmplY3Rvcik7XHJcbiAgfVxyXG5cclxuICBnZXRWb2NhYnVsYXJ5TGlzdChsaXN0TmFtZSk6IE9ic2VydmFibGU8YW55PiB7XHJcbiAgICByZXR1cm4gdGhpcy5hY3R1YWxHZXRWb2NhYnVsYXJ5TGlzdChsaXN0TmFtZSlcclxuICB9XHJcblxyXG4gIGdldFZvY2FidWxhcnlMaXN0QnlGaWx0ZXJzKGxpc3ROYW1lLCBwYXJhbXMgPSB7fSwgZmlsdGVyID0ge30sIGZ1bGxUZXh0ID0gbnVsbCk6IE9ic2VydmFibGU8YW55PiB7XHJcbiAgICByZXR1cm4gdGhpcy5hY3R1YWxHZXRWb2NhYnVsYXJ5TGlzdChsaXN0TmFtZSwge1xyXG4gICAgICBmaWx0ZXJzOiBmaWx0ZXIsXHJcbiAgICAgIHNlYXJjaFRlcm06IGZ1bGxUZXh0LFxyXG4gICAgICAuLi5wYXJhbXNcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgYWN0dWFsR2V0Vm9jYWJ1bGFyeUxpc3QobGlzdE5hbWUsIGV4dHJhUGFyYW1zID0ge30pOiBPYnNlcnZhYmxlPGFueT4ge1xyXG4gICAgcmV0dXJuIGZyb20oXHJcbiAgICAgIHRoaXMubnV4ZW9TZXJ2aWNlLm51eGVvQ2xpZW50XHJcbiAgICAgICAgLm9wZXJhdGlvbignRGlyZWN0b3J5LlN1Z2dlc3RFbnRyaWVzJywge30pXHJcbiAgICAgICAgLnBhcmFtcyh7XHJcbiAgICAgICAgICBkaXJlY3RvcnlOYW1lOiBsaXN0TmFtZSxcclxuICAgICAgICAgIGRibDEwbjogZmFsc2UsXHJcbiAgICAgICAgICBsb2NhbGl6ZTogdHJ1ZSxcclxuICAgICAgICAgIGxhbmc6IHRoaXMudHJhbnNsYXRlU2VydmljZS5jdXJyZW50TGFuZyxcclxuICAgICAgICAgIC4uLmV4dHJhUGFyYW1zXHJcbiAgICAgICAgfSlcclxuICAgICAgICAuZXhlY3V0ZSgpXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgdm9jYWJ1bGFyeU9wZXJhdGlvbnMob3BOYW1lOiBvcFR5cGUsIGJvZHkpIHtcclxuICAgIHJldHVybiBmcm9tKFxyXG4gICAgICB0aGlzLm51eGVvU2VydmljZS5udXhlb0NsaWVudFxyXG4gICAgICAgIC5vcGVyYXRpb24ob3BOYW1lLCB7XHJcbiAgICAgICAgICB1cmw6IGAke3RoaXMuZW52aXJvbm1lbnQubnV4ZW99JHt0aGlzLmVudmlyb25tZW50LmN1c3RvbUF1dG9tYXRpb259YCxcclxuICAgICAgICB9KVxyXG4gICAgICAgIC5jb250ZXh0KHsgdm9jYWJ1bGFyeTogYm9keSB9KVxyXG4gICAgICAgIC5leGVjdXRlKClcclxuICAgICkucGlwZShcclxuICAgICAgY2F0Y2hFcnJvcigoZXJyKSA9PiB7XHJcbiAgICAgICAgY29uc29sZS5sb2coZXJyKTtcclxuICAgICAgICB0aHJvdyBlcnI7XHJcbiAgICAgIH0pXHJcbiAgICApO1xyXG4gIH1cclxuICBnZXRWb2NMaXN0QnlWb2NOYW1lKHZvY05hbWUpOiBPYnNlcnZhYmxlPGFueT4ge1xyXG4gICAgY29uc3QgdXJsID0gYCR7dGhpcy5lbnZpcm9ubWVudC5udXhlb30vYXBpL3YxL2RpcmVjdG9yeS8ke3ZvY05hbWV9YDtcclxuICAgIHJldHVybiB0aGlzLmdldDxhbnk+KHsgZW5kcG9pbnQ6IHVybCwgaGVhZGVyczogeyBwcm9wZXJ0aWVzOiAnKicgfSB9KTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Optional, Output, Self, ViewChild } from '@angular/core';
|
|
2
2
|
import { NgSelectComponent } from '@ng-select/ng-select';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
|
-
import { takeUntil } from 'rxjs/operators';
|
|
4
|
+
import { map, takeUntil } from 'rxjs/operators';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@ngx-translate/core";
|
|
7
7
|
import * as i2 from "../../../core/services/translation/translation.service";
|
|
@@ -33,6 +33,7 @@ export class TranslatedVocabularySelectComponent {
|
|
|
33
33
|
this.loading = false;
|
|
34
34
|
this.mapingResponse = false;
|
|
35
35
|
this.params = {};
|
|
36
|
+
this.getByDirectorySuggestion = true;
|
|
36
37
|
/** event emitted with selected items */
|
|
37
38
|
this.onSelectItems = new EventEmitter();
|
|
38
39
|
this.selection = [];
|
|
@@ -77,20 +78,27 @@ export class TranslatedVocabularySelectComponent {
|
|
|
77
78
|
getlistOfVocabulary() {
|
|
78
79
|
this.loading = true;
|
|
79
80
|
if (this.vocbularyId) {
|
|
80
|
-
this.vocabularyApiServ
|
|
81
|
-
.getVocabularyListByFilters(this.vocbularyId, this.params, this.filter)
|
|
82
|
-
|
|
81
|
+
const observable = (this.getByDirectorySuggestion) ? this.vocabularyApiServ
|
|
82
|
+
.getVocabularyListByFilters(this.vocbularyId, this.params, this.filter).pipe(map(res => {
|
|
83
|
+
let tempArr = [];
|
|
83
84
|
if (this.mapingResponse) {
|
|
84
85
|
res.forEach((element) => {
|
|
85
|
-
|
|
86
|
+
tempArr.push({
|
|
86
87
|
label_ar: element.displayLabel,
|
|
87
88
|
label_en: element.displayLabel,
|
|
88
89
|
});
|
|
89
90
|
});
|
|
90
91
|
}
|
|
91
92
|
else {
|
|
92
|
-
|
|
93
|
+
tempArr = res;
|
|
93
94
|
}
|
|
95
|
+
return tempArr;
|
|
96
|
+
}))
|
|
97
|
+
: this.vocabularyApiServ.getVocListByVocName(this.vocbularyId).pipe(map((res) => {
|
|
98
|
+
return res.entries.map(elem => elem.properties);
|
|
99
|
+
}));
|
|
100
|
+
observable.subscribe((res) => {
|
|
101
|
+
this.data = res;
|
|
94
102
|
this.buffer = (this.data || []).slice(0, this.bufferSize);
|
|
95
103
|
this.loading = false;
|
|
96
104
|
}, err => {
|
|
@@ -154,7 +162,7 @@ export class TranslatedVocabularySelectComponent {
|
|
|
154
162
|
}
|
|
155
163
|
}
|
|
156
164
|
TranslatedVocabularySelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TranslatedVocabularySelectComponent, deps: [{ token: i1.TranslateService }, { token: i2.TranslationService }, { token: i3.VocabularyApiService }, { token: i4.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
157
|
-
TranslatedVocabularySelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TranslatedVocabularySelectComponent, selector: "app-translated-vocabulary-select", inputs: { label: "label", bindValue: "bindValue", arbBindLabel: "arbBindLabel", engBindLabel: "engBindLabel", placeholder: "placeholder", multiple: "multiple", searchable: "searchable", closeOnSelect: "closeOnSelect", hideSelectedItems: "hideSelectedItems", disabled: "disabled", clear: "clear", filter: "filter", useFilter: "useFilter", vocbularyId: "vocbularyId", mapingResponse: "mapingResponse", params: "params" }, outputs: { onSelectItems: "onSelectItems" }, viewQueries: [{ propertyName: "ngSelectComponent", first: true, predicate: NgSelectComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"translated-vocbulary-wrapper\" [ngClass]=\"{'rtl-translated-vocbulary-wrapper' : isArabic === true}\">\r\n <div class=\"vocabulary-title text-base font-bold text-accent-900 mb-0\">\r\n {{label | translate}}\r\n <span *ngIf=\"isRequired()\" class=\"required-flage\">*</span>\r\n </div>\r\n <ng-select\r\n [bindLabel]=\"bindLabel\"\r\n [bindValue]=\"bindValue\"\r\n [placeholder]=\"placeholder\"\r\n [multiple]=\"multiple\"\r\n [clearable]=\"clear\"\r\n [searchable]=\"searchable\"\r\n [closeOnSelect]=\"closeOnSelect\"\r\n [hideSelected]=\"hideSelectedItems\"\r\n [loading]=\"loading\"\r\n (scrollToEnd)=\"onScrollToEnd()\"\r\n (change)=\"emitSelection($event)\"\r\n [disabled]=\"disabled\"\r\n [(ngModel)]=\"selection\"\r\n >\r\n <ng-option *ngFor=\"let option of buffer\" [value]=\"option[bindValue]\">{{isArabic ? option[bindLabel] : option[bindLabel]}}</ng-option>\r\n </ng-select>\r\n</div>\r\n", styles: [".translated-vocbulary-wrapper .vocabulary-title .required-flage{color:#ef4444}.rtl-translated-vocbulary-wrapper{direction:rtl}\n"], components: [{ type: i5.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i5.ɵr, selector: "ng-option", inputs: ["disabled", "value"] }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
165
|
+
TranslatedVocabularySelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TranslatedVocabularySelectComponent, selector: "app-translated-vocabulary-select", inputs: { label: "label", bindValue: "bindValue", arbBindLabel: "arbBindLabel", engBindLabel: "engBindLabel", placeholder: "placeholder", multiple: "multiple", searchable: "searchable", closeOnSelect: "closeOnSelect", hideSelectedItems: "hideSelectedItems", disabled: "disabled", clear: "clear", filter: "filter", useFilter: "useFilter", vocbularyId: "vocbularyId", mapingResponse: "mapingResponse", params: "params", getByDirectorySuggestion: "getByDirectorySuggestion" }, outputs: { onSelectItems: "onSelectItems" }, viewQueries: [{ propertyName: "ngSelectComponent", first: true, predicate: NgSelectComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"translated-vocbulary-wrapper\" [ngClass]=\"{'rtl-translated-vocbulary-wrapper' : isArabic === true}\">\r\n <div class=\"vocabulary-title text-base font-bold text-accent-900 mb-0\">\r\n {{label | translate}}\r\n <span *ngIf=\"isRequired()\" class=\"required-flage\">*</span>\r\n </div>\r\n <ng-select\r\n [bindLabel]=\"bindLabel\"\r\n [bindValue]=\"bindValue\"\r\n [placeholder]=\"placeholder\"\r\n [multiple]=\"multiple\"\r\n [clearable]=\"clear\"\r\n [searchable]=\"searchable\"\r\n [closeOnSelect]=\"closeOnSelect\"\r\n [hideSelected]=\"hideSelectedItems\"\r\n [loading]=\"loading\"\r\n (scrollToEnd)=\"onScrollToEnd()\"\r\n (change)=\"emitSelection($event)\"\r\n [disabled]=\"disabled\"\r\n [(ngModel)]=\"selection\"\r\n >\r\n <ng-option *ngFor=\"let option of buffer\" [value]=\"option[bindValue]\">{{isArabic ? option[bindLabel] : option[bindLabel]}}</ng-option>\r\n </ng-select>\r\n</div>\r\n", styles: [".translated-vocbulary-wrapper .vocabulary-title .required-flage{color:#ef4444}.rtl-translated-vocbulary-wrapper{direction:rtl}\n"], components: [{ type: i5.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i5.ɵr, selector: "ng-option", inputs: ["disabled", "value"] }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
158
166
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TranslatedVocabularySelectComponent, decorators: [{
|
|
159
167
|
type: Component,
|
|
160
168
|
args: [{
|
|
@@ -201,7 +209,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
201
209
|
type: Input
|
|
202
210
|
}], params: [{
|
|
203
211
|
type: Input
|
|
212
|
+
}], getByDirectorySuggestion: [{
|
|
213
|
+
type: Input
|
|
204
214
|
}], onSelectItems: [{
|
|
205
215
|
type: Output
|
|
206
216
|
}] } });
|
|
207
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translated-vocabulary-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/vocabulary/translated-vocabulary-select/translated-vocabulary-select.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/vocabulary/translated-vocabulary-select/translated-vocabulary-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnDestroy, Optional, Output, Self, ViewChild } from '@angular/core';\r\nimport { AbstractControl, ControlValueAccessor, FormControl, NgControl } from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { TranslationService } from '../../../core/services/translation/translation.service';\r\nimport { VocabularyApiService } from '../services/vocabulary-api.service';\r\nimport { filter } from 'lodash';\r\n\r\n@Component({\r\n    selector: 'app-translated-vocabulary-select',\r\n    templateUrl: './translated-vocabulary-select.component.html',\r\n    styleUrls: ['./translated-vocabulary-select.component.scss'],\r\n})\r\nexport class TranslatedVocabularySelectComponent\r\n    implements OnChanges, OnDestroy, ControlValueAccessor\r\n{\r\n    @ViewChild(NgSelectComponent) ngSelectComponent: NgSelectComponent;\r\n    /** Field Label */\r\n    @Input() label: string;\r\n    /** Property name to bind value to */\r\n    @Input() bindValue;\r\n    /** Property name to bind label to */\r\n    @Input() arbBindLabel;\r\n    /** Property name to bind label to */\r\n    @Input() engBindLabel;\r\n    /** Items array */\r\n    // @Input() data;\r\n    /** Placeholder string */\r\n    @Input() placeholder;\r\n    /** can select multiple */\r\n    @Input() multiple = false;\r\n    /** is searchable */\r\n    @Input() searchable = false;\r\n    /** should close on select */\r\n    @Input() closeOnSelect = true;\r\n    /** should hide selected items */\r\n    @Input() hideSelectedItems = false;\r\n    /** is disabled */\r\n    @Input() disabled = false;\r\n    /** should show clear action */\r\n    @Input() clear = true;\r\n    /** filter to be sent from out side to send it in api to filter the vocabulary items */\r\n    @Input() filter;\r\n    /** flage to indicate if call api without filter or wait untile there is filter and then call api*/\r\n    @Input() useFilter = true;\r\n\r\n    /** is vocabulary select */\r\n    // @Input() voc = false;\r\n    /** vocabulary id for translation (for vocabulary select only) */\r\n    @Input() vocbularyId: string;\r\n    /** Should show loading indicator */\r\n    loading = false;\r\n    @Input() mapingResponse = false;\r\n\r\n    @Input() params = {};\r\n    /** event emitted with selected items */\r\n    @Output() onSelectItems = new EventEmitter();\r\n\r\n    bindLabel;\r\n    selection = [];\r\n    data = [];\r\n    buffer = [];\r\n    bufferSize = 50;\r\n    numberOfItemsFromEndBeforeFetchingMore = 10;\r\n    private _unsubscribeAll: Subject<any> = new Subject<any>();\r\n    isArabic = false;\r\n    propagateChange: any = () => {};\r\n    validateFn: any = () => {};\r\n\r\n    public onTouched: any = () => {\r\n        /*Empty*/\r\n    };\r\n    public get invalid(): boolean {\r\n        return this.control ? this.control.invalid : false;\r\n    }\r\n\r\n    public get showError(): boolean {\r\n        if (!this.control) {\r\n            return false;\r\n        }\r\n\r\n        const { dirty, touched } = this.control;\r\n\r\n        return this.invalid ? dirty || touched : false;\r\n    }\r\n    constructor(\r\n        public translate: TranslateService,\r\n        private translationService: TranslationService,\r\n        private vocabularyApiServ: VocabularyApiService,\r\n        @Self() @Optional() public control: NgControl\r\n    ) {\r\n        if (this.control) {\r\n            this.control.valueAccessor = this;\r\n        }\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.translationService.isArabic\r\n            .pipe(takeUntil(this._unsubscribeAll))\r\n            .subscribe((res) => {\r\n                this.isArabic = res;\r\n                this.bindLabel = this.isArabic\r\n                    ? this.arbBindLabel\r\n                    : this.engBindLabel;\r\n            });\r\n        if (!this.useFilter) {\r\n            this.getlistOfVocabulary();\r\n        }\r\n    }\r\n\r\n    getlistOfVocabulary() {\r\n        this.loading = true;\r\n        if (this.vocbularyId) {\r\n            this.vocabularyApiServ\r\n                .getVocabularyListByFilters(this.vocbularyId, this.params, this.filter)\r\n                .subscribe((res) => {\r\n                    if (this.mapingResponse) {\r\n                        res.forEach((element) => {\r\n                            this.data.push({\r\n                                label_ar: element.displayLabel,\r\n                                label_en: element.displayLabel,\r\n                            });\r\n                        });\r\n                    } else {\r\n                        this.data = res;\r\n                    }\r\n                    this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n                    this.loading = false;\r\n                }, err => {\r\n                    this.loading = false;\r\n                });\r\n        }\r\n    }\r\n\r\n    ngOnChanges(changes): void {\r\n        if (this.useFilter && changes.filter && changes.filter.currentValue) {\r\n            this.getlistOfVocabulary();\r\n        }\r\n    }\r\n\r\n    emitSelection(event) {\r\n        this.propagateChange(this.selection);\r\n        this.onSelectItems.emit(event);\r\n    }\r\n\r\n    onScrollToEnd() {\r\n        this.fetchMore();\r\n    }\r\n\r\n    private fetchMore() {\r\n        this.loading = true;\r\n        const len = this.buffer.length;\r\n        const more = this.data.slice(len, this.bufferSize + len);\r\n        this.buffer = this.data.concat(more);\r\n        this.loading = false;\r\n    }\r\n\r\n    writeValue(value) {\r\n        if (value) {\r\n            this.selection = value;\r\n        } else {\r\n            //added to allow reseting ui when resetting form\r\n            this.selection = [];\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn) {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any) {\r\n        this.onTouched = fn;\r\n    }\r\n\r\n    validate(c: FormControl) {\r\n        return this.validateFn(c);\r\n    }\r\n\r\n    isRequired() {\r\n        if (!this.control || !this.control.control.validator) {\r\n            return false;\r\n        }\r\n\r\n        const validator = this.control.control.validator({} as AbstractControl);\r\n        return validator && validator.required;\r\n    }\r\n\r\n    hasErrors(): boolean {\r\n        return this.showError;\r\n    }\r\n    reset() {\r\n        this.ngSelectComponent.handleClearClick();\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._unsubscribeAll.next();\r\n        this._unsubscribeAll.complete();\r\n    }\r\n    // onSearch =  (term: string, item: any) => {\r\n    //   let key = '';\r\n    //   this.voc ? key =  \"vocabulary.\" + this.vocId + \".\" + item.id : key = item.label;\r\n    //   let value = this.translate.instant(key);\r\n    //     if(value){\r\n    //       return value.toLowerCase().includes(term);\r\n    //     }else{\r\n    //       return item.label.includes(term);\r\n    //     }\r\n\r\n    // }\r\n}\r\n","<div class=\"translated-vocbulary-wrapper\" [ngClass]=\"{'rtl-translated-vocbulary-wrapper' : isArabic === true}\">\r\n        <div class=\"vocabulary-title text-base font-bold text-accent-900 mb-0\">\r\n            {{label | translate}}\r\n            <span *ngIf=\"isRequired()\" class=\"required-flage\">*</span>\r\n        </div>\r\n        <ng-select\r\n            [bindLabel]=\"bindLabel\"\r\n            [bindValue]=\"bindValue\"\r\n            [placeholder]=\"placeholder\"\r\n            [multiple]=\"multiple\"\r\n            [clearable]=\"clear\"\r\n            [searchable]=\"searchable\"\r\n            [closeOnSelect]=\"closeOnSelect\"\r\n            [hideSelected]=\"hideSelectedItems\"\r\n            [loading]=\"loading\"\r\n            (scrollToEnd)=\"onScrollToEnd()\"\r\n            (change)=\"emitSelection($event)\"\r\n            [disabled]=\"disabled\"\r\n            [(ngModel)]=\"selection\"\r\n        >\r\n        <ng-option *ngFor=\"let option of buffer\" [value]=\"option[bindValue]\">{{isArabic ? option[bindLabel] : option[bindLabel]}}</ng-option>\r\n        </ng-select>\r\n</div>\r\n"]}
|
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translated-vocabulary-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/vocabulary/translated-vocabulary-select/translated-vocabulary-select.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/vocabulary/translated-vocabulary-select/translated-vocabulary-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnDestroy, Optional, Output, Self, ViewChild } from '@angular/core';\r\nimport { AbstractControl, ControlValueAccessor, FormControl, NgControl } from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\n\r\nimport { TranslationService } from '../../../core/services/translation/translation.service';\r\nimport { VocabularyApiService } from '../services/vocabulary-api.service';\r\nimport { filter } from 'lodash';\r\n\r\n@Component({\r\n    selector: 'app-translated-vocabulary-select',\r\n    templateUrl: './translated-vocabulary-select.component.html',\r\n    styleUrls: ['./translated-vocabulary-select.component.scss'],\r\n})\r\nexport class TranslatedVocabularySelectComponent\r\n    implements OnChanges, OnDestroy, ControlValueAccessor {\r\n    @ViewChild(NgSelectComponent) ngSelectComponent: NgSelectComponent;\r\n    /** Field Label */\r\n    @Input() label: string;\r\n    /** Property name to bind value to */\r\n    @Input() bindValue;\r\n    /** Property name to bind label to */\r\n    @Input() arbBindLabel;\r\n    /** Property name to bind label to */\r\n    @Input() engBindLabel;\r\n    /** Items array */\r\n    // @Input() data;\r\n    /** Placeholder string */\r\n    @Input() placeholder;\r\n    /** can select multiple */\r\n    @Input() multiple = false;\r\n    /** is searchable */\r\n    @Input() searchable = false;\r\n    /** should close on select */\r\n    @Input() closeOnSelect = true;\r\n    /** should hide selected items */\r\n    @Input() hideSelectedItems = false;\r\n    /** is disabled */\r\n    @Input() disabled = false;\r\n    /** should show clear action */\r\n    @Input() clear = true;\r\n    /** filter to be sent from out side to send it in api to filter the vocabulary items */\r\n    @Input() filter;\r\n    /** flage to indicate if call api without filter or wait untile there is filter and then call api*/\r\n    @Input() useFilter = true;\r\n\r\n    /** is vocabulary select */\r\n    // @Input() voc = false;\r\n    /** vocabulary id for translation (for vocabulary select only) */\r\n    @Input() vocbularyId: string;\r\n    /** Should show loading indicator */\r\n    loading = false;\r\n    @Input() mapingResponse = false;\r\n\r\n    @Input() params = {};\r\n    @Input() getByDirectorySuggestion: boolean = true;\r\n    /** event emitted with selected items */\r\n    @Output() onSelectItems = new EventEmitter();\r\n\r\n    bindLabel;\r\n    selection = [];\r\n    data = [];\r\n    buffer = [];\r\n    bufferSize = 50;\r\n    numberOfItemsFromEndBeforeFetchingMore = 10;\r\n    private _unsubscribeAll: Subject<any> = new Subject<any>();\r\n    isArabic = false;\r\n    propagateChange: any = () => { };\r\n    validateFn: any = () => { };\r\n\r\n    public onTouched: any = () => {\r\n        /*Empty*/\r\n    };\r\n    public get invalid(): boolean {\r\n        return this.control ? this.control.invalid : false;\r\n    }\r\n\r\n    public get showError(): boolean {\r\n        if (!this.control) {\r\n            return false;\r\n        }\r\n\r\n        const { dirty, touched } = this.control;\r\n\r\n        return this.invalid ? dirty || touched : false;\r\n    }\r\n    constructor(\r\n        public translate: TranslateService,\r\n        private translationService: TranslationService,\r\n        private vocabularyApiServ: VocabularyApiService,\r\n        @Self() @Optional() public control: NgControl\r\n    ) {\r\n        if (this.control) {\r\n            this.control.valueAccessor = this;\r\n        }\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.translationService.isArabic\r\n            .pipe(takeUntil(this._unsubscribeAll))\r\n            .subscribe((res) => {\r\n                this.isArabic = res;\r\n                this.bindLabel = this.isArabic\r\n                    ? this.arbBindLabel\r\n                    : this.engBindLabel;\r\n            });\r\n        if (!this.useFilter) {\r\n            this.getlistOfVocabulary();\r\n        }\r\n    }\r\n\r\n    getlistOfVocabulary() {\r\n        this.loading = true;\r\n        if (this.vocbularyId) {\r\n            const observable: Observable<any> = (this.getByDirectorySuggestion) ? this.vocabularyApiServ\r\n                .getVocabularyListByFilters(this.vocbularyId, this.params, this.filter).pipe(map(res => {\r\n                    let tempArr = [];\r\n                    if (this.mapingResponse) {\r\n                        res.forEach((element) => {\r\n                            tempArr.push({\r\n                                label_ar: element.displayLabel,\r\n                                label_en: element.displayLabel,\r\n                            });\r\n                        });\r\n                    } else {\r\n                        tempArr = res;\r\n                    }\r\n                    return tempArr;\r\n                }))\r\n                : this.vocabularyApiServ.getVocListByVocName(this.vocbularyId).pipe(map((res: { entries: Array<Record<string, any>> }) => {\r\n                    return res.entries.map(elem => elem.properties);\r\n                }))\r\n            observable.subscribe((res) => {\r\n                this.data = res;\r\n                this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n                this.loading = false;\r\n            }, err => {\r\n                this.loading = false;\r\n            });\r\n        }\r\n    }\r\n\r\n    ngOnChanges(changes): void {\r\n        if (this.useFilter && changes.filter && changes.filter.currentValue) {\r\n            this.getlistOfVocabulary();\r\n        }\r\n    }\r\n\r\n    emitSelection(event) {\r\n        this.propagateChange(this.selection);\r\n        this.onSelectItems.emit(event);\r\n    }\r\n\r\n    onScrollToEnd() {\r\n        this.fetchMore();\r\n    }\r\n\r\n    private fetchMore() {\r\n        this.loading = true;\r\n        const len = this.buffer.length;\r\n        const more = this.data.slice(len, this.bufferSize + len);\r\n        this.buffer = this.data.concat(more);\r\n        this.loading = false;\r\n    }\r\n\r\n    writeValue(value) {\r\n        if (value) {\r\n            this.selection = value;\r\n        } else {\r\n            //added to allow reseting ui when resetting form\r\n            this.selection = [];\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn) {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any) {\r\n        this.onTouched = fn;\r\n    }\r\n\r\n    validate(c: FormControl) {\r\n        return this.validateFn(c);\r\n    }\r\n\r\n    isRequired() {\r\n        if (!this.control || !this.control.control.validator) {\r\n            return false;\r\n        }\r\n\r\n        const validator = this.control.control.validator({} as AbstractControl);\r\n        return validator && validator.required;\r\n    }\r\n\r\n    hasErrors(): boolean {\r\n        return this.showError;\r\n    }\r\n    reset() {\r\n        this.ngSelectComponent.handleClearClick();\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._unsubscribeAll.next();\r\n        this._unsubscribeAll.complete();\r\n    }\r\n    // onSearch =  (term: string, item: any) => {\r\n    //   let key = '';\r\n    //   this.voc ? key =  \"vocabulary.\" + this.vocId + \".\" + item.id : key = item.label;\r\n    //   let value = this.translate.instant(key);\r\n    //     if(value){\r\n    //       return value.toLowerCase().includes(term);\r\n    //     }else{\r\n    //       return item.label.includes(term);\r\n    //     }\r\n\r\n    // }\r\n}\r\n","<div class=\"translated-vocbulary-wrapper\" [ngClass]=\"{'rtl-translated-vocbulary-wrapper' : isArabic === true}\">\r\n        <div class=\"vocabulary-title text-base font-bold text-accent-900 mb-0\">\r\n            {{label | translate}}\r\n            <span *ngIf=\"isRequired()\" class=\"required-flage\">*</span>\r\n        </div>\r\n        <ng-select\r\n            [bindLabel]=\"bindLabel\"\r\n            [bindValue]=\"bindValue\"\r\n            [placeholder]=\"placeholder\"\r\n            [multiple]=\"multiple\"\r\n            [clearable]=\"clear\"\r\n            [searchable]=\"searchable\"\r\n            [closeOnSelect]=\"closeOnSelect\"\r\n            [hideSelected]=\"hideSelectedItems\"\r\n            [loading]=\"loading\"\r\n            (scrollToEnd)=\"onScrollToEnd()\"\r\n            (change)=\"emitSelection($event)\"\r\n            [disabled]=\"disabled\"\r\n            [(ngModel)]=\"selection\"\r\n        >\r\n        <ng-option *ngFor=\"let option of buffer\" [value]=\"option[bindValue]\">{{isArabic ? option[bindLabel] : option[bindLabel]}}</ng-option>\r\n        </ng-select>\r\n</div>\r\n"]}
|
|
@@ -4865,11 +4865,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
4865
4865
|
type: Output
|
|
4866
4866
|
}] } });
|
|
4867
4867
|
|
|
4868
|
-
class VocabularyApiService {
|
|
4869
|
-
constructor(nuxeoService,
|
|
4868
|
+
class VocabularyApiService extends BaseService {
|
|
4869
|
+
constructor(nuxeoService, injector) {
|
|
4870
|
+
super(injector);
|
|
4870
4871
|
this.nuxeoService = nuxeoService;
|
|
4871
|
-
this.
|
|
4872
|
-
this.environment = environment;
|
|
4872
|
+
this.injector = injector;
|
|
4873
4873
|
this.vocabular = {};
|
|
4874
4874
|
}
|
|
4875
4875
|
getVocabularyList(listName) {
|
|
@@ -4881,7 +4881,7 @@ class VocabularyApiService {
|
|
|
4881
4881
|
actualGetVocabularyList(listName, extraParams = {}) {
|
|
4882
4882
|
return from(this.nuxeoService.nuxeoClient
|
|
4883
4883
|
.operation('Directory.SuggestEntries', {})
|
|
4884
|
-
.params(Object.assign({ directoryName: listName, dbl10n: false, localize: true, lang: this.
|
|
4884
|
+
.params(Object.assign({ directoryName: listName, dbl10n: false, localize: true, lang: this.translateService.currentLang }, extraParams))
|
|
4885
4885
|
.execute());
|
|
4886
4886
|
}
|
|
4887
4887
|
vocabularyOperations(opName, body) {
|
|
@@ -4895,18 +4895,19 @@ class VocabularyApiService {
|
|
|
4895
4895
|
throw err;
|
|
4896
4896
|
}));
|
|
4897
4897
|
}
|
|
4898
|
+
getVocListByVocName(vocName) {
|
|
4899
|
+
const url = `${this.environment.nuxeo}/api/v1/directory/${vocName}`;
|
|
4900
|
+
return this.get({ endpoint: url, headers: { properties: '*' } });
|
|
4901
|
+
}
|
|
4898
4902
|
}
|
|
4899
|
-
VocabularyApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VocabularyApiService, deps: [{ token: NuxeoService }, { token:
|
|
4903
|
+
VocabularyApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VocabularyApiService, deps: [{ token: NuxeoService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
4900
4904
|
VocabularyApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VocabularyApiService, providedIn: 'root' });
|
|
4901
4905
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VocabularyApiService, decorators: [{
|
|
4902
4906
|
type: Injectable,
|
|
4903
4907
|
args: [{
|
|
4904
4908
|
providedIn: 'root',
|
|
4905
4909
|
}]
|
|
4906
|
-
}], ctorParameters: function () { return [{ type: NuxeoService }, { type:
|
|
4907
|
-
type: Inject,
|
|
4908
|
-
args: ['environment']
|
|
4909
|
-
}] }]; } });
|
|
4910
|
+
}], ctorParameters: function () { return [{ type: NuxeoService }, { type: i0.Injector }]; } });
|
|
4910
4911
|
|
|
4911
4912
|
/**
|
|
4912
4913
|
* A vocabulary dropdown input integrated with nuxeo vocabulary API,
|
|
@@ -20177,6 +20178,7 @@ class TranslatedVocabularySelectComponent {
|
|
|
20177
20178
|
this.loading = false;
|
|
20178
20179
|
this.mapingResponse = false;
|
|
20179
20180
|
this.params = {};
|
|
20181
|
+
this.getByDirectorySuggestion = true;
|
|
20180
20182
|
/** event emitted with selected items */
|
|
20181
20183
|
this.onSelectItems = new EventEmitter();
|
|
20182
20184
|
this.selection = [];
|
|
@@ -20221,20 +20223,27 @@ class TranslatedVocabularySelectComponent {
|
|
|
20221
20223
|
getlistOfVocabulary() {
|
|
20222
20224
|
this.loading = true;
|
|
20223
20225
|
if (this.vocbularyId) {
|
|
20224
|
-
this.vocabularyApiServ
|
|
20225
|
-
.getVocabularyListByFilters(this.vocbularyId, this.params, this.filter)
|
|
20226
|
-
|
|
20226
|
+
const observable = (this.getByDirectorySuggestion) ? this.vocabularyApiServ
|
|
20227
|
+
.getVocabularyListByFilters(this.vocbularyId, this.params, this.filter).pipe(map(res => {
|
|
20228
|
+
let tempArr = [];
|
|
20227
20229
|
if (this.mapingResponse) {
|
|
20228
20230
|
res.forEach((element) => {
|
|
20229
|
-
|
|
20231
|
+
tempArr.push({
|
|
20230
20232
|
label_ar: element.displayLabel,
|
|
20231
20233
|
label_en: element.displayLabel,
|
|
20232
20234
|
});
|
|
20233
20235
|
});
|
|
20234
20236
|
}
|
|
20235
20237
|
else {
|
|
20236
|
-
|
|
20238
|
+
tempArr = res;
|
|
20237
20239
|
}
|
|
20240
|
+
return tempArr;
|
|
20241
|
+
}))
|
|
20242
|
+
: this.vocabularyApiServ.getVocListByVocName(this.vocbularyId).pipe(map((res) => {
|
|
20243
|
+
return res.entries.map(elem => elem.properties);
|
|
20244
|
+
}));
|
|
20245
|
+
observable.subscribe((res) => {
|
|
20246
|
+
this.data = res;
|
|
20238
20247
|
this.buffer = (this.data || []).slice(0, this.bufferSize);
|
|
20239
20248
|
this.loading = false;
|
|
20240
20249
|
}, err => {
|
|
@@ -20298,7 +20307,7 @@ class TranslatedVocabularySelectComponent {
|
|
|
20298
20307
|
}
|
|
20299
20308
|
}
|
|
20300
20309
|
TranslatedVocabularySelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TranslatedVocabularySelectComponent, deps: [{ token: i1.TranslateService }, { token: TranslationService }, { token: VocabularyApiService }, { token: i6.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
20301
|
-
TranslatedVocabularySelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TranslatedVocabularySelectComponent, selector: "app-translated-vocabulary-select", inputs: { label: "label", bindValue: "bindValue", arbBindLabel: "arbBindLabel", engBindLabel: "engBindLabel", placeholder: "placeholder", multiple: "multiple", searchable: "searchable", closeOnSelect: "closeOnSelect", hideSelectedItems: "hideSelectedItems", disabled: "disabled", clear: "clear", filter: "filter", useFilter: "useFilter", vocbularyId: "vocbularyId", mapingResponse: "mapingResponse", params: "params" }, outputs: { onSelectItems: "onSelectItems" }, viewQueries: [{ propertyName: "ngSelectComponent", first: true, predicate: NgSelectComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"translated-vocbulary-wrapper\" [ngClass]=\"{'rtl-translated-vocbulary-wrapper' : isArabic === true}\">\r\n <div class=\"vocabulary-title text-base font-bold text-accent-900 mb-0\">\r\n {{label | translate}}\r\n <span *ngIf=\"isRequired()\" class=\"required-flage\">*</span>\r\n </div>\r\n <ng-select\r\n [bindLabel]=\"bindLabel\"\r\n [bindValue]=\"bindValue\"\r\n [placeholder]=\"placeholder\"\r\n [multiple]=\"multiple\"\r\n [clearable]=\"clear\"\r\n [searchable]=\"searchable\"\r\n [closeOnSelect]=\"closeOnSelect\"\r\n [hideSelected]=\"hideSelectedItems\"\r\n [loading]=\"loading\"\r\n (scrollToEnd)=\"onScrollToEnd()\"\r\n (change)=\"emitSelection($event)\"\r\n [disabled]=\"disabled\"\r\n [(ngModel)]=\"selection\"\r\n >\r\n <ng-option *ngFor=\"let option of buffer\" [value]=\"option[bindValue]\">{{isArabic ? option[bindLabel] : option[bindLabel]}}</ng-option>\r\n </ng-select>\r\n</div>\r\n", styles: [".translated-vocbulary-wrapper .vocabulary-title .required-flage{color:#ef4444}.rtl-translated-vocbulary-wrapper{direction:rtl}\n"], components: [{ type: i5.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i5.ɵr, selector: "ng-option", inputs: ["disabled", "value"] }], directives: [{ type: i4$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i4$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
20310
|
+
TranslatedVocabularySelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TranslatedVocabularySelectComponent, selector: "app-translated-vocabulary-select", inputs: { label: "label", bindValue: "bindValue", arbBindLabel: "arbBindLabel", engBindLabel: "engBindLabel", placeholder: "placeholder", multiple: "multiple", searchable: "searchable", closeOnSelect: "closeOnSelect", hideSelectedItems: "hideSelectedItems", disabled: "disabled", clear: "clear", filter: "filter", useFilter: "useFilter", vocbularyId: "vocbularyId", mapingResponse: "mapingResponse", params: "params", getByDirectorySuggestion: "getByDirectorySuggestion" }, outputs: { onSelectItems: "onSelectItems" }, viewQueries: [{ propertyName: "ngSelectComponent", first: true, predicate: NgSelectComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"translated-vocbulary-wrapper\" [ngClass]=\"{'rtl-translated-vocbulary-wrapper' : isArabic === true}\">\r\n <div class=\"vocabulary-title text-base font-bold text-accent-900 mb-0\">\r\n {{label | translate}}\r\n <span *ngIf=\"isRequired()\" class=\"required-flage\">*</span>\r\n </div>\r\n <ng-select\r\n [bindLabel]=\"bindLabel\"\r\n [bindValue]=\"bindValue\"\r\n [placeholder]=\"placeholder\"\r\n [multiple]=\"multiple\"\r\n [clearable]=\"clear\"\r\n [searchable]=\"searchable\"\r\n [closeOnSelect]=\"closeOnSelect\"\r\n [hideSelected]=\"hideSelectedItems\"\r\n [loading]=\"loading\"\r\n (scrollToEnd)=\"onScrollToEnd()\"\r\n (change)=\"emitSelection($event)\"\r\n [disabled]=\"disabled\"\r\n [(ngModel)]=\"selection\"\r\n >\r\n <ng-option *ngFor=\"let option of buffer\" [value]=\"option[bindValue]\">{{isArabic ? option[bindLabel] : option[bindLabel]}}</ng-option>\r\n </ng-select>\r\n</div>\r\n", styles: [".translated-vocbulary-wrapper .vocabulary-title .required-flage{color:#ef4444}.rtl-translated-vocbulary-wrapper{direction:rtl}\n"], components: [{ type: i5.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i5.ɵr, selector: "ng-option", inputs: ["disabled", "value"] }], directives: [{ type: i4$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i4$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
20302
20311
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TranslatedVocabularySelectComponent, decorators: [{
|
|
20303
20312
|
type: Component,
|
|
20304
20313
|
args: [{
|
|
@@ -20345,6 +20354,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
20345
20354
|
type: Input
|
|
20346
20355
|
}], params: [{
|
|
20347
20356
|
type: Input
|
|
20357
|
+
}], getByDirectorySuggestion: [{
|
|
20358
|
+
type: Input
|
|
20348
20359
|
}], onSelectItems: [{
|
|
20349
20360
|
type: Output
|
|
20350
20361
|
}] } });
|
|
@@ -20508,7 +20519,7 @@ class DynamicFieldsRendererComponent {
|
|
|
20508
20519
|
}
|
|
20509
20520
|
}
|
|
20510
20521
|
DynamicFieldsRendererComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DynamicFieldsRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
20511
|
-
DynamicFieldsRendererComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DynamicFieldsRendererComponent, selector: "app-dynamic-fields-renderer", inputs: { form: "form", agencyNameFilter: "agencyNameFilter", countryNameFilter: "countryNameFilter", mode: "mode", fields: "fields" }, ngImport: i0, template: "<div [formGroup]=\"form\" *ngIf=\"form\">\r\n
|
|
20522
|
+
DynamicFieldsRendererComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DynamicFieldsRendererComponent, selector: "app-dynamic-fields-renderer", inputs: { form: "form", agencyNameFilter: "agencyNameFilter", countryNameFilter: "countryNameFilter", mode: "mode", fields: "fields" }, ngImport: i0, template: "<div [formGroup]=\"form\" *ngIf=\"form\">\r\n <div class=\"renderer-container\">\r\n <div class=\"field-container\" *ngFor=\"let field of fields\">\r\n <ng-container\r\n *permission=\"{ name: field.permission, entity: field.formControlName }\"\r\n >\r\n <div class=\"single-field mb-3\" *ngIf=\"field.type === 'text'\">\r\n <div class=\"label-style\">\r\n {{ field.label | translate }}\r\n <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n </div>\r\n <input\r\n class=\"field-style\"\r\n [formControlName]=\"field.formControlName\"\r\n placeholder=\" {{ field.placeholder | translate }}\"\r\n />\r\n </div>\r\n <div class=\"single-field mb-3\" *ngIf=\"field.type === 'number'\">\r\n <div class=\"label-style\">\r\n {{ field.label | translate }}\r\n <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n </div>\r\n <input\r\n min=\"1\"\r\n type=\"number\"\r\n class=\"field-style\"\r\n [formControlName]=\"field.formControlName\"\r\n placeholder=\" {{ field.placeholder | translate }}\"\r\n />\r\n </div>\r\n <div class=\"single-field mb-3\" *ngIf=\"field.type === 'date'\">\r\n <cts-dynamic-form-hijri-dateitem\r\n [formControlName]=\"field.formControlName\"\r\n [label]=\"field.label\"\r\n >\r\n </cts-dynamic-form-hijri-dateitem>\r\n </div>\r\n\r\n <div\r\n class=\"single-field mb-3\"\r\n *ngIf=\"field.type === 'dynamic-vocabulary'\"\r\n >\r\n <app-dynamic-form-vocabulary-item\r\n [label]=\"field.label\"\r\n [bindLabel]=\"field.bindLabel\"\r\n [bindValue]=\"field.bindValue\"\r\n placeholder=\"{{ field.placeholder | translate }}\"\r\n [multiple]=\"field.multiple\"\r\n [searchable]=\"field.searchable\"\r\n [closeOnSelect]=\"field.closeOnSelect\"\r\n [disabled]=\"field.disabled\"\r\n [hideSelectedItems]=\"field.hideSelectedItems\"\r\n [vocabularyType]=\"field.vocabularyType\"\r\n [formControlName]=\"field.formControlName\"\r\n >\r\n </app-dynamic-form-vocabulary-item>\r\n </div>\r\n\r\n <!-- <div class=\"single-field mb-3\" *ngIf=\"field.type === 'department-selector'\">\r\n <div class=\"label-style\">\r\n {{ field.label | translate }}\r\n <span class=\"text-red-500\" *ngIf=\"field.required\">*</span>\r\n </div>\r\n <app-dynamic-form-department\r\n [formControlName]=\"field.formControlName\"\r\n [placeholder]=\"field.placeholder\"\r\n [pp_departmentNestedTree]=\"field.pp_departmentNestedTree\"\r\n [pp_departmentTree]=\"field.pp_departmentTree\"\r\n [customPrefix]=\"field.customPrefix\"\r\n [customParentProperty]=\"field.customParentProperty\"\r\n [useCustomAddEditAction]=\"field.useCustomAddEditAction\"\r\n >\r\n </app-dynamic-form-department>\r\n </div> -->\r\n\r\n <div\r\n class=\"single-field mb-3\"\r\n *ngIf=\"field.type === 'translated-vocabulary'\"\r\n >\r\n <app-translated-vocabulary-select\r\n [label]=\"field.label\"\r\n [arbBindLabel]=\"field.arbBindLabel\"\r\n [engBindLabel]=\"field.engBindLabel\"\r\n [bindValue]=\"field.bindValue\"\r\n placeholder=\"{{ field.placeholder | translate }}\"\r\n [multiple]=\"field.multiple\"\r\n [searchable]=\"field.searchable\"\r\n [closeOnSelect]=\"field.closeOnSelect\"\r\n [hideSelectedItems]=\"field.hideSelectedItems\"\r\n [formControlName]=\"field.formControlName\"\r\n [vocbularyId]=\"field.vocbularyId\"\r\n [useFilter]=\"field.useFilter\"\r\n [filter]=\"\r\n field.filter === 'agencyName'\r\n ? agencyNameFilter\r\n : field.filter === 'countryName'\r\n ? countryNameFilter\r\n : {}\r\n \"\r\n [params]=\"field.params || {}\"\r\n [getByDirectorySuggestion]=\"field.getByDirectorySuggestion\"\r\n >\r\n </app-translated-vocabulary-select>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [""], components: [{ type: DynamicFormHijriDateitemComponent, selector: "cts-dynamic-form-hijri-dateitem", inputs: ["minHijri", "maxHijri", "minGreg", "maxGreg", "label", "isDisabled", "range", "vertical", "isReadOnly", "placeholder"], outputs: ["valueChanged"] }, { type: DynamicFormVocabularyItemComponent, selector: "app-dynamic-form-vocabulary-item", inputs: ["bindValue", "bindLabel", "placeholder", "multiple", "searchable", "closeOnSelect", "hideSelectedItems", "disabled", "vocabularyType", "label", "cacheable", "shwoAllValues"], outputs: ["onSelecting"] }, { type: TranslatedVocabularySelectComponent, selector: "app-translated-vocabulary-select", inputs: ["label", "bindValue", "arbBindLabel", "engBindLabel", "placeholder", "multiple", "searchable", "closeOnSelect", "hideSelectedItems", "disabled", "clear", "filter", "useFilter", "vocbularyId", "mapingResponse", "params", "getByDirectorySuggestion"], outputs: ["onSelectItems"] }], directives: [{ type: i4$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i6.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: PermissionsDirective, selector: "[permission]", inputs: ["permission"] }, { type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { type: i6.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }], pipes: { "translate": i1.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
20512
20523
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DynamicFieldsRendererComponent, decorators: [{
|
|
20513
20524
|
type: Component,
|
|
20514
20525
|
args: [{
|