기술자료 (KB)/Power Platform

PowerApps으로 만드는 조직도 솔루션 - 11. 직원 (편집 및 삭제)

이완주 2024. 10. 10. 16:41
 

PowerApps으로 만든 조직도 솔루션 제안서

작년에 Power Apps으로 만들어 아직까지 저희 회사에 잘 쓰고 있는 솔루션 입니다.조직도는 연차 결재 솔루션과 연동하여 사용 중에 있습니다. 해당 솔루션의 구성 방법 입니다. 대략 10개 내외 정

leemcse.tistory.com

 

수정 및 삭제

1. 직원 정보를 수정 할 수 있어야 한다.

2. 표시 순서를 위한 OrderNo를 변경 할 수 있어야 한다.

3. 저장 버튼은 필수 입력값이 들어가야 활성화 된다.

 

편집 버튼

 

Visible 속성

편집 버튼은 편집 모두 이면서 회사를 선택하지 않고 직원을 선택 했을 때만 표시

And(!editMode, !newMode, !deleteMode, CurrentItem.Level > 0)

 

OnSelect 속성

편집 버튼을 누루면 최신 데이터를 가져와서 ColOrgAllList 컬렉션을 생성

소속 부서의 순서를 변경하기 위해 ColEmployeeSub1, ColEmployeeSub2, ColEmployeeSub3 3개의 컬렉션을 생성

UpdateContext({ editMode: true, selectedRecord: EmployeeGallery.Selected });

// ColOrgAllList 컬렉션 생성 - 회사일 경우 Type을 Company로 설정
Clear(ColOrgAllList);
ForAll(
    OrgCompany,
    Collect(ColOrgAllList,
        {
            Name: Name,
            Level: 0,
            OrderNo: Text(OrderNo,"00") & "000000000000000000000000000000",
            Visible:true,
            Type:"Company"
        }
    )
);

// ColOrgAllList 컬렉션 추가 - 부서 값 추가 Type을 Department로 설정
ForAll(
    Filter(ColDepartment,Level<>0),
    Collect(ColOrgAllList,
        {
            Company:Company,
            Name: Name,
            DepartmentID: ID,
            Level: Level,
            OrderNo: OrderNo,
            Visible:true,
            Type:"Department"
        }
    )
);

// ColOrgAllList 컬렉션 추가 - 직원 추가 Type을 Employee로 설정, Department 값은 필수 값
ForAll(
    Filter(ColEmployee,!IsBlank(No) And Level<>0),
    Collect(ColOrgAllList,
        {
            Company:Company,
            CompanyID:CompanyID,
            Name: Name,
            DepartmentID: DepartmentID,
            Department:Department,
            EmployeeID:ID,
            Level: Level,
            No:No,
            OrderNo: OrderNo,
            Jobtitle : Jobtitle,
            Mail:Mail,
            Phone:Phone,
            Mobile:Mobile,
            ShortNumber:ShortNumber,
            Visible:true,
            ResignationDate:ResignationDate,
            JoinDate:JoinDate,
            Specialize:Specialize,
            Type:"Employee",
            DepartmentNum : 1
        }
    )
);

// ColOrgAllList 컬렉션 추가 - 직원 추가 Type을 Employee로 설정, Department1 (겸직부서1) 값이 있는 경우 추가
ForAll(
    Filter(ColEmployee,!IsBlank(No1)),
    Collect(ColOrgAllList,
        {
            Company:Company,
            CompanyID:CompanyID,
            Name: Name,
            DepartmentID: DepartmentID1,
            Department:Department1,
            EmployeeID:ID,
            Level: Level1,
            No:No1,
            OrderNo: OrderNo1,
            Jobtitle : Jobtitle,
            Mail:Mail,
            Phone:Phone,
            Mobile:Mobile,
            ShortNumber:ShortNumber,
            Visible:true,
            ResignationDate:ResignationDate,
            JoinDate:JoinDate,
            Specialize:Specialize,
            Type:"Employee",
            DepartmentNum : 2
        }
    )
);

// ColOrgAllList 컬렉션 추가 - 직원 추가 Type을 Employee로 설정, Department2 (겸직부서2) 값이 있는 경우 추가
ForAll(
    Filter(ColEmployee,!IsBlank(No2)),
    Collect(ColOrgAllList,
        {
            Company:Company,
            CompanyID:CompanyID,
            Name: Name,
            DepartmentID: DepartmentID2,
            Department:Department2,
            EmployeeID:ID,
            Level: Level2,
            No:No2,
            OrderNo: OrderNo2,
            Jobtitle : Jobtitle,
            Mail:Mail,
            Phone:Phone,
            Mobile:Mobile,
            ShortNumber:ShortNumber,
            Visible:true,
            ResignationDate:ResignationDate,
            JoinDate:JoinDate,
            Specialize:Specialize,
            Type:"Employee",
            DepartmentNum : 3
        }
    )
);

// OrderNo 정렬을 위한 컬렉션 생성
Clear(ColEmployeeSub1);
ForAll(
    Filter(Sort(ColOrgAllList,OrderNo),Type="Employee" And IsBlank(ResignationDate) And StartsWith(OrderNo,Left(CurrentItem.OrderNo,CurrentItem.Level * 5 + 2))
),
Collect(
    ColEmployeeSub1,
    {
        cID: First(Sort(ColEmployeeSub1,cID,SortOrder.Descending)).cID +1,
        EmployeeID:EmployeeID,
        DepartmentID:EmployeeDepartmentID,
        DepartmentNum:DepartmentNum,
        Name:Name,
        No:No,
        OrderNo:OrderNo,
        cIsCheck:false
    })
);

// OrderNo1 정렬을 위한 컬렉션 생성
If(!IsBlank(LookUp(OrgEmployee,ID=CurrentItem.ID).OrderNo1),
    Clear(ColEmployeeSub2);
    ForAll(
        Filter(Sort(ColOrgAllList,OrderNo),Type="Employee" And IsBlank(ResignationDate) And StartsWith(OrderNo,Left(LookUp(OrgEmployee,ID=CurrentItem.ID).OrderNo1,LookUp(OrgEmployee,ID=CurrentItem.ID).Level1 * 5 + 2))
    ),
    Collect(
        ColEmployeeSub2,
        {
            cID: First(Sort(ColEmployeeSub2,cID,SortOrder.Descending)).cID +1,
            EmployeeID:EmployeeID,
            DepartmentID:EmployeeDepartmentID,
            DepartmentNum:DepartmentNum,
            Name:Name,
            No:No,
            OrderNo:OrderNo,
            cIsCheck:false
        })
    ),
    Clear(ColEmployeeSub2);
);

// OrderNo2 정렬을 위한 컬렉션 생성
If(!IsBlank(LookUp(OrgEmployee,ID=CurrentItem.ID).OrderNo2),
    Clear(ColEmployeeSub3);
    ForAll(
        Filter(Sort(ColOrgAllList,OrderNo),Type="Employee" And IsBlank(ResignationDate) And StartsWith(OrderNo,Left(LookUp(OrgEmployee,ID=CurrentItem.ID).OrderNo2,LookUp(OrgEmployee,ID=CurrentItem.ID).Level2 * 5 + 2))
    ),
    Collect(
        ColEmployeeSub3,
        {
            cID: First(Sort(ColEmployeeSub3,cID,SortOrder.Descending)).cID +1,
            EmployeeID:EmployeeID,
            DepartmentID:EmployeeDepartmentID,
            DepartmentNum:DepartmentNum,
            Name:Name,
            No:No,
            OrderNo:OrderNo,
            cIsCheck:false
        })
    ),
    Clear(ColEmployeeSub3);
)

 

저장 버튼

DisplayMode 속성 - 새로 만들기와 동일한 조건

필수 값이 입력 되었을 경우만 저장 버튼 활성화

// 이름, 메일주소, 소속부서 값이 비어 있으면 저장 버튼을 비활성화
If(!IsBlank(EmployeeName.Text) And !IsBlank(EmployeeMail.Text) And !IsBlank(EmployeeIDComboBox.Selected.Name),DisplayMode.Edit,DisplayMode.Disabled)

 

OnSelect 속성

저장은 컬렉션 값과 SharePoint Lists 값 둘다 저장이 가능하게 설정

If(newMode,
    SubmitForm(Form1_5);

    // ColDepartment 초기화 및 생성
    ClearCollect(ColDepartment,AddColumns(OrgDepartment,NewID,ID));

    // OrgCompany의 회사 정보를 ColDepartment에 추가
    ForAll(
        OrgCompany,
        Collect(
            ColDepartment,
            {
                No: Text(OrderNo,"00"),
                CompanyID : ID,
                Name: Name,
                Level: 0,
                OrderNo: Text(OrderNo,"00") & "000000000000000000000000000000",
                Visible:true
            }
        )
    );

    // ColEmployee 초기화 및 생성
    ClearCollect(ColEmployee,AddColumns(OrgEmployee,NewID,ID));
    ForAll(
        OrgCompany,
        Collect(
            ColEmployee,
            {
                No: Text(OrderNo,"00"),
                CompanyID : ID,
                Name: Name,
                Level: 0,
                OrderNo: Text(OrderNo,"00") & "000000000000000000000000000000",
                Visible:true
            }
        )
    ),
    //ColEmployee에 변경된 값을 저장

UpdateIf(ColEmployee,ID=CurrentItem.ID,
{
    Name:EmployeeName.Text,
    Jobtitle:JobtitleDropdown2_1_2.Selected.Name,
    Position:PositionDropdown3_1_2.Selected.Name,
    Mail: EmployeeMailResult.Text,
    Mobile:EmployeeMobile.Text,
    Phone:EmployeePhone.Text,
    ShortNumber:Value(EmployeeShortNumber.Text),
    Specialize:EmployeeSpecialize.Text,
    JoinDate:EmployeeJoinDate.SelectedDate,
    CompanyID:CompanyIDDropdown.Selected.ID,
    Company:CompanyIDDropdown.Selected.Name,
   
    DepartmentID:EmployeeIDComboBox.Selected.ID,
    DepartmentID1:EmployeeID1ComboBox.Selected.ID,
    DepartmentID2:EmployeeID2ComboBox.Selected.ID,
    Department:EmployeeIDComboBox.Selected.Name,
    Department1:EmployeeID1ComboBox.Selected.Name,
    Department2:EmployeeID2ComboBox.Selected.Name,
    Level:Value(EmployeeLevel.Text),
    Level1:Value(EmployeeLevel1.Text),
    Level2:Value(EmployeeLevel2.Text),
    No:EmployeeNo.Text,
    No1:EmployeeNo1.Text,
    No2:EmployeeNo2.Text,
    OrderNo:EmployeeOrderNo.Text,
    OrderNo1:EmployeeOrderNo1.Text,
    OrderNo2:EmployeeOrderNo2.Text,
    ResignationDate:EmployeeResignationDate.SelectedDate
});

SubmitForm(Form1_5);   //OrgEmployee에 값을 저장

//OrderNo 변경 순서를 OrgEmployee에 순서가 변경된 값에 대한 No와 OrderNo를 변경
//여기서 DepartmentNum을 이용해서 No, No1, No2 혹은 OrderNo, OrderNo1, OrderNo2 인지 확인 후 변경

If(!IsBlank(LookUp(ColEmployeeSub1,cIsCheck= true )),
    ForAll(RenameColumns(Filter(ColEmployeeSub1,cIsCheck=true),EmployeeID,EID),
        If(
            DepartmentNum=1,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No:No,OrderNo:OrderNo}),
            DepartmentNum=2,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No1:No,OrderNo1:OrderNo}),
            DepartmentNum=3,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No2:No,OrderNo2:OrderNo}))
    )
);
If(!IsBlank(LookUp(ColEmployeeSub2,cIsCheck= true )),
    ForAll(RenameColumns(Filter(ColEmployeeSub2,cIsCheck=true),EmployeeID,EID),
        If(
            DepartmentNum=1,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No:No,OrderNo:OrderNo}),
            DepartmentNum=2,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No1:No,OrderNo1:OrderNo}),
            DepartmentNum=3,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No2:No,OrderNo2:OrderNo}))
    )
);
If(!IsBlank(LookUp(ColEmployeeSub3,cIsCheck= true )),
    ForAll(RenameColumns(Filter(ColEmployeeSub3,cIsCheck=true),EmployeeID,EID),
        If(
            DepartmentNum=1,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No:No,OrderNo:OrderNo}),
            DepartmentNum=2,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No1:No,OrderNo1:OrderNo}),
            DepartmentNum=3,Patch(OrgEmployee,LookUp(OrgEmployee,ID=EID),{No2:No,OrderNo2:OrderNo}))
    )
);

//OrderNo 변경 순서를 ColEmployee에 순서가 변경된 값에 대한 No와 OrderNo를 변경
//여기서 DepartmentNum을 이용해서 No, No1, No2 혹은 OrderNo, OrderNo1, OrderNo2 인지 확인 후 변경

If(!IsBlank(LookUp(ColEmployeeSub1,cIsCheck= true )),
    ForAll(RenameColumns(Filter(ColEmployeeSub1,cIsCheck=true),EmployeeID,EID),
        If(
            DepartmentNum=1,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No:No,OrderNo:OrderNo}),
            DepartmentNum=2,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No1:No,OrderNo1:OrderNo}),
            DepartmentNum=3,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No2:No,OrderNo2:OrderNo}))
    )
);
If(!IsBlank(LookUp(ColEmployeeSub2,cIsCheck= true )),
    ForAll(RenameColumns(Filter(ColEmployeeSub2,cIsCheck=true),EmployeeID,EID),
        If(
            DepartmentNum=1,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No:No,OrderNo:OrderNo}),
            DepartmentNum=2,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No1:No,OrderNo1:OrderNo}),
            DepartmentNum=3,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No2:No,OrderNo2:OrderNo}))
    )
);
If(!IsBlank(LookUp(ColEmployeeSub3,cIsCheck= true )),
    ForAll(RenameColumns(Filter(ColEmployeeSub3,cIsCheck=true),EmployeeID,EID),
        If(
            DepartmentNum=1,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No:No,OrderNo:OrderNo}),
            DepartmentNum=2,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No1:No,OrderNo1:OrderNo}),
            DepartmentNum=3,Patch(ColEmployee,LookUp(ColEmployee,ID=EID),{No2:No,OrderNo2:OrderNo}))
    )
);

//ColOrgAllList 값을 업데이트
Clear(ColOrgAllList);
ForAll(
    OrgCompany,
    Collect(ColOrgAllList,
        {
            Name: Name,
            Level: 0,
            OrderNo: Text(OrderNo,"00") & "000000000000000000000000000000",
            Visible:true,
            Type:"Company"
        }
    )
);
ForAll(
    Filter(ColDepartment,Level<>0),
    Collect(ColOrgAllList,
        {
            Company:Company,
            Name: Name,
            DepartmentID: ID,
            Level: Level,
            OrderNo: OrderNo,
            Visible:true,
            Type:"Department"
        }
    )
);
ForAll(
    Filter(ColEmployee,!IsBlank(No) And Level<>0),
    Collect(ColOrgAllList,
        {
            Company:Company,
            CompanyID:CompanyID,
            EmpNo : EmpNo,
            Name: Name,
            DepartmentID: DepartmentID,
            Department:Department,
            EmployeeID:ID,
            Level: Level,
            No:No,
            OrderNo: OrderNo,
            Jobtitle : Jobtitle,
            Mail:Mail,
            Phone:Phone,
            Mobile:Mobile,
            ShortNumber:ShortNumber,
            Visible:true,
            ResignationDate:ResignationDate,
            Specialize:Specialize,
            Type:"Employee",
            DepartmentNum : 1
        }
    )
);
ForAll(
    Filter(ColEmployee,!IsBlank(No1)),
    Collect(ColOrgAllList,
        {
            Company:Company,
            CompanyID:CompanyID,
            EmpNo : EmpNo,
            Name: Name,
            DepartmentID: DepartmentID1,
            Department:Department1,
            EmployeeID:ID,
            Level: Level1,
            No:No1,
            OrderNo: OrderNo1,
            Jobtitle : Jobtitle,
            Mail:Mail,
            Phone:Phone,
            Mobile:Mobile,
            ShortNumber:ShortNumber,
            Visible:true,
            ResignationDate:ResignationDate,
            Specialize:Specialize,
            Type:"Employee",
            DepartmentNum : 2
        }
    )
);
ForAll(
    Filter(ColEmployee,!IsBlank(No2)),
    Collect(ColOrgAllList,
        {
            Company:Company,
            CompanyID:CompanyID,
            EmpNo : EmpNo,
            Name: Name,
            DepartmentID: DepartmentID2,
            Department:Department2,
            EmployeeID:ID,
            Level: Level2,
            No:No2,
            OrderNo: OrderNo2,
            Jobtitle : Jobtitle,
            Mail:Mail,
            Phone:Phone,
            Mobile:Mobile,
            ShortNumber:ShortNumber,
            Visible:true,
            ResignationDate:ResignationDate,
            Specialize:Specialize,
            Type:"Employee",
            DepartmentNum : 2
        }
    )
);

// OrderNo를 변경할 수 있는 Collection을 업데이트
Clear(ColEmployeeSub1);
ForAll(
    Filter(Sort(ColOrgAllList,OrderNo),Type="Employee" And StartsWith(OrderNo,Left(CurrentItem.OrderNo,CurrentItem.Level * 5 + 2))
),
Collect(
    ColEmployeeSub1,
    {
        cID: First(Sort(ColEmployeeSub1,cID,SortOrder.Descending)).cID +1,
        EmployeeID:EmployeeID,
        DepartmentID:EmployeeDepartmentID,
        DepartmentNum:DepartmentNum,
        Name:Name,
        No:No,
        OrderNo:OrderNo,
        cIsCheck:false
    })
);
If(!IsBlank(LookUp(OrgEmployee,ID=CurrentItem.ID).OrderNo1),
    Clear(ColEmployeeSub2);
    ForAll(
        Filter(Sort(ColOrgAllList,OrderNo),Type="Employee" And StartsWith(OrderNo,Left(LookUp(OrgEmployee,ID=CurrentItem.ID).OrderNo1,LookUp(OrgEmployee,ID=CurrentItem.ID).Level1 * 5 + 2))
    ),
    Collect(
        ColEmployeeSub2,
        {
            cID: First(Sort(ColEmployeeSub2,cID,SortOrder.Descending)).cID +1,
            EmployeeID:EmployeeID,
            DepartmentID:EmployeeDepartmentID,
            DepartmentNum:DepartmentNum,
            Name:Name,
            No:No,
            OrderNo:OrderNo,
            cIsCheck:false
        })
    ),
    Clear(ColEmployeeSub2);
);
If(!IsBlank(LookUp(OrgEmployee,ID=CurrentItem.ID).OrderNo2),
    Clear(ColEmployeeSub3);
    ForAll(
        Filter(Sort(ColOrgAllList,OrderNo),Type="Employee" And StartsWith(OrderNo,Left(LookUp(OrgEmployee,ID=CurrentItem.ID).OrderNo2,LookUp(OrgEmployee,ID=CurrentItem.ID).Level2 * 5 + 2))
    ),
    Collect(
        ColEmployeeSub3,
        {
            cID: First(Sort(ColEmployeeSub3,cID,SortOrder.Descending)).cID +1,
            EmployeeID:EmployeeID,
            DepartmentID:EmployeeDepartmentID,
            DepartmentNum:DepartmentNum,
            Name:Name,
            No:No,
            OrderNo:OrderNo,
            cIsCheck:false
        })
    ),
    Clear(ColEmployeeSub3);

);

);

 

 

OrderNo 변경은 기존 순서 변경에 대한 내용 참고

 

삭제 버튼

 

Visible 속성

삭제 버튼은 편집 모두 이면서 회사를 선택하지 않고 직원을 선택 했을 때만 표시

And(!editMode, !newMode, !deleteMode,CurrentItem.Level > 0)

 

OnSelect 속성

삭제 버튼 기본 값으로 별도 변경하지 않음.

UpdateContext({ deleteMode: true, deleteCancelled: false, selectedRecord: EmployeeGallery.Selected })

 

삭제

OnSelect

컬렉션과 SharePoint 목록 둘다 제거

Remove(ColEmployee,Filter(ColEmployee,ID=CurrentItem.ID));
Remove([@OrgEmployee], selectedRecord);
If(IsEmpty(Errors([@OrgEmployee], selectedRecord)), UpdateContext( { CurrentItem: First([@OrgEmployee]), itemSelected: false, editMode: false, newMode: false, deleteMode: false }));