|  | @@ -15,232 +15,449 @@ const C2D = { name: 'Semi C2D', role: 'Designer' };
 | 
	
		
			
				|  |  |  const DSM = { name: 'Semi DSM', role: 'Designer' };
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  describe('Form', () => {
 | 
	
		
			
				|  |  | -    // it('formApi-setValue with array field path, 3 -> 2, remove middle line field', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--use-form-api-set-value-update-array');
 | 
	
		
			
				|  |  | -    //     cy.get(':nth-child(3) > .semi-button').click();
 | 
	
		
			
				|  |  | -    //     // line 1
 | 
	
		
			
				|  |  | -    //     cy.get('[x-field-id="effects[0].name"] > .semi-form-field-main > .semi-input-wrapper > input').should('have.value', '1-name');
 | 
	
		
			
				|  |  | -    //     cy.get('[x-field-id="effects[0].type"] > .semi-form-field-main > .semi-input-wrapper > input').should('have.value', '1-type');
 | 
	
		
			
				|  |  | -    //     // line 2
 | 
	
		
			
				|  |  | -    //     cy.get('[x-field-id="effects[1].name"] > .semi-form-field-main > .semi-input-wrapper > input').should('have.value', '3-name');
 | 
	
		
			
				|  |  | -    //     cy.get('[x-field-id="effects[1].type"] > .semi-form-field-main > .semi-input-wrapper > input').should('have.value', '3-type');
 | 
	
		
			
				|  |  | -    //     // cy.get('body').find('.semi-popover .semi-datepicker').should('have.length', 0);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | +    it('formApi-setValue with array field path, 3 -> 2, remove middle line field', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--use-form-api-set-value-update-array');
 | 
	
		
			
				|  |  | +        cy.get(':nth-child(3) > .semi-button').click();
 | 
	
		
			
				|  |  | +        // line 1
 | 
	
		
			
				|  |  | +        cy.get('[x-field-id="effects[0].name"] > .semi-form-field-main > .semi-input-wrapper > input').should('have.value', '1-name');
 | 
	
		
			
				|  |  | +        cy.get('[x-field-id="effects[0].type"] > .semi-form-field-main > .semi-input-wrapper > input').should('have.value', '1-type');
 | 
	
		
			
				|  |  | +        // line 2
 | 
	
		
			
				|  |  | +        cy.get('[x-field-id="effects[1].name"] > .semi-form-field-main > .semi-input-wrapper > input').should('have.value', '3-name');
 | 
	
		
			
				|  |  | +        cy.get('[x-field-id="effects[1].type"] > .semi-form-field-main > .semi-input-wrapper > input').should('have.value', '3-type');
 | 
	
		
			
				|  |  | +        // cy.get('body').find('.semi-popover .semi-datepicker').should('have.length', 0);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      // ❌ 发现了bug
 | 
	
		
			
				|  |  |      // modify
 | 
	
		
			
				|  |  | -    // it('Basic usage - modify、add blank row、add withInitValue row', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-array-field-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').type('-new');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').type('-new');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', 'Semi D2C-new');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', 'Engineer-new');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     // add blank row
 | 
	
		
			
				|  |  | -    //     cy.get('#add').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2-name').should('have.value', '');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2-role').should('have.value', '');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     // add withInitValue row
 | 
	
		
			
				|  |  | -    //     cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-3-name').should('have.value', 'Semi New-3');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-3-role').should('have.value', 'Designer');
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('Basic usage - add withInitValue row、add blank row', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-array-field-demo');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     // add withInitValue row
 | 
	
		
			
				|  |  | -    //     cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2-name').should('have.value', 'Semi New-3');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2-role').should('have.value', 'Designer');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     // add blank row
 | 
	
		
			
				|  |  | -    //     cy.get('#add').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-3-name').should('have.value', '');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-3-role').should('have.value', '');
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // // // remove row
 | 
	
		
			
				|  |  | -    // it('Remove row - 3 -> 2, remove middle', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--remove-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', D2C.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', D2C.role);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('Remove row - 3 -> 2, remove middle, 2 -> 1, remove head', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--remove-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', D2C.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', D2C.role);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1').should('not.exist');
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('Remove row - 3 -> 2, remove head', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--remove-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2').should('exist');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2').should('not.exist');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', C2D.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', C2D.role);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('Remove row - 3 -> 2, remove last', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--remove-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2').should('exist');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2').should('not.exist');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', D2C.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', D2C.role);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', C2D.name);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', C2D.role);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // // it('Basic usage - add、remove、reset', () => { });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // // reset
 | 
	
		
			
				|  |  | -    // it('Reset Usage: modify  => reset ', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--reset-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').type('-new');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').type('-new');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', `${D2C.name}-new`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', `${D2C.role}-new`);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('Reset Usage: length 2 -> 1  => reset ', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--reset-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1').should('not.exist');
 | 
	
		
			
				|  |  | -    //     cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     // cy.get('#data-1').should('exist');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('Reset Usage: length 2 -> 0 -> 3  => reset ', () => { 
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--reset-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0').should('not.exist');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2').should('exist');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2').should('not.exist');
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('Reset Usage: length 2 -> 0 -> 2  => reset ', () => {
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--reset-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0').should('not.exist');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | -    //     cy.get('.line').should('have.length', 2);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-2').should('not.exist');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('Combine Usage', () => {
 | 
	
		
			
				|  |  | -    //     // add -> remove -> modify
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-array-field-demo', {
 | 
	
		
			
				|  |  | -    //         onBeforeLoad(win) {
 | 
	
		
			
				|  |  | -    //             cy.stub(win.console, 'log').as('consoleLog');
 | 
	
		
			
				|  |  | -    //         },
 | 
	
		
			
				|  |  | -    //     });
 | 
	
		
			
				|  |  | -    //     cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').type('-0');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').type('-0');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', `${D2C.name}-0`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', `${D2C.role}-0`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', `Semi New-3`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', `Designer`);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('combine usage-2', () => {
 | 
	
		
			
				|  |  | -    //     // add -> remove -> modify -> reset
 | 
	
		
			
				|  |  | -    //     cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-array-field-demo');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').type('-0');
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').type('-0');
 | 
	
		
			
				|  |  | -    //     cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | -    //     cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | -    // });
 | 
	
		
			
				|  |  | +    it('Basic usage - modify、add blank row、add withInitValue row', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-array-field-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').type('-new');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').type('-new');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', 'Semi D2C-new');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', 'Engineer-new');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        // add blank row
 | 
	
		
			
				|  |  | +        cy.get('#add').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', '');
 | 
	
		
			
				|  |  | +        cy.get('#data-2-role').should('have.value', '');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        // add withInitValue row
 | 
	
		
			
				|  |  | +        cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-3-name').should('have.value', 'Semi New-3');
 | 
	
		
			
				|  |  | +        cy.get('#data-3-role').should('have.value', 'Designer');
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Basic usage - add withInitValue row、add blank row', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-array-field-demo');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        // add withInitValue row
 | 
	
		
			
				|  |  | +        cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', 'Semi New-3');
 | 
	
		
			
				|  |  | +        cy.get('#data-2-role').should('have.value', 'Designer');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        // add blank row
 | 
	
		
			
				|  |  | +        cy.get('#add').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-3-name').should('have.value', '');
 | 
	
		
			
				|  |  | +        cy.get('#data-3-role').should('have.value', '');
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    // // remove row
 | 
	
		
			
				|  |  | +    it('Remove row - 3 -> 2, remove middle', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--remove-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', D2C.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', D2C.role);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Remove row - 3 -> 2, remove middle, 2 -> 1, remove head', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--remove-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', D2C.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', D2C.role);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | +        cy.get('#data-1').should('not.exist');
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Remove row - 3 -> 2, remove head', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--remove-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-2').should('exist');
 | 
	
		
			
				|  |  | +        cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2').should('not.exist');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', C2D.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', C2D.role);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', DSM.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', DSM.role);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Remove row - 3 -> 2, remove last', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--remove-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-2').should('exist');
 | 
	
		
			
				|  |  | +        cy.get('#data-2 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2').should('not.exist');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', D2C.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', D2C.role);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', C2D.name);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', C2D.role);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    // it('Basic usage - add、remove、reset', () => { });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    // reset
 | 
	
		
			
				|  |  | +    it('Reset Usage: modify  => reset ', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--reset-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').type('-new');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').type('-new');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}-new`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}-new`);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Reset Usage: length 2 -> 1  => reset ', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--reset-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-1').should('not.exist');
 | 
	
		
			
				|  |  | +        cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        // cy.get('#data-1').should('exist');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Reset Usage: length 2 -> 0 -> 3  => reset ', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--reset-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0').should('not.exist');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | +        cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | +        cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2').should('exist');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2').should('not.exist');
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Reset Usage: length 2 -> 0 -> 2  => reset ', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--reset-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0').should('not.exist');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | +        cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | +        cy.get('.line').should('have.length', 2);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2').should('not.exist');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Combine Usage', () => {
 | 
	
		
			
				|  |  | +        // add -> remove -> modify
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-array-field-demo', {
 | 
	
		
			
				|  |  | +            onBeforeLoad(win) {
 | 
	
		
			
				|  |  | +                cy.stub(win.console, 'log').as('consoleLog');
 | 
	
		
			
				|  |  | +            },
 | 
	
		
			
				|  |  | +        });
 | 
	
		
			
				|  |  | +        cy.get('#addWithInit').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').type('-0');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').type('-0');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}-0`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}-0`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `Semi New-3`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `Designer`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('combine usage-2', () => {
 | 
	
		
			
				|  |  | +        // add -> remove -> modify -> reset
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-array-field-demo');
 | 
	
		
			
				|  |  | +        cy.get('#data-1 button').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').type('-0');
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').type('-0');
 | 
	
		
			
				|  |  | +        cy.get('button[type=reset]').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('sync setValue - modify value, 2 -> 2', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-demo');
 | 
	
		
			
				|  |  | +        cy.get('#updateSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}-0`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}-0`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}-1`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('sync setValue - add, 2 -> 3, add tail', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('sync setValue - add, 2 -> 3, add first', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addHeadSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('sync setValue - add, 2 -> 3, add middle', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addMiddleSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('sync setValue - remove, 3 -> 2, remove first', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#removeHeadSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('sync setValue - remove, 3 -> 2, remove middle', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#removeMiddleSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('sync setValue - remove, 3 -> 2, remove tail', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#removeTailSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('sync setValue - remove, 3 -> 0, remove all', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailSync').click();
 | 
	
		
			
				|  |  | +        cy.get('#removeAllSync').click();
 | 
	
		
			
				|  |  | +        cy.get('.line').should('have.length', 0);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Async setValue - modify value, 2 -> 2', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-async-demo');
 | 
	
		
			
				|  |  | +        cy.get('#updateAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}-0`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}-0`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}-1`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Async setValue - add, 2 -> 3, add tail', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-async-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Async setValue - add, 2 -> 3, add first', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-async-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addHeadAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Async setValue - add, 2 -> 3, add middle', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-async-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addMiddleAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Async setValue - remove, 3 -> 2, remove first', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-async-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#removeHeadAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Async setValue - remove, 3 -> 2, remove middle', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-async-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#removeMiddleAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${DSM.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${DSM.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Async setValue - remove, 3 -> 2, remove tail', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-async-demo');
 | 
	
		
			
				|  |  | +        cy.get('#addTailAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#removeTailAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `${D2C.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-role').should('have.value', `${D2C.role}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `${C2D.name}`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-role').should('have.value', `${C2D.role}`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('Async setValue - remove, 2 -> 0, remove all', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--manual-set-async-demo');
 | 
	
		
			
				|  |  | +        cy.get('#removeAllAsync').click();
 | 
	
		
			
				|  |  | +        cy.wait(500);
 | 
	
		
			
				|  |  | +        cy.get('.line').should('have.length', 0);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    // TODO 
 | 
	
		
			
				|  |  | +    it('2 Nested ArrayField - basic', () => {
 | 
	
		
			
				|  |  | +        cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-nested-demo');
 | 
	
		
			
				|  |  | +        // check initValue
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `0`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-0-type').should('have.value', `0-0-type`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-0-desc').should('have.value', `0-0-desc`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-1-type').should('have.value', `0-1-type`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-1-desc').should('have.value', `0-1-desc`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `1`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-rule-0-type').should('have.value', `1-0-type`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-rule-0-desc').should('have.value', `1-0-desc`);
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    it('2 Nested ArrayField - add / remove / reset', () => {
 | 
	
		
			
				|  |  | +        // cy.visit('http://127.0.0.1:6006/iframe.html?path=/story/form--basic-nested-demo');
 | 
	
		
			
				|  |  | +        // // add level 0 
 | 
	
		
			
				|  |  | +        cy.get('#data-1-add').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', `2`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-rule-0-type').should('have.value', `2-0-type`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-rule-0-desc').should('have.value', `2-0-desc`);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        // // add level 1
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-1-add').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-2-type').should('have.value', `0-2-type`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-2-desc').should('have.value', `0-2-desc`);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-2-rule-0-add').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2-rule-1-type').should('have.value', `2-1-type`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-rule-1-desc').should('have.value', `2-1-desc`);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        // remove
 | 
	
		
			
				|  |  | +        /**
 | 
	
		
			
				|  |  | +         *  0            =>        0
 | 
	
		
			
				|  |  | +         *   0-0                     0-0
 | 
	
		
			
				|  |  | +         *   0-1                     0-2
 | 
	
		
			
				|  |  | +         *   0-2
 | 
	
		
			
				|  |  | +         *  1                      1
 | 
	
		
			
				|  |  | +         *   1-0                   
 | 
	
		
			
				|  |  | +         *  2                      2 
 | 
	
		
			
				|  |  | +         *   2-0                     2-0
 | 
	
		
			
				|  |  | +         *   2-1
 | 
	
		
			
				|  |  | +         */
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-1-remove').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-1-rule-0-remove').click();
 | 
	
		
			
				|  |  | +        cy.get('#data-2-rule-1-remove').click();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-0-name').should('have.value', `0`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-0-type').should('have.value', `0-0-type`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-0-desc').should('have.value', `0-0-desc`);
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-1-type').should('have.value', `0-2-type`); // cause remove middle
 | 
	
		
			
				|  |  | +        cy.get('#data-0-rule-1-desc').should('have.value', `0-2-desc`); // cause remove middle
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-1-name').should('have.value', `1`);
 | 
	
		
			
				|  |  | +        cy.get('#data-1-rule-0-type').should('not.exist');
 | 
	
		
			
				|  |  | +        cy.get('#data-1-rule-0-desc').should('not.exist');
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        cy.get('#data-2-name').should('have.value', `2`);
 | 
	
		
			
				|  |  | +        cy.get('#data-2-rule-0-type').should('have.value', `2-0-type`); // cause remove tail
 | 
	
		
			
				|  |  | +        cy.get('#data-2-rule-0-desc').should('have.value', `2-0-desc`); // cause remove tail
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        // reset
 | 
	
		
			
				|  |  | +        //❌ TODO still exist bug here
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +    // it('2 Nested ArrayField - formApi.setValues', () => { });
 | 
	
		
			
				|  |  | +    // it('2 Nested ArrayField - formApi.setValue level-1', () => { });
 | 
	
		
			
				|  |  | +    // it('2 Nested ArrayField - formApi.setValue level-2', () => { });
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      // it('Init - Form Props initValues、ArrayField initValue、Field initValue', () => { 
 | 
	
		
			
				|  |  |      // // 一个 Form 三个 ArrayField
 | 
	
		
			
				|  |  |      // });
 | 
	
		
			
				|  |  | -    // it('Init - combine', () => {});
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    // it('sync setValue - modify value, 2 -> 2', () => { });
 | 
	
		
			
				|  |  | -    // it('sync setValue - add, 2 -> 3, add first', () => { });
 | 
	
		
			
				|  |  | -    // it('sync setValue - add, 2 -> 3, add middle', () => { });
 | 
	
		
			
				|  |  | -    // it('sync setValue - add, 2 -> 3, add last', () => { });
 | 
	
		
			
				|  |  | -    // it('sync setValue - remove, 3 -> 2, remove first', () => { });
 | 
	
		
			
				|  |  | -    // it('sync setValue - remove, 3 -> 2, remove middle', () => { });
 | 
	
		
			
				|  |  | -    // it('sync setValue - remove, 3 -> 2, remove last', () => { });
 | 
	
		
			
				|  |  | -    // it('sync setValue - remove, 3 -> 0, remove all', () => { });
 | 
	
		
			
				|  |  | +    // it('Init - combine', () => {});
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      // it('sync setValues - modify', () => { });
 | 
	
		
			
				|  |  |      // it('sync setValues - add', () => { });
 | 
	
		
			
				|  |  |      // it('sync setValues - remove', () => { });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('ASync setValues', () => { });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('ASync setValue', () => { });
 | 
	
		
			
				|  |  | -    // it('ASync setValue: ', () => { });
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // it('2 Nested ArrayField - add/remove', () => { });
 | 
	
		
			
				|  |  | -    // it('2 Nested ArrayField - reset', () => { });
 | 
	
		
			
				|  |  | -    // it('2 Nested ArrayField - formApi.setValues', () => { });
 | 
	
		
			
				|  |  | -    // it('2 Nested ArrayField - formApi.setValue level-1', () => { });
 | 
	
		
			
				|  |  | -    // it('2 Nested ArrayField - formApi.setValue level-2', () => { });
 | 
	
		
			
				|  |  | -    // it('3 Nested ArrayField - add/remove', () => {});
 | 
	
		
			
				|  |  | +    // it('Async setValues', () => { });
 | 
	
		
			
				|  |  |  });
 |