mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-08-07 17:48:54 +00:00
[AAE-4428] Add selected file counter to attach file widget (#6881)
* [AAE-4428] Add selected file counter to attach file widget * [AAE-4428] Add getSelectedCount method * [AAE-4428] Add unit tests * [AAE-4428] Changed so TranslationService injection is not necessary * [AAE-4428] Added unit tests to check the element has been injected * spacing * [AAE-4428] Remove unnecessary check in unit test * [AAE-4428] Add node counter directive * [ci skip] Fix linting issues * Remove changing the selection to the nabigated node * Revert removing selection on folder loaded, add unit test * Added documentation Co-authored-by: adomi <ardit.domi@alfresco.com>
This commit is contained in:
@@ -18,19 +18,25 @@
|
||||
import { CommonModule } from '@angular/common';
|
||||
import { NgModule } from '@angular/core';
|
||||
import { MaterialModule } from '../material.module';
|
||||
import { TranslateModule } from '@ngx-translate/core';
|
||||
|
||||
import { NodeLockDirective } from './node-lock.directive';
|
||||
import { NodeCounterComponent, NodeCounterDirective } from './node-counter.directive';
|
||||
|
||||
@NgModule({
|
||||
imports: [
|
||||
CommonModule,
|
||||
MaterialModule
|
||||
MaterialModule,
|
||||
TranslateModule
|
||||
],
|
||||
declarations: [
|
||||
NodeLockDirective
|
||||
NodeLockDirective,
|
||||
NodeCounterDirective,
|
||||
NodeCounterComponent
|
||||
],
|
||||
exports: [
|
||||
NodeLockDirective
|
||||
NodeLockDirective,
|
||||
NodeCounterDirective
|
||||
]
|
||||
})
|
||||
export class ContentDirectiveModule {
|
||||
|
@@ -0,0 +1,56 @@
|
||||
/*!
|
||||
* @license
|
||||
* Copyright 2019 Alfresco Software, Ltd.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
import { Component } from '@angular/core';
|
||||
import { ComponentFixture, TestBed } from '@angular/core/testing';
|
||||
import { NodeCounterDirective, NodeCounterComponent } from './node-counter.directive';
|
||||
import { By } from '@angular/platform-browser';
|
||||
import { TranslateModule } from '@ngx-translate/core';
|
||||
|
||||
@Component({
|
||||
template: `<div [adf-node-counter]="count"></div>`
|
||||
})
|
||||
class TestComponent {
|
||||
count: number = 0;
|
||||
}
|
||||
|
||||
describe('NodeCounterDirective', () => {
|
||||
let fixture: ComponentFixture<TestComponent>;
|
||||
|
||||
beforeEach(() => {
|
||||
TestBed.configureTestingModule({
|
||||
imports: [
|
||||
TranslateModule.forRoot()
|
||||
],
|
||||
declarations: [
|
||||
NodeCounterDirective,
|
||||
NodeCounterComponent,
|
||||
TestComponent
|
||||
]
|
||||
});
|
||||
fixture = TestBed.createComponent(TestComponent);
|
||||
fixture.detectChanges();
|
||||
});
|
||||
|
||||
it('should display the counter component', () => {
|
||||
fixture.whenStable().then(() => {
|
||||
const counterElement = fixture.debugElement.query(By.css('adf-node-counter'));
|
||||
expect(counterElement).not.toBeNull();
|
||||
expect(counterElement.nativeElement.innerText).toBe('NODE_COUNTER.SELECTED_COUNT');
|
||||
});
|
||||
});
|
||||
});
|
@@ -0,0 +1,55 @@
|
||||
/*!
|
||||
* @license
|
||||
* Copyright 2019 Alfresco Software, Ltd.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
import { Directive, Input, Component, OnInit, OnChanges, ComponentFactoryResolver, ViewContainerRef } from '@angular/core';
|
||||
|
||||
@Directive({
|
||||
selector: '[adf-node-counter]'
|
||||
})
|
||||
export class NodeCounterDirective implements OnInit, OnChanges {
|
||||
@Input('adf-node-counter')
|
||||
counter: number;
|
||||
|
||||
componentRef: NodeCounterComponent;
|
||||
|
||||
constructor(
|
||||
private resolver: ComponentFactoryResolver,
|
||||
public viewContainerRef: ViewContainerRef
|
||||
) {}
|
||||
|
||||
ngOnInit() {
|
||||
const componentFactory = this.resolver.resolveComponentFactory(NodeCounterComponent);
|
||||
this.componentRef = this.viewContainerRef.createComponent(componentFactory).instance;
|
||||
this.componentRef.counter = this.counter;
|
||||
}
|
||||
|
||||
ngOnChanges() {
|
||||
if (this.componentRef) {
|
||||
this.componentRef.counter = this.counter;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Component({
|
||||
selector: 'adf-node-counter',
|
||||
template: `
|
||||
<div>{{ 'NODE_COUNTER.SELECTED_COUNT' | translate: { count: counter } }}</div>
|
||||
`
|
||||
})
|
||||
export class NodeCounterComponent {
|
||||
counter: number;
|
||||
}
|
Reference in New Issue
Block a user