/** * Test case for NaFieldStyler * * Copyright (C) 2016 R-T Specialty, LLC. * * This file is part of the Liza Data Collection Framework * * Liza is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ var styler = require( '../../../' ).ui.styler, expect = require( 'chai' ).expect, Class = require( 'easejs' ).Class, Sut = styler.NaFieldStyler; describe( 'ui.styler.NaFieldStyler', function() { function testApplyHidden() { var element = stubEle( { className: '' } ), r1 = stubEle( { className: '' } ), r2 = stubEle( { className: '' } ), row = [ r1, r2 ]; Sut().applyStyle( getStubField( element ), element, row ); [ element, r1, r2 ].forEach( function( ele ) { expect( ele.className ).to.match( /\bhidden\b/ ); } ); } function testApplyClear() { var element = stubEle( { style: 'foo' } ), r1 = stubEle( { style: 'foo' } ), r2 = stubEle( { style: 'foo' } ), row = [ r1, r2 ]; Sut().applyStyle( getStubField( element ), element, row ); [ element, r1, r2 ].forEach( function( ele ) { expect( ele.style ).to.equal( '' ); } ); } function testRevokeHidden() { var element = stubEle( { className: 'foo hidden' } ), r1 = stubEle( { className: 'foo hidden' } ), r2 = stubEle( { className: 'foo hidden' } ), row = [ r1, r2 ]; Sut().revokeStyle( getStubField( element ), element, row ); [ element, r1, r2 ].forEach( function( ele ) { expect( ele.className ).to.not.match( /\bhidden\b/ ); expect( ele.className ).to.match( /foo/ ); } ); } function testRevokeStyle() { var element = stubEle( { style: 'foo' } ), r1 = stubEle( { style: 'foo' } ), r2 = stubEle( { style: 'foo' } ), row = [ r1, r2 ]; Sut().revokeStyle( getStubField( element ), element, row ); [ element, r1, r2 ].forEach( function( ele ) { expect( ele.style ).to.equal( 'foo' ); } ); } describe( '#getId', function() { it( 'returns unique identifier', function() { expect( Sut().getId() ).to.equal( 'na' ); } ); } ); describe( '#applyStyle', function() { it( 'sets hidden class on all elements', testApplyHidden ); it( 'clears style on all elements', testApplyClear ); it( 'does not set class on subfield parents', function() { var element = stubEle( { className: '', parentElement: { className: 'widget', removeChild: function() {}, } } ); var r1 = stubEle( { className: '' } ), r2 = stubEle( { className: '' } ), row = [ r1, r2 ]; Sut().applyStyle( getStubField( element ), element, row ); expect( element.className ).to.match( /\bhidden\b/ ); [ r1, r2 ].forEach( function( ele ) { expect( ele.className ).to.equal( '' ); } ); } ); it( 'does not clears style subfield parents', function() { var element = stubEle( { style: 'foo', parentElement: { className: 'widget', removeChild: function() {}, } } ); var r1 = stubEle( { style: 'foo' } ), r2 = stubEle( { style: 'foo' } ), row = [ r1, r2 ]; Sut().applyStyle( getStubField( element ), element, row ); expect( element.style ).to.equal( '' ); [ r1, r2 ].forEach( function( ele ) { expect( ele.style ).to.equal( 'foo' ); } ); } ); // f@#(& IE it( 'removes subfield from DOM', function( done ) { var element = stubEle( { style: '', parentElement: { className: 'widget', removeChild: function( ele ) { expect( ele ).to.equal( element ); done(); }, } } ); Sut().applyStyle( getStubField( element ), element, [] ); } ); } ); describe( '#revokeStyle', function() { it( 'removes hidden class on all elements', testRevokeHidden ); it( 'does not clear style on all elements', testRevokeStyle ); it( 'does not remove hidden class on subfield parents', function() { var element = { className: 'foo hidden', parentElement: { className: 'widget', appendChild: function() {}, } }; var r1 = { className: 'foo hidden' }, r2 = { className: 'foo hidden' }, row = [ r1, r2 ]; Sut().revokeStyle( getStubField( element ), element, row ); expect( element.className ).to.not.match( /\bhidden\b/ ); expect( element.className ).to.match( /foo/ ); [ r1, r2 ].forEach( function( ele ) { expect( ele.className ).to.equal( 'foo hidden' ); } ); } ); // we eventually need to care about where it's re-attached it( 're-attaches subfield to DOM', function( done ) { var element = { className: '', parentElement: { className: 'widget', appendChild: function( ele ) { expect( ele ).to.equal( element ); done(); }, } }; Sut().revokeStyle( getStubField( element ), element, [] ); } ); } ); describe( '#isApplied', function() { it( 'recognizes when applied', function() { var element = stubEle( { className: '', } ); var sut = Sut(), field = getStubField( element ); sut.applyStyle( field, element, [] ); expect( sut.isApplied( field, element ) ) .to.be.true; sut.revokeStyle( field, element, [] ); expect( sut.isApplied( field, element ) ) .to.be.false; } ); } ); describe( 'protected API', function() { describe( '#isSubField', function() { it( 'recognizes parent widget class as subfield', function() { var element = { className: '', parentElement: { className: 'widget', removeChild: function() {}, } }; expect( protSut().protIsSubField( getStubField( element ) ) ) .to.be.true; } ); it( 'missing parent widget class is non-subfield', function() { var element = { className: '', }; expect( protSut().protIsSubField( getStubField( element ) ) ) .to.be.false; } ); } ); describe( '#hideField', function() { it( 'sets hidden class on all elements', testApplyHidden ); it( 'clears style on all elements', testApplyClear ); } ); describe( '#showField', function() { it( 'removes hidden class on all elements', testRevokeHidden ); it( 'does not clear style on all elements', testRevokeStyle ); } ); } ); } ); function getStubField( element ) { return { getParent: function() { return element.parentElement; } }; } function protSut() { return Class.extend( Sut, { protIsSubField: function( element ) { return this.isSubField( element ); } } )(); } function stubEle( obj ) { obj.setAttribute = function( name, value ) { obj[ name ] = value; } return obj; }