Compare commits

...

226 Commits

Author SHA1 Message Date
10c35f6f10 add validation and change the list of employees 2025-04-26 20:44:24 +03:30
SamSys
89a8e1c027 merge EditFile-SessionList 2025-04-26 16:27:46 +03:30
SamSys
e584605c4e merge Accept-CutByBgService 2025-04-26 16:26:35 +03:30
MahanCh
734699b319 fix accept cutbyservice 2025-04-26 11:08:31 +03:30
MahanCh
e8407868a7 fix session bug and edit file bug 2025-04-26 11:01:08 +03:30
7ad1a2f376 add tomam 2 2025-04-24 15:07:30 +03:30
e190408504 Revert "GetEmployeeShiftDateByRollCallStartDate bug fixed"
This reverts commit b880721dfa.
2025-04-24 14:49:30 +03:30
e520c8c14b Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-24 14:49:09 +03:30
bd0e79fadf . 2025-04-24 14:48:11 +03:30
SamSys
b880721dfa GetEmployeeShiftDateByRollCallStartDate bug fixed 2025-04-24 14:25:30 +03:30
SamSys
e0a68690c1 InsuranvePermission - Checkout change 2025-04-23 21:33:29 +03:30
SamSys
817a848eef Merge remote-tracking branch 'origin/Feature/Leave/CreateLeaveStyleChanges' 2025-04-22 22:45:26 +03:30
SamSys
f77fa7a324 sms mearg 2025-04-22 22:44:42 +03:30
MahanCh
e44dad08ef fix sms style 2025-04-22 20:38:24 +03:30
MahanCh
f901f8a682 change the create leave modal 2025-04-22 19:57:45 +03:30
SamSys
08913d38f2 mahan 2025-04-22 19:29:33 +03:30
SamSys
15156c06fc sms report and task styles merged 2025-04-22 19:26:57 +03:30
MahanCh
5da9d23875 add sms and task fix 2025-04-22 19:26:08 +03:30
SamSys
c14da7ad5b Merge remote-tracking branch 'origin/Feature/InstitutionPlan/init' 2025-04-22 19:23:35 +03:30
SamSys
1629b121d3 Merge remote-tracking branch 'origin/Fix/CWS/breakTime-validation-rotating-shifts' 2025-04-22 19:22:26 +03:30
SamSys
3a60ddf449 Merge remote-tracking branch 'origin/Feature/RollCall/mannual-edit' 2025-04-22 19:21:46 +03:30
SamSys
c90fe4cb29 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-22 19:14:32 +03:30
SamSys
57930aae4f rotatingShift Compute on Rollcall Bug Fixed 2025-04-22 19:14:26 +03:30
MahanCh
d816e73fed delete useless workshopId 2025-04-22 19:13:15 +03:30
MahanCh
10bfbad3cb add institution plan front 2025-04-22 18:31:00 +03:30
MahanCh
671f6be87a change current day mannual edit validaton 2025-04-22 18:13:09 +03:30
MahanCh
2901a9ecf4 fix rotating shift validation 2025-04-22 17:39:53 +03:30
MahanCh
aff835fd7f add split query to customize checkout print 2025-04-22 13:38:26 +03:30
MahanCh
7055839538 fix excel bugs 2025-04-22 13:35:15 +03:30
SamSys
2166e7c5ee Leave Compute On Checkout Add ShiftDuration 2025-04-21 23:38:44 +03:30
SamSys
d4dc65b4e8 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-21 23:37:49 +03:30
38dd1b1818 fix customize checkout bug 2025-04-21 22:55:27 +03:30
SamSys
8c5b21b726 Merge remote-tracking branch 'origin/Fix/CustomizeCheckout/Change31DaysTo30' 2025-04-21 15:44:20 +03:30
SamSys
77d9c42823 change 2025-04-21 15:43:49 +03:30
SamSys
214882108c HasRollCallRecord Condition 2025-04-21 15:43:25 +03:30
MahanCh
98a8bef754 fix rollcall shiftdate bug 2025-04-21 15:42:30 +03:30
SamSys
ececd99d07 merge for kabab mahdi 2025-04-21 13:51:56 +03:30
MahanCh
8cb39f4a55 change customizeCheckoutBug 2025-04-21 13:44:42 +03:30
SamSys
d54e3c4a67 merge for excel Multy sheets 2025-04-20 20:51:10 +03:30
SamSys
4e8a7d74a2 merge for smsReport 2025-04-20 20:50:20 +03:30
SamSys
d1414b0b90 change 2025-04-20 20:48:55 +03:30
MahanCh
aeb65dc152 add sms report for admin 2025-04-20 20:43:45 +03:30
MahanCh
e69525b1ad add excel export in multi sheet 2025-04-20 20:28:08 +03:30
SamSys
47c53ce116 Merge Fix/LeaveDuration 2025-04-20 20:21:58 +03:30
SamSys
fe7a70e9db Blocked Contract And Checkout Can signe now 2025-04-20 20:16:55 +03:30
MahanCh
f7db92c4a7 fix leave duration bug fix 2025-04-20 19:54:58 +03:30
SamSys
d257711d16 Create ClientAcount on InstitutionContract when edit or extend 2025-04-20 18:44:19 +03:30
SamSys
7ab83c73aa institutionContract createClinetAccount bug fixed 2025-04-20 18:12:47 +03:30
SamSys
6aefe7e88c Classified check 2025-04-20 16:18:34 +03:30
SamSys
a3533234f1 file select2 bug fixed - session responsive bug fixed 2025-04-20 15:43:19 +03:30
SamSys
5dae65cad1 fix file list bug 2025-04-19 21:41:51 +03:30
SamSys
c5c79a9629 report bug fixed 2025-04-19 20:34:16 +03:30
SamSys
aad033731a mask change on layout 2025-04-19 19:26:55 +03:30
SamSys
949c9dd34e merge from featuer/file/list-redesign 2025-04-19 19:26:27 +03:30
SamSys
d0406b2bbe HasRollCallRecorde Changes 2025-04-19 19:06:09 +03:30
SamSys
cb8741faf9 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-19 19:05:16 +03:30
SamSys
649bf5338a HasShiftDuration - MandatoryCumpute 2025-04-19 19:05:07 +03:30
MahanCh
3896b3cec1 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-19 18:56:58 +03:30
MahanCh
4064d5fdf8 mahan access to backup 2025-04-19 18:56:51 +03:30
MahanCh
fc200e53f1 fix admin new style problem 2025-04-19 16:24:05 +03:30
MahanCh
f2f8571b44 add list new design 2025-04-19 16:11:22 +03:30
SamSys
52e1d0a78b TemporaryClientRegistration - TaxAdded 2025-04-19 16:05:17 +03:30
SamSys
b5affa43c1 Merge From Upload/Dad-Mehr to master 2025-04-17 16:16:29 +03:30
MahanCh
6b7c3730ad fix loan fine and reward style bug 2025-04-16 20:41:17 +03:30
SamSys
b627311d73 Merge From Feature/File/Session 2025-04-16 20:23:43 +03:30
MahanCh
9cc62d76c2 change side bar names 2025-04-16 20:06:25 +03:30
MahanCh
6422218409 fix reward bug in description 2025-04-16 20:05:58 +03:30
MahanCh
9eb9c0d49a fix bugs for employees select list 2025-04-16 20:05:21 +03:30
MahanCh
cc740439ec get the employees select2 changes 2025-04-16 20:04:57 +03:30
MahanCh
ff15307160 fix salaryAid color bug 2025-04-16 17:27:49 +03:30
MahanCh
f2a2afc7a4 fix sidebar bugs 2025-04-16 17:14:23 +03:30
MahanCh
fe2a70bf60 merge task schedule with file for orginal publish 2025-04-16 17:02:14 +03:30
MahanCh
d52141f729 fix 2025-04-16 15:50:35 +03:30
MahanCh
1915dc0565 fix rollcall bug and reward desc bug 2025-04-16 15:30:20 +03:30
MahanCh
4cc0e72136 add validation for file operations 2025-04-16 15:01:44 +03:30
MahanCh
535e3943eb fix file alerts 2025-04-16 14:50:53 +03:30
SamSys
e8efb0a579 merge from feature/file/session 2025-04-15 23:58:04 +03:30
SamSys
8800af7647 Commented 2025-04-15 23:52:07 +03:30
SamSys
8ec9f5daef TemporaryClientRegister 2025-04-15 23:51:13 +03:30
MahanCh
e625ed9a6e fix alert bug 2 2025-04-15 21:22:19 +03:30
MahanCh
39ffd52107 fix alert bug 2025-04-15 21:22:07 +03:30
MahanCh
6dbf6c2008 fix file session bug 2025-04-15 16:56:18 +03:30
MahanCh
00a85e54ee remove operation result 2025-04-15 15:06:17 +03:30
SamSys
f5195ecaa2 Control + k + d on TemporaryClientRegistrationApplication 2025-04-14 21:48:12 +03:30
SamSys
aaa3618522 File Excel 2025-04-14 21:46:31 +03:30
SamSys
9376c2cca6 comentted while 2025-04-14 21:32:15 +03:30
SamSys
36480df2f5 TemporaryClientRegistration - InstitutionContractTemp 2025-04-14 21:30:15 +03:30
MahanCh
60db153dfe finish list of files 2025-04-14 20:24:55 +03:30
MahanCh
4ffdf14de2 add excel export for file page 2025-04-14 16:02:51 +03:30
SamSys
fa587c61eb file1 bug fixed - merge from fil-bug-fix brach 2025-04-13 23:41:09 +03:30
SamSys
7e35f8009a add new account to staticWorkshopAccount 2025-04-13 23:21:45 +03:30
MahanCh
13080fd64c Merge branch 'Feature/Main/Header' into Upload/Dad-mehr 2025-04-13 22:55:04 +03:30
MahanCh
39eb401575 add loan details 2025-04-13 22:51:21 +03:30
SamSys
bcd6447509 BaseYearPay bug Fixed YearlySalery 2025-04-13 22:49:43 +03:30
MahanCh
ac46886922 add grouping search for loan reward SA fine 2025-04-13 22:23:25 +03:30
MahanCh
252c601eb4 fix some bugs 2025-04-13 19:36:38 +03:30
SamSys
4f673f22d5 merge from Delete-bug-after-openning-Create-modal into master 2025-04-13 16:54:58 +03:30
SamSys
d4a80f5b87 TemporaryClientRegister -ReviewAndPayment 2025-04-13 16:51:38 +03:30
MahanCh
0c73ac44e8 fix delete bug in customize checkout 2025-04-13 16:45:14 +03:30
MahanCh
059624ff9f fix year and month on creating checkout unofficial 2025-04-13 16:30:09 +03:30
MahanCh
a792936d66 FIx SideBar and add currentDay css 2025-04-12 11:15:54 +03:30
SamSys
a99e1cef32 merge from customize-chekout-header 2025-04-10 14:39:23 +03:30
SamSys
408a78fb27 merge from master 2025-04-10 14:38:03 +03:30
SamSys
6f7eb05047 TemporaryClientRegister - Chekout-Bonuses Bug Fixed 2025-04-10 14:23:39 +03:30
SamSys
03ee772974 TemporaryClientRegister - Compelet edcreatWorkshopTemp 2025-04-09 19:18:00 +03:30
MahanCh
a0cab667c4 merge from task schedule 2025-04-09 19:13:46 +03:30
MahanCh
53ece03000 fix task schedule bug 2025-04-09 19:12:45 +03:30
MahanCh
3354e0343c fix case history bug 2025-04-09 19:08:10 +03:30
MahanCh
811d8c023c merge from checkoukt header 2025-04-09 18:43:32 +03:30
MahanCh
c561a138d6 add early exit 2025-04-09 18:38:15 +03:30
MahanCh
d03f19a51e add new header 2025-04-09 18:38:05 +03:30
MahanCh
d4f56b2d82 add shift duration on create leave 2025-04-08 19:27:25 +03:30
SamSys
de54e609c8 temporaryClientRegister - CreateOrUpdate workshop 2025-04-08 18:31:27 +03:30
MahanCh
a4bdd55161 fix bug for task schedule 2025-04-08 17:45:57 +03:30
MahanCh
a43e32fa04 merge Task schedule with customize checkout header 2025-04-08 17:04:47 +03:30
MahanCh
4801fcfd89 finish customize chekcout header 2025-04-08 16:50:51 +03:30
MahanCh
4eb7e8eaf5 add file 2025-04-08 16:33:30 +03:30
MahanCh
caa887cd04 merge from master 2025-04-08 16:33:17 +03:30
MahanCh
baededb717 fix conflict 2025-04-08 16:32:10 +03:30
SamSys
a14595a961 TemporaryClientRegister - migration 2025-04-08 16:26:42 +03:30
MahanCh
7911109c64 init 2025-04-08 15:17:42 +03:30
SamSys
67b2d3ab55 GroupingRollCall fix mobile view proplem 2025-04-07 23:02:43 +03:30
SamSys
090a47fc70 TemoraryClientRegister - Creat WorkshopTemp 2025-04-07 22:58:44 +03:30
SamSys
d39dc5047f TemporaryClient - WorkshopTemp and WorkshopServicesTemp 2025-04-07 19:50:33 +03:30
MahanCh
ecfae75010 add task schedule 2025-04-07 19:44:22 +03:30
SamSys
ad8896a12c merge from Fix\Create-Reward-for-kebab-in-checkout 2025-04-07 16:16:35 +03:30
MahanCh
d46e8b5de5 fix bug 2025-04-07 14:46:17 +03:30
SamSys
51a4e5c1fe plan and service new 2025-04-06 21:26:07 +03:30
SamSys
b6a581c456 tomam for kabab mahdi 2025-04-05 13:33:14 +03:30
MahanCh
3e914b7b1d fix add reward bug 2025-04-05 12:29:29 +03:30
MahanCh
40f021197b add method for creating reward for kebab mahdi 2025-04-05 09:47:00 +03:30
0303f04ae3 delete employee picture in select 2025-03-30 19:22:01 +03:30
3e56d31ff2 fix missed Items 2025-03-30 19:19:55 +03:30
d5d0634807 revert back 2025-03-30 19:19:34 +03:30
SamSys
a950c3130d change 2025-03-30 19:00:38 +03:30
SamSys
85f493bcbb changes 2025-03-30 18:58:15 +03:30
SamSys
b8a82f783c merge from master 2025-03-30 18:53:30 +03:30
SamSys
e2d06d8f7e add injection 2025-03-30 18:44:09 +03:30
SamSys
44a0a2df86 merge from master 2025-03-30 18:40:03 +03:30
SamSys
ee5e608581 add somthing again 2025-03-30 18:36:08 +03:30
SamSys
6583706db6 Print & delet Permission Customizechekout ajax ug fixed 2025-03-30 18:33:51 +03:30
1449e83a0f fix bug! 2025-03-30 18:28:39 +03:30
bf5f416470 Merge branch 'Feature/Customize-Checkout-Header' of https://github.com/syntax24/OriginalGozareshgir into Feature/Customize-Checkout-Header 2025-03-30 13:18:40 +03:30
6526aefbbf fix not found bug in customize checkout 2025-03-30 13:18:33 +03:30
SamSys
1fec40982c Revert "changes"
This reverts commit 677adbeddb.
2025-03-30 04:14:37 +03:30
SamSys
868abae2e8 merge from Customize-Chekout-Headr To Master 2025-03-30 03:45:37 +03:30
SamSys
c627ba6d3d merg from master 2025-03-30 03:41:03 +03:30
SamSys
dadf541dd1 Permission for CustomizeCheckoutTemp Bug Fixed 2025-03-30 03:37:55 +03:30
4b0c700b3e add daily wage for non calculation for kabab mahdi 2025-03-30 00:48:17 +03:30
677adbeddb changes 2025-03-30 00:44:01 +03:30
SamSys
caaace7bcc change 2025-03-29 20:32:05 +03:30
SamSys
c6142b684e Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-03-29 20:31:48 +03:30
SamSys
ef5f80ba91 merage from custom-Checkout-for-Kebab-mahdi To Master 2025-03-29 20:31:41 +03:30
SamSys
cac3d47c32 Merge branch 'Custom-Checkout-For-Kebab-Mahdi' of https://github.com/syntax24/OriginalGozareshgir into Custom-Checkout-For-Kebab-Mahdi 2025-03-29 20:23:20 +03:30
SamSys
e2e0171564 change 2025-03-29 20:23:09 +03:30
d139a36fba remove Math.truncate for monthly salary for compute customize checkout 2025-03-27 19:09:09 +03:30
SamSys
a9655d6df5 Merge from CreateRewardForKababMahdi to Master 2025-03-26 01:58:25 +03:30
e0bdde8264 fix reward paginate problem 2025-03-25 17:30:45 +03:30
67111fff6b add filter for create reward 2025-03-25 17:22:14 +03:30
ef4c9ee201 fix rollcall mandatory repository 2025-03-25 17:01:30 +03:30
b621a709aa add reward creation method - fix create left work tremp 2025-03-25 15:36:41 +03:30
SamSys
1f96f0bc87 Merge From CustomizeCheckoutBuf To master 2025-03-25 03:39:45 +03:30
SamSys
aa8eac6923 Merge From Master to customizeCheckoutBug 2025-03-25 03:37:21 +03:30
SamSys
1707c90072 tomam for kabab mahdi 2025-03-25 03:35:15 +03:30
9bd85fc22e fix late work hout problem in customize checkout - fix front print problem 2025-03-24 20:55:08 +03:30
SamSys
f2b03cc34f merge from customizeChekoutBug to Master 2025-03-24 19:33:58 +03:30
SamSys
7f14c14589 appsetting fix to original 2025-03-24 19:27:52 +03:30
SamSys
80486a5f3a Merge From Master 2025-03-24 19:27:03 +03:30
SamSys
9ff7fc7a90 resgisteration test commented 2025-03-24 19:25:52 +03:30
99bfb472b0 fix search bug 2025-03-24 19:11:47 +03:30
SamSys
21b209b83a register 2025-03-24 19:01:13 +03:30
a4aff718dc fix bug 2025-03-24 18:59:30 +03:30
SamSys
14f54149ea appsetting 2025-03-21 19:15:52 +03:30
SamSys
3e2c7df38b marge create employee front to master 2025-03-21 19:11:04 +03:30
SamSys
cc11dcfde7 test 2025-03-21 19:08:12 +03:30
bc6f817c34 Merge branch 'mahan' of https://github.com/syntax24/OriginalGozareshgir into mahan 2025-03-21 18:16:41 +03:30
d2d629d750 fix employee upload picture bug 2025-03-21 18:16:34 +03:30
SamSys
0a2b6b33d6 Mearge from Mahan Brach to maste - Create Employee Backend Bug Fixed 2025-03-21 16:29:37 +03:30
SamSys
43b68a3e88 f 2025-03-21 16:27:17 +03:30
SamSys
8f9d0ecffb kabiseh bug fixed 2025-03-21 16:25:58 +03:30
e73672e114 fix create employee bug 2025-03-21 12:52:37 +03:30
SamSys
c62a16a25f merge new changes from mahan to master 2025-03-18 17:35:49 +03:30
SamSys
f5aef7c7cc bale 2025-03-18 17:19:57 +03:30
SamSys
60c60a9e17 personalcotractingParty add new prop 2025-03-18 17:18:06 +03:30
MahanCh
9311c7bfc7 employee document part 3 2025-03-18 17:03:17 +03:30
MahanCh
f6a710dc03 fix bug employee document part 2 2025-03-18 16:49:57 +03:30
MahanCh
db47f8f354 fix employee document bug and add bank and salary aid in customize checkout list 2025-03-18 16:41:28 +03:30
SamSys
9deb0ca4c6 add permission tag helper 2025-03-17 21:43:43 +03:30
SamSys
c99e242caa permission pug fixed 2025-03-17 21:43:29 +03:30
SamSys
f5a767abc4 appsetting 2025-03-17 21:13:31 +03:30
SamSys
5389d58fbd change 2025-03-17 21:10:33 +03:30
SamSys
e5450dffa7 change 2025-03-17 21:07:56 +03:30
SamSys
870184310f marge from master 2025-03-17 20:50:55 +03:30
SamSys
a2de24a72a ContractingPartyTemp Changes 2025-03-17 20:44:13 +03:30
MahanCh
be9051d8b0 finish create employee bug 2025-03-17 20:42:36 +03:30
MahanCh
ebb1d3dd61 fix conflict 2025-03-17 18:47:52 +03:30
MahanCh
2879d75ae8 fix bug create employee part 2 2025-03-17 18:47:07 +03:30
MahanCh
79cfad0c13 add changes for create employee bugs 2025-03-17 18:46:43 +03:30
SamSys
bf94e9c76d permission changed 2025-03-17 18:37:44 +03:30
SamSys
44d5af811b add git ignore for appsettings 2025-03-16 23:52:16 +03:30
SamSys
f85e040750 ToPersianMetod by Mahan 2025-03-16 23:30:06 +03:30
SamSys
b81c5163e5 Add Employee By Client = Explodng Original by Mahan 2025-03-16 23:01:54 +03:30
SamSys
961720e896 Toumam changed 2025-03-16 22:42:47 +03:30
SamSys
56993da86b fix conflict after marge from master 2025-03-16 21:08:03 +03:30
SamSys
a11532f2bd Marge from Master 2025-03-16 21:06:48 +03:30
SamSys
330a663bd1 create contractingpartytemp 2025-03-16 18:45:50 +03:30
MahanCh
ad3ef5699c Merge branch 'AddEmployeeByClient' of https://github.com/syntax24/OriginalGozareshgir into AddEmployeeByClient 2025-03-16 17:52:55 +03:30
MahanCh
424acb9661 fix employee document bug for uploading client 2025-03-16 17:52:48 +03:30
SamSys
e0fcdc612b change appsetting 2025-03-16 16:58:22 +03:30
SamSys
7e2f691bb3 add connectionstring 2025-03-16 16:48:51 +03:30
SamSys
f105e21ef7 migration & update-databse to contractingParty (new prop) 2025-03-16 16:45:12 +03:30
SamSys
5b3b073223 contracting party domain changed 2025-03-16 16:02:18 +03:30
MahanCh
1acd218f77 add client layout bug and responsive of employee document admin workflow 2025-03-16 14:52:50 +03:30
MahanCh
d32b6a10c0 fix date of issue bug in create employee 2025-03-16 14:25:12 +03:30
SamSys
a4546366aa Temporary ClientRegisration 2025-03-15 21:18:02 +03:30
SamSys
2f8e2ff44c Insurance Exception commented 2025-03-15 18:45:13 +03:30
MahanCh
b088e0d8ec fix rollcall paginate condition bug 2025-03-15 14:59:59 +03:30
MahanCh
604007e087 Merge branch 'master' into Mahan 2025-03-15 14:58:13 +03:30
MahanCh
180d17b254 fix admin rollcall report bug 2025-03-13 11:22:48 +03:30
SamSys
a60e0bd211 mahan changed 2025-03-13 00:04:47 +03:30
SamSys
6b543b4627 mahan access to backup 2025-03-12 23:13:05 +03:30
MahanCh
8222f8be4a fix employee documet and send to checker button on workflow admin 2025-03-12 21:08:40 +03:30
SamSys
1c89068557 fix bug rollcallEmployee - upload picture 2025-03-12 20:46:33 +03:30
MahanCh
c7a99f7ca0 fix add employee by client bugs 2025-03-11 18:53:57 +03:30
MahanCh
d7d938dfcc Add employee by client part 2 2025-03-09 21:52:06 +03:30
MahanCh
89a01b5948 add employee by client to orginal part 1 2025-03-08 21:49:34 +03:30
756 changed files with 267743 additions and 15856 deletions

5
.gitignore vendored
View File

@@ -359,5 +359,6 @@ MigrationBackup/
# Ionide (cross platform F# VS Code tools) working folder
.ionide/
# Fody - auto-generated XML schema
FodyWeavers.xsd
# # Fody - auto-generated XML schema
# FodyWeavers.xsd

View File

@@ -14,7 +14,9 @@
<PackageReference Include="Newtonsoft.Json.Bson" Version="1.0.2" />
<PackageReference Include="PersianTools.Core" Version="2.0.4" />
<PackageReference Include="System.Drawing.Common" Version="9.0.0" />
<PackageReference Include="MD.PersianDateTime.Standard" Version="2.5.0" />
</ItemGroup>
</Project>

View File

@@ -3,5 +3,6 @@
public enum Gender
{
Male,
Female
Female,
None
}

View File

@@ -9,10 +9,24 @@ public interface ISmsService
void Send(string number, string message);
bool VerifySend(string number, string message);
bool LoginSend(string number, string message);
/// <summary>
/// ارسال کد به کلاینت برای تکمیل فرایند ثبت نام
/// </summary>
/// <param name="number"></param>
/// <param name="code"></param>
/// <returns></returns>
Task<SentSmsViewModel> SendVerifyCodeToClient(string number, string code);
bool SendAccountsInfo(string number,string fullName, string userName);
Task<ApiResultViewModel> GetByMessageId(int messId);
Task<List<ApiResultViewModel>> GetApiResult(string startDate, string endDate);
string DeliveryStatus(byte? dv);
string DeliveryColorStatus(byte? dv);
string UnixTimeStampToDateTime(int? unixTimeStamp);
#region Mahan
Task<double> GetCreditAmount();
#endregion
}

View File

@@ -0,0 +1,32 @@
namespace _0_Framework.Application;
public class SentSmsViewModel
{
public SentSmsViewModel()
{
IsSuccedded = false;
}
public bool IsSuccedded { get; set; }
public string Message { get; set; }
public byte StatusCode { get; set; }
public int MessageId { get; set; }
public SentSmsViewModel Succedded(byte statusCode, string message, int messageId)
{
IsSuccedded = true;
Message = message;
StatusCode = statusCode;
MessageId = messageId;
return this;
}
public SentSmsViewModel Failed(byte statusCode, string message, int messageId)
{
IsSuccedded = false;
Message = message;
StatusCode = statusCode;
MessageId = messageId;
return this;
}
}

View File

@@ -9,6 +9,7 @@ using IPE.SmsIrClient;
using IPE.SmsIrClient.Models.Requests;
using IPE.SmsIrClient.Models.Results;
using Microsoft.Extensions.Configuration;
using static System.Runtime.InteropServices.JavaScript.JSType;
namespace _0_Framework.Application.Sms;
@@ -16,10 +17,14 @@ namespace _0_Framework.Application.Sms;
public class SmsService : ISmsService
{
private readonly IConfiguration _configuration;
public SmsIr SmsIr { get; set; }
public SmsService(IConfiguration configuration)
{
_configuration = configuration;
SmsIr = new SmsIr("Og5M562igmzJRhQPnq0GdtieYdLgtfikjzxOmeQBPxJjZtyge5Klc046Lfw1mxSa");
}
public void Send(string number, string message)
@@ -110,6 +115,31 @@ public class SmsService : ISmsService
}
}
public async Task<SentSmsViewModel> SendVerifyCodeToClient(string number, string code)
{
SmsIr smsIr = new SmsIr("Og5M562igmzJRhQPnq0GdtieYdLgtfikjzxOmeQBPxJjZtyge5Klc046Lfw1mxSa");
var result = new SentSmsViewModel();
//var bulkSendResult = smsIr.BulkSendAsync(95007079000006, "your text message", new string[] { "9120000000" });
var sendResult = await smsIr.VerifySendAsync(number, 768382, new VerifySendParameter[] { new VerifySendParameter("VerificationCode", code) });
Thread.Sleep(2000);
if (sendResult.Message == "موفق")
{
var status = sendResult.Status;
var message = sendResult.Message;
var messaeId = sendResult.Data.MessageId;
return result.Succedded(status, message, messaeId);
}
else
{
var status = sendResult.Status;
var message = sendResult.Message;
var messaeId = sendResult.Data.MessageId;
return result.Failed(status, message, messaeId);
}
}
public bool SendAccountsInfo(string number, string fullName, string userName)
{
@@ -285,4 +315,15 @@ public class SmsService : ISmsService
//var tokenService = new Token();
//return tokenService.GetToken("x-api-key", "Og5M562igmzJRhQPnq0GdtieYdLgtfikjzxOmeQBPxJjZtyge5Klc046Lfw1mxSa");
}
#region Mahan
public async Task<double> GetCreditAmount()
{
var credit = await SmsIr.GetCreditAsync();
return (double)credit.Data;
}
#endregion
}

View File

@@ -20,8 +20,9 @@ public static class StaticWorkshopAccounts
/// 3 - میلاد مصباح
/// 380 - افروز نظری
/// 381 - مهدی قربانی
/// 392 - عمار حسن دوست
/// </summary>
public static List<long> StaticAccountIds = [2, 3, 380, 381];
public static List<long> StaticAccountIds = [2, 3, 380, 381, 392];
/// <summary>
/// این تاریخ در جدول اکانت لفت ورک به این معنیست

View File

@@ -37,10 +37,12 @@
/// </summary>
public const int PersonnelStatusIndividualReportPermissionCode = 10205;
/// <summary>
/// لیست کل پرسنل
/// </summary>
public const int PersonnelListPermissionCode = 10206;
//کد 10206 به بخش عملیات پرسنل منتقل شد و رزرو می باشد
///// <summary>
///// لیست کل پرسنل
///// </summary>
//public const int PersonnelListPermissionCode = 10206;
#endregion
@@ -72,11 +74,22 @@
/// </summary>
public const int PaymentToEmployeePermissionCode = 10304;
/// <summary>
/// عملیات حساب بانکی پرسنل
/// </summary>
public const int EmployeeBankInformationPermissionCode = 10309;
/// <summary>
/// عملیات افزودن پرسنل
/// </summary>
public const int AddEmployeePermissionCode = 10310;
/// <summary>
/// عملیات افزودن پرسنل
/// </summary>
public const int LeftWorkEmployeePermissionCode = 10311;
/// <summary>
/// ایجاد وام
/// </summary>
@@ -190,6 +203,12 @@
public const int DeleteFinePermissionCode = 1030804;
#endregion
/// <summary>
/// لیست کل پرسنل
/// </summary>
public const int PersonnelListPermissionCode = 10206;
#endregion
@@ -562,13 +581,7 @@
Code = PersonnelStatusIndividualReportPermissionCode,
ParentId = WorkshopOperationsPermissionCode
};
public static SubAccountPermissionDto PersonnelListPermission { get; } = new()
{
Id = PersonnelListPermissionCode,
Name = "لیست کل پرسنل",
Code = PersonnelListPermissionCode,
ParentId = WorkshopOperationsPermissionCode
};
#endregion
#region عملیات پرسنل, ParentId = PersonnelOperationsPermissionCode
@@ -613,12 +626,35 @@
ParentId = PersonnelOperationsPermissionCode
};
#endregion
public static SubAccountPermissionDto AddEmployeeInformationPermission { get; } = new()
{
Id = AddEmployeePermissionCode,
Name = "عملیات افزودن پرسنل",
Code = AddEmployeePermissionCode,
ParentId = PersonnelOperationsPermissionCode
};
#region فیش حقوقی غیر رسمی,ParentId = CustomizeCheckoutOperationsPermissionCode
public static SubAccountPermissionDto LeftWorkEmployeeInformationPermission { get; } = new()
{
Id = LeftWorkEmployeePermissionCode,
Name = "عملیات ترک کار پرسنل",
Code = LeftWorkEmployeePermissionCode,
ParentId = PersonnelOperationsPermissionCode
};
public static SubAccountPermissionDto PersonnelListPermission { get; } = new()
{
Id = PersonnelListPermissionCode,
Name = "لیست کل پرسنل",
Code = PersonnelListPermissionCode,
ParentId = PersonnelOperationsPermissionCode
};
#endregion
#region فیش حقوقی غیر رسمی,ParentId = CustomizeCheckoutOperationsPermissionCode
public static SubAccountPermissionDto CustomizeCheckoutSetGroupAndSalaryPermission { get; } = new()
public static SubAccountPermissionDto CustomizeCheckoutSetGroupAndSalaryPermission { get; } = new()
{
Id = CustomizeCheckoutSetGroupAndSalaryPermissionCode,
Name = "تنظیم گروه بندی و حقوق پرسنل",

View File

@@ -19,6 +19,7 @@ using Microsoft.Extensions.Logging;
using System.IO.Compression;
using System.Linq;
using _0_Framework.Domain.CustomizeCheckoutShared.Base;
using System.ComponentModel.DataAnnotations;
namespace _0_Framework.Application;
@@ -32,6 +33,15 @@ public static class Tools
public static string[] DayNames = { "شنبه", "یکشنبه", "دو شنبه", "سه شنبه", "چهار شنبه", "پنج شنبه", "جمعه" };
public static string[] DayNamesG = { "یکشنبه", "دو شنبه", "سه شنبه", "چهار شنبه", "پنج شنبه", "جمعه", "شنبه" };
public static bool IsMobileValid(this string mobileNo)
{
if (mobileNo.Length < 11)
return false;
return Regex.IsMatch(mobileNo, "^((09))(\\d{9})$");
}
/// <summary>
/// دریافت روزهای کارکرد پرسنل در لیست بیمه ماه مشخص شده
/// با کمک شروع بکار و ترک کار
@@ -42,81 +52,81 @@ public static class Tools
/// <param name="endDate"></param>
/// <param name="employeeId"></param>
/// <returns></returns>
public static (int countWorkingDays,DateTime startWork,DateTime endWork,bool hasStartWorkInMonth,bool hasLeftWorkInMonth) GetEmployeeInsuranceWorkingDays(DateTime startWork,DateTime? leftWork,DateTime startDate,
DateTime endDate,long employeeId)
public static (int countWorkingDays, DateTime startWork, DateTime endWork, bool hasStartWorkInMonth, bool hasLeftWorkInMonth) GetEmployeeInsuranceWorkingDays(DateTime startWork, DateTime? leftWork, DateTime startDate,
DateTime endDate, long employeeId)
{
DateTime start = startDate;
DateTime start = startDate;
DateTime end = endDate;
bool startWorkInMonth = false;
bool endWorkInMonth = false;
//اگر شروع بکار پرسنل در ماه مشخص شده لیست بیمه بود
if (startWork >= startDate)
{
start = startWork;
startWorkInMonth = true;
start = startWork;
startWorkInMonth = true;
}
if(leftWork == null)
if (leftWork == null)
leftWork = DateTime.MinValue;
//اگر ترک کار پرسنل در ماه مشخص شده لیست بیمه بود
if (leftWork != DateTime.MinValue && leftWork.Value < endDate)
{
end = leftWork.Value;
end = leftWork.Value;
endWorkInMonth = true;
}
int countDays = (int)(end - start).TotalDays +1;
int countDays = (int)(end - start).TotalDays + 1;
//روزهای کارکرد پرسنل با آی دی های زیر دستی تعریف شد
switch (employeeId)
{
//case 3812://ثابت- کسری حاجی پور
// countWorkingDays = 15;
// break;
case 40463://ثابت
countDays = 10;
break;
case 40469://ثابت
countDays = 7;
break;
//case 9950://ثابت
// countDays = 15;
//break;
case 9640://ثابت
countDays = 15;
break;
case 40998://ثابت
countDays = 15;
break;
case 6219://ثابت
countDays = 15;
break;
//case 7897://ثابت
// countWorkingDays = 15;
//case 3812://ثابت- کسری حاجی پور
// countWorkingDays = 15;
// break;
case 40463://ثابت
countDays = 10;
break;
case 40469://ثابت
countDays = 7;
break;
//case 9950://ثابت
// countDays = 15;
//break;
case 9640://ثابت
countDays = 15;
break;
case 40998://ثابت
countDays = 15;
break;
case 6219://ثابت
countDays = 15;
break;
//case 7897://ثابت
// countWorkingDays = 15;
}
return (countDays,start,end,startWorkInMonth,endWorkInMonth);
return (countDays, start, end, startWorkInMonth, endWorkInMonth);
}
/// <summary>
/// محاسبه سن
/// </summary>
/// <param name="startDate"></param>
/// <param name="endDate"></param>
/// <returns></returns>
public static (int yearCount, int monthCount, int dayCount) GetAge(DateTime startDate, DateTime endDate)
/// <summary>
/// محاسبه سن
/// </summary>
/// <param name="startDate"></param>
/// <param name="endDate"></param>
/// <returns></returns>
public static (int yearCount, int monthCount, int dayCount) GetAge(DateTime startDate, DateTime endDate)
{
var startFa = startDate.ToFarsi();
int startYear = Convert.ToInt32(startFa.Substring(0, 4));
int startMonth = Convert.ToInt32(startFa.Substring(5, 2));
int startDay = Convert.ToInt32(startFa.Substring(8, 2));
var start = new PersianDateTime(startYear, startMonth, startDay);
var endFa = endDate.ToFarsi();
int endYear = Convert.ToInt32(endFa.Substring(0, 4));
int endMonth = Convert.ToInt32(endFa.Substring(5, 2));
@@ -131,7 +141,7 @@ public static class Tools
if (firstYearCounter > end)
{
start = start.AddYears(-1);
var endMonthCounter = new PersianDateTime(end.Year, end.Month, start.Day);
for (var monthCounter = start; monthCounter <= end; monthCounter = monthCounter.AddMonths(1))
@@ -183,7 +193,7 @@ public static class Tools
if (yearCouner.Year == end.Year)
{
var endMonthCounter = new PersianDateTime(end.Year, end.Month, (yearCouner.Day > end.Day ? end.Day : yearCouner.Day));
var endMonthCounter = new PersianDateTime(end.Year, end.Month, (yearCouner.Day > end.Day ? end.Day : yearCouner.Day));
if (yearCouner.Day <= end.Day)
{
@@ -234,7 +244,7 @@ public static class Tools
Console.ResetColor();
Console.WriteLine($"old: [{years} year] ، [{months} month] ، [{days} day]");
return (years,months,days);
return (years, months, days);
}
public static string ToFarsi(this DateTime? date)
@@ -387,9 +397,9 @@ public static class Tools
public static DateTime ToGeorgianDateTime(this string persianDate)
{
persianDate = persianDate.ToEnglishNumber();
try
{
persianDate = persianDate.ToEnglishNumber();
var year = Convert.ToInt32(persianDate.Substring(0, 4));
var month = Convert.ToInt32(persianDate.Substring(5, 2));
var day = Convert.ToInt32(persianDate.Substring(8, 2));
@@ -778,8 +788,8 @@ public static class Tools
{
case "0000000000":
case "1111111111":
case "22222222222":
case "33333333333":
case "2222222222":
case "3333333333":
case "4444444444":
case "5555555555":
case "6666666666":
@@ -1257,16 +1267,16 @@ public static class Tools
var part5 = parts[5].Substring(0, 2);
try
try
{
PersianCalendar pc = new PersianCalendar();
dateTime = pc.ToDateTime(int.Parse(parts[1]), int.Parse(parts[2]), int.Parse(parts[3]), int.Parse(parts[4]), int.Parse(part5), 0, 0, 0);
dateTime = pc.ToDateTime(int.Parse(parts[1]), int.Parse(parts[2]), int.Parse(parts[3]), int.Parse(parts[4]), int.Parse(part5), 0, 0, 0);
}
catch (Exception e)
{
}
}
@@ -1374,18 +1384,44 @@ public static class Tools
}
public static DateTime FindFirstDayOfMonthGr(this DateTime date)
{
var pc = new PersianCalendar();
return ($"{pc.GetYear(date)}/{pc.GetMonth(date):00}/01").ToGeorgianDateTime();
var pc = new PersianCalendar();
return ($"{pc.GetYear(date)}/{pc.GetMonth(date):00}/01").ToGeorgianDateTime();
}
#region Mahan
/// <summary>
/// این متد سعی میکند رشته را به تاریخ برگرداند و یک بول و دیت تایم برمیگرداند
/// </summary>
/// <param name="persianDate">تاریخ شمسی</param>
/// <param name="georgianDateTime">تاریخ</param>
/// <returns></returns>
public static bool TryToGeorgianDateTime(this string persianDate, out DateTime georgianDateTime)
#region Mahan
/// <summary>
/// این متد حروف عربی را به فارسی در میاورد. مثال: علي را به علی تبدیل میکند
/// </summary>
/// <param name="text"></param>
/// <returns></returns>
public static string ToPersian(this string text)
{
var res = "";
foreach (var @char in text)
{
if (@char == char.Parse("ي"))
res += "ی";
else
res += @char;
}
return res;
}
/// <summary>
/// این متد سعی میکند رشته را به تاریخ برگرداند و یک بول و دیت تایم برمیگرداند
/// </summary>
/// <param name="persianDate">تاریخ شمسی</param>
/// <param name="georgianDateTime">تاریخ</param>
/// <returns></returns>
public static bool TryToGeorgianDateTime(this string persianDate, out DateTime georgianDateTime)
{
if (string.IsNullOrWhiteSpace(persianDate))
{
georgianDateTime = new DateTime(3000, 12, 20, new PersianCalendar());
return false;
}
persianDate = persianDate.ToEnglishNumber();
try
{
@@ -1552,19 +1588,19 @@ public static class Tools
public static TimeOnly CalculateOffset(ICollection<CustomizeSifts> shiftDetailsRegularShifts)
{
if (!shiftDetailsRegularShifts.Any())
{
return TimeOnly.MinValue;
}
var date = new DateOnly();
var firstStartShift = new DateTime(date, shiftDetailsRegularShifts.MinBy(x => x.Placement).StartTime);
var lastEndShift = new DateTime(date, shiftDetailsRegularShifts.MaxBy(x => x.Placement).EndTime);
if (lastEndShift > firstStartShift)
firstStartShift = firstStartShift.AddDays(1);
var offSet = (firstStartShift - lastEndShift).Divide(2);
return TimeOnly.FromDateTime(lastEndShift.Add(offSet));
if (!shiftDetailsRegularShifts.Any())
{
return TimeOnly.MinValue;
}
var date = new DateOnly();
var firstStartShift = new DateTime(date, shiftDetailsRegularShifts.MinBy(x => x.Placement).StartTime);
var lastEndShift = new DateTime(date, shiftDetailsRegularShifts.MaxBy(x => x.Placement).EndTime);
if (lastEndShift > firstStartShift)
firstStartShift = firstStartShift.AddDays(1);
var offSet = (firstStartShift - lastEndShift).Divide(2);
return TimeOnly.FromDateTime(lastEndShift.Add(offSet));
}
public static DateTime GetNextDayOfWeek(this DateTime date, DayOfWeek dayOfWeek)
public static DateTime GetNextDayOfWeek(this DateTime date, DayOfWeek dayOfWeek)
{
int numberOfNextDayOfWeek = ((int)dayOfWeek - (int)date.DayOfWeek + 7) % 7;
return date.AddDays(numberOfNextDayOfWeek == 0 ? 7 : numberOfNextDayOfWeek);
@@ -1644,6 +1680,10 @@ public static class Tools
}
#endregion
#region Pooya
@@ -1736,75 +1776,75 @@ public static class Tools
public static string ToFarsiHoursAndMinutes(int hours, int minutes, string emptyValue = "")
{
string message = emptyValue;
if (hours > 0 && minutes > 0)
{
string message = emptyValue;
if (hours > 0 && minutes > 0)
{
message = hours + " " + "ساعت و" + " " + minutes + " " + "دقیقه";
}
else if (hours > 0 && minutes == 0)
{
message = hours + " " + "ساعت و" + " " + minutes + " " + "دقیقه";
}
else if (hours > 0 && minutes == 0)
{
message = hours + " " + "ساعت ";
}
else if (hours == 0 && minutes > 0)
{
message = hours + " " + "ساعت ";
}
else if (hours == 0 && minutes > 0)
{
message = minutes + " " + "دقیقه";
}
message = minutes + " " + "دقیقه";
}
return message;
return message;
}
public static string ToFarsiHoursAndMinutes(this TimeSpan timeSpan, string emptyValue = "")
public static string ToFarsiHoursAndMinutes(this TimeSpan timeSpan, string emptyValue = "")
{
var hours = (int)timeSpan.TotalHours;
var minutes = timeSpan.Minutes;
string message = emptyValue;
if (hours > 0 && minutes > 0)
{
var hours = (int)timeSpan.TotalHours;
var minutes = timeSpan.Minutes;
string message = emptyValue;
if (hours > 0 && minutes > 0)
{
message = hours + " " + "ساعت و" + " " + minutes + " " + "دقیقه";
}
else if (hours > 0 && minutes == 0)
{
message = hours + " " + "ساعت و" + " " + minutes + " " + "دقیقه";
}
else if (hours > 0 && minutes == 0)
{
message = hours + " " + "ساعت ";
}
else if (hours == 0 && minutes > 0)
{
message = hours + " " + "ساعت ";
}
else if (hours == 0 && minutes > 0)
{
message = minutes + " " + "دقیقه";
}
message = minutes + " " + "دقیقه";
}
return message;
return message;
}
public static string ToFarsiDaysAndHoursAndMinutes(this TimeSpan timeSpan, string emptyValue = "")
{
var hours = (int)timeSpan.TotalHours;
var minutes = timeSpan.Minutes;
var days = hours / 24;
hours = hours % 24;
string message = "";
public static string ToFarsiDaysAndHoursAndMinutes(this TimeSpan timeSpan, string emptyValue = "")
{
var hours = (int)timeSpan.TotalHours;
var minutes = timeSpan.Minutes;
var days = hours / 24;
hours = hours % 24;
string message = "";
if (days > 0)
message += days + " " + "روز";
if (hours > 0)
if (message == "")
message += hours + " " + "ساعت";
else
message += " و " + hours + " " + "ساعت";
if (minutes > 0)
if (message == "")
message += minutes + " " + "دقیقه";
else
message += " و " + minutes + " " + "دقیقه";
if (days > 0)
message += days + " " + "روز";
if (hours > 0)
if (message == "")
message += hours + " " + "ساعت";
else
message += " و " + hours + " " + "ساعت";
if (minutes > 0)
if (message == "")
message += minutes + " " + "دقیقه";
else
message += " و " + minutes + " " + "دقیقه";
if (message == "")
message = emptyValue;
return message;
}
if (message == "")
message = emptyValue;
return message;
}
public static bool ArePropertiesEqual<T>(this T obj1, T obj2)
public static bool ArePropertiesEqual<T>(this T obj1, T obj2)
{
// If either object is null, they can't be equal
if (obj1 == null || obj2 == null)
@@ -1837,5 +1877,44 @@ public static class Tools
return true;
}
#endregion
#region Davoodi
public static List<string> GetDaysBetweenDateGeorgian(DateTime startDate, DateTime? endDate)
{
var days = new List<string>();
if (endDate == null)
endDate = DateTime.Now;
var persianStartDate = new MD.PersianDateTime.Standard.PersianDateTime(startDate);
var persianEndDate = new MD.PersianDateTime.Standard.PersianDateTime(endDate);
while (persianEndDate - persianStartDate >= TimeSpan.FromDays(0))
{
days.Add(persianStartDate.ToShortDateString());
persianStartDate = persianStartDate.AddDays(1);
}
return days;
}
public static int GetWorkingDaysDifference(DateTime? fromDate, DateTime? toDate)
{
//var workingDays = PersianDateExtensions.GetWorkingDays(new PersianDateTime(fromDate.ToFarsi()), new PersianDateTime(toDate.ToFarsi()), true);
var workingDays = PersianDateExtensions.GetWorkingDays((DateTime)fromDate, (DateTime)toDate, true);
if (fromDate > toDate)
workingDays *= -1;
return workingDays;
}
#endregion
}

View File

@@ -32,11 +32,24 @@ public class UidService : IUidService
var json = JsonConvert.SerializeObject(request);
var contentType = new StringContent(json, Encoding.UTF8, "application/json");
var requestResult = await _httpClient.PostAsync("person/v2", contentType);
if(!requestResult.IsSuccessStatusCode)
return null;
var responseResult = await requestResult.Content.ReadFromJsonAsync<PersonalInfoResponse>();
return responseResult;
try
{
var requestResult = await _httpClient.PostAsync("person/v2", contentType);
if (!requestResult.IsSuccessStatusCode)
return null;
var responseResult = await requestResult.Content.ReadFromJsonAsync<PersonalInfoResponse>();
responseResult.BasicInformation.FirstName = responseResult.BasicInformation.FirstName.ToPersian();
responseResult.BasicInformation.LastName = responseResult.BasicInformation.LastName.ToPersian();
responseResult.BasicInformation.FatherName = responseResult.BasicInformation.FatherName.ToPersian();
return responseResult;
}
catch (Exception)
{
return null;
}
}
@@ -50,12 +63,19 @@ public class UidService : IUidService
};
var json = JsonConvert.SerializeObject(request);
var contentType = new StringContent(json, Encoding.UTF8, "application/json");
try
{
var requestResult = await _httpClient.PostAsync("mobile/owner/v2", contentType);
if (!requestResult.IsSuccessStatusCode)
return null;
var requestResult = await _httpClient.PostAsync("mobile/owner/v2", contentType);
if (!requestResult.IsSuccessStatusCode)
var responseResult = await requestResult.Content.ReadFromJsonAsync<MatchMobileWithNationalCodeResponse>();
return responseResult;
}
catch (Exception e)
{
return null;
}
var responseResult = await requestResult.Content.ReadFromJsonAsync<MatchMobileWithNationalCodeResponse>();
return responseResult;
}
}

View File

@@ -8,7 +8,8 @@ namespace _0_Framework.Application
Client,
SubAccount,
Camera,
Admin
Admin,
System
}
}

View File

@@ -1,231 +0,0 @@
using System.Collections.Generic;
using System.Drawing;
using System.IO;
using System.Linq;
using _0_Framework.Application;
using OfficeOpenXml;
namespace _0_Framework.Excel.Checkout;
using OfficeOpenXml;
using OfficeOpenXml.Style;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
public class CustomizeCheckoutExcelGenerator
{
public static byte[] GenerateCheckoutTempExcelInfo(List<CustomizeCheckoutTempExcelViewModel> data, List<string> selectedParameters)
{
OfficeOpenXml.ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
using var package = new ExcelPackage();
var worksheet = package.Workbook.Worksheets.Add("Sheet1");
// Define headers
Dictionary<string, string> headers = new Dictionary<string, string>
{
{ "Month", "ماه" },
{ "Year", "سال" },
{ "EmployeeFullName", "نام و نام خانوادگی" },
{ "PersonnelCodeString", "شماره پرسنلی" },
{ "NationalCode", "کدملی" },
{ "SumOfWorkingDays", "روز کارکرد" },
{ "MonthlySalary", "حقوق ماهانه" },
{ "BaseYearsPay", "سنوات" },
{ "MarriedAllowance", "حق تاهل" },
{ "OvertimePay", "اضافه کاری" },
{ "NightworkPay", "شب کاری" },
{ "FridayPay", "جمعه کاری" },
{ "MissionPay", "مأموریت" },
{ "ShiftPay", "نوبت کاری" },
{ "FamilyAllowance", "حق فرزند" },
{ "BonusesPay", "پاداش" },
{ "LeavePay", "مزد مرخصی" },
{ "RewardPay", "پاداش" },
{ "FineDeduction", "جریمه" },
{ "InsuranceDeduction", "حق بیمه" },
{ "TaxDeducation", "مالیات" },
{ "InstallmentDeduction", "قسط وام" },
{ "SalaryAidDeduction", "مساعده" },
{ "AbsenceDeduction", "غیبت" },
{ "EarlyExitDeduction", "تعجیل در خروج" },
{ "LateToWorkDeduction", "تاخیر در ورود" },
{ "TotalClaims", "جمع مطالبات" },
{ "TotalDeductions", "جمع کسورات" },
{ "TotalPayment", "مبلغ قابل پرداخت" },
{ "CardNumber", "شماره کارت" },
{ "ShebaNumber", "شماره شبا" },
{ "BankAccountNumber", "شماره حساب" },
};
Dictionary<string, string> filteredHeaders;
if (!selectedParameters.Any())
{
filteredHeaders = headers;
}
else
{
// Filter headers based on selected parameters
filteredHeaders = headers.Where(h => selectedParameters.Contains(h.Key)).ToDictionary();
}
var indexCell = worksheet.Cells[1, 1];
indexCell.Value = "ردیف";
ApplyHeaderStyle(indexCell);
// Add headers to worksheet
for (int i = 0; i < filteredHeaders.Count; i++)
{
worksheet.Cells[1, i + 2].Value = filteredHeaders.ElementAt(i).Value;
ApplyHeaderStyle(worksheet.Cells[1, i + 2]);
}
var dataRow = 2;
int totalPaymentColumnIndex = -1;
foreach (var item in data)
{
var column = 2;
foreach (var header in filteredHeaders)
{
var property = item.GetType().GetProperty(header.Key);
var value = property.GetValue(item, null)?.ToString();
// Check if the property requires MoneyToDouble()
if (RequiresMoneyToDouble(property.Name))
{
worksheet.Cells[dataRow, column].Value = MoneyToDouble(value);
}
else
{
worksheet.Cells[dataRow, column].Value = value;
}
ApplyGeneralDataStyle(worksheet.Cells[dataRow, column]);
ApplySpecificStyle(worksheet.Cells[dataRow, column], column); // Apply specific styles
if (header.Key == "TotalPayment")
{
totalPaymentColumnIndex = column;
}
column++;
}
var rowCounter = worksheet.Cells[dataRow, 1];
rowCounter.Value = dataRow - 1;
ApplyGeneralDataStyle(rowCounter);
ApplySpecificStyle(rowCounter, 1);
dataRow++;
}
worksheet.Cells[worksheet.Dimension.Address].AutoFitColumns();
worksheet.PrinterSettings.PaperSize = ePaperSize.A4;
worksheet.PrinterSettings.Orientation = eOrientation.Landscape;
worksheet.PrinterSettings.FitToPage = true;
worksheet.PrinterSettings.FitToWidth = 1;
worksheet.PrinterSettings.FitToHeight = 0;
worksheet.PrinterSettings.Scale = 85;
worksheet.View.RightToLeft = true;
if (totalPaymentColumnIndex != -1)
{
ApplyConditionalFormatting(worksheet, dataRow, totalPaymentColumnIndex);
}
return package.GetAsByteArray();
}
// Method to check if a property requires MoneyToDouble()
private static bool RequiresMoneyToDouble(string propertyName)
{
var propertiesRequiringConversion = new HashSet<string>
{
"MonthlySalary", "RewardPay", "FridayPay", "OvertimePay", "ShiftPay", "NightWorkPay",
"MarriedAllowance", "FamilyAllowance", "BonusesPay", "BaseYearsPay", "LeavePay",
"AbsenceDeduction", "LateToWorkDeduction", "EarlyExitDeduction", "SalaryAidDeduction",
"InstallmentDeduction", "FineDeduction", "InsuranceDeduction", "TaxDeduction",
"TotalClaims", "TotalDeductions", "TotalPayment"
};
return propertiesRequiringConversion.Contains(propertyName);
}
// Placeholder for the MoneyToDouble() method
private static double MoneyToDouble(string value)
{
Console.WriteLine(value);
var min = value.Length>1? value.Substring(0, 2): "";
var test = min == "\u200e\u2212" ? value.MoneyToDouble() * -1 : value.MoneyToDouble();
Console.WriteLine(test);
return test;
}
private static void ApplyHeaderStyle(ExcelRange cell)
{
cell.Style.Font.Bold = true;
cell.Style.Fill.PatternType = ExcelFillStyle.Solid;
cell.Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.LightGray);
cell.Style.HorizontalAlignment = ExcelHorizontalAlignment.Center;
cell.Style.Border.BorderAround(ExcelBorderStyle.Thin);
}
private static void ApplyGeneralDataStyle(ExcelRange cell)
{
cell.Style.Border.BorderAround(ExcelBorderStyle.Thin);
cell.Style.HorizontalAlignment = ExcelHorizontalAlignment.Center;
cell.Style.VerticalAlignment = ExcelVerticalAlignment.Center;
cell.Style.Fill.PatternType = ExcelFillStyle.Solid;
}
private static void ApplySpecificStyle(ExcelRange cell, int columnIndex)
{
switch (columnIndex)
{
case int n when (n >= 1 && n <= 8):
cell.Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.LightYellow);
break;
case int n when (n >= 9 && n <= 19):
cell.Style.Fill.BackgroundColor.SetColor(1, 208, 248, 208);
cell.Style.Numberformat.Format = "#,##0";
break;
case int n when (n >= 20 && n <= 27):
cell.Style.Fill.BackgroundColor.SetColor(1, 246, 176, 176);
cell.Style.Numberformat.Format = "#,##0";
break;
case 28:
cell.Style.Fill.BackgroundColor.SetColor(1, 169, 208, 142);
cell.Style.Numberformat.Format = "#,##0";
break;
case 29:
cell.Style.Fill.BackgroundColor.SetColor(1, 241, 143, 143);
cell.Style.Numberformat.Format = "#,##0";
break;
case 30:
cell.Style.Fill.BackgroundColor.SetColor(1, 168, 186, 254);
cell.Style.Numberformat.Format = "#,##0";
break;
case >= 31 and <= 33:
cell.Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.LightYellow);
break;
}
}
private static void ApplyConditionalFormatting(ExcelWorksheet worksheet, int dataRow, int totalPaymentColumnIndex)
{
for (int rowIndex = 2; rowIndex < dataRow; rowIndex++)
{
var totalPaymentValue = worksheet.Cells[rowIndex, totalPaymentColumnIndex].Value;
if (totalPaymentValue != null && double.TryParse(totalPaymentValue.ToString(), out double payment))
{
if (payment < 0)
{
var rowRange = worksheet.Cells[rowIndex, 1, rowIndex, worksheet.Dimension.End.Column];
rowRange.Style.Fill.PatternType = ExcelFillStyle.Solid; rowRange.Style.Fill.BackgroundColor.SetColor(Color.Red);
foreach (var cell in rowRange)
{
cell.Style.Font.Color.SetColor(Color.White);
}
}
}
}
}
}

View File

@@ -55,4 +55,11 @@ public interface IAccountApplication
#endregion
OperationResult DirectCameraLogin(long cameraAccountId);
/// <summary>
/// چک میکند که آیا اکانتی با این نام کاربری وجود دارد یا نه
/// </summary>
/// <param name="userName"></param>
/// <returns></returns>
public bool CheckExistClientAccount(string userName);
}

View File

@@ -1,4 +1,5 @@
using System.Collections.Generic;
using IPE.SmsIrClient.Models.Results;
using Microsoft.AspNetCore.Http;
namespace AccountManagement.Application.Contracts.Task;
@@ -19,9 +20,9 @@ public class CreateTask
#region Task Schedule
public string ScheduleCount { get; set; }
public string ScheduleType{ get; set; }
public TaskScheduleType ScheduleType { get; set; }
public bool HasSchedule { get; set; }
public string ScheduleUnitType { get; set; }
public TaskScheduleUnitType ScheduleUnitType { get; set; }
public string ScheduleUnitNumber { get; set; }
public long TaskScheduleId { get; set; }
@@ -30,4 +31,18 @@ public class CreateTask
}
public enum TaskScheduleType
{
Limited,
Unlimited
}
public enum TaskScheduleUnitType
{
Day,
Week,
Month,
Year
}

View File

@@ -20,4 +20,5 @@ public class EditTask:CreateTask
public long? TicketId { get; set; }
public List<AccountViewModel> AssignsLists { get; set; }
public bool HasTicket { get; set; }
public long TaskScheduleId { get; set; }
}

View File

@@ -1,4 +1,5 @@
using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework.Application;
using AccountManagement.Application.Contracts.Assign;
using AccountManagement.Application.Contracts.TaskMessage;
@@ -24,6 +25,13 @@ public interface ITaskApplication
List<TaskViewModel> GetSentTasks(TaskSearchModel searchModel);
List<TaskViewModel> GetTasksHaveTicket(TaskSearchModel searchModel);
/// <summary>
/// لیست تسک های دوره ای ایجاد شده توسط کاربر
/// </summary>
/// <param name="searchModel"></param>
/// <returns></returns>
List<TaskViewModel> GetTaskScheduleList(TaskSearchModel searchModel);
// گرفتن مهلت برای یک وظیفه
OperationResult CreateRequestTime(CreateTaskTimeRequest command);
List<TaskViewModel> GetRequestTaskHasTicket(TaskSearchModel searchModel);
@@ -46,10 +54,10 @@ public interface ITaskApplication
OperationResult CreateTaskByPosition(CreateTask command, List<long> positionIds);
List<TaskViewModel> GetRequestedTasks(TaskSearchModel searchModel);
List<TaskViewModel> AllRequestedTasks(TaskSearchModel searchModel);
int GetRequestedTasksCount();
Task<int> GetRequestedTasksCount();
int TasksHaveTicketCounts(long userId);
int TasksHaveTicketRequestsCount(long userId);
Task<int> TasksHaveTicketCounts(long userId);
Task<int> TasksHaveTicketRequestsCount(long userId);
List<TaskMessageViewModel> GetTaskMessages(long assignId);
@@ -63,16 +71,14 @@ public interface ITaskApplication
List<AssignViewModel> GetAssignsByTaskId(long taskId);
int RequestedAndOverdueTasksCount(long userId);
Task<int> RequestedAndOverdueTasksCount(long userId);
/// <summary>
///تعداد تسک های شخصی و دریافتی برای امروز و یا عقب افتاده
/// </summary>
/// <param name="userId"></param>
/// <returns></returns>
int OverdueTasksCount(long userId);
/// <summary>
/// تعداد تسک های شخصی و دریافتی برای امروز و یا عقب افتاده
/// </summary>
/// <param name="userId"></param>
/// <returns></returns>
Task<int> OverdueTasksCount(long userId);
//متد انتقال داده از تسک به ارجاعی ها
//OperationResult MoveDataFRomTaskToAssign();
}
}

View File

@@ -50,5 +50,7 @@ public class TaskViewModel
public bool CanCheckRequests { get; set; }
public AssignViewModel AssignedReceiverViewModel { get; set; }
public TaskScheduleType ScheduleType { get; set; }
public TaskScheduleUnitType ScheduleUnitType { get; set; }
public long TaskScheduleId { get; set; }
}

View File

@@ -1,4 +1,6 @@
using _0_Framework.Application;
using System;
using System.Threading.Tasks;
using _0_Framework.Application;
using AccountManagement.Application.Contracts.Task;
namespace AccountManagement.Application.Contracts.TaskSchedule;
@@ -6,7 +8,8 @@ namespace AccountManagement.Application.Contracts.TaskSchedule;
public interface ITaskScheduleApplication
{
OperationResult Create(CreateTask command);
OperationResult CreateLimitedTasks(CreateTask command);
OperationResult CreateUnlimitedTasks(CreateTask command);
Task<TaskScheduleDetailsViewModel> GetDetails(long id);
OperationResult Remove(long taskScheduleId);
}

View File

@@ -0,0 +1,20 @@
using System.Collections.Generic;
using AccountManagement.Application.Contracts.Media;
using AccountManagement.Application.Contracts.Task;
namespace AccountManagement.Application.Contracts.TaskSchedule;
public class TaskScheduleDetailsViewModel
{
public string SenderName { get; set; }
public List<string> AssignedName { get; set; }
public TaskScheduleType TaskScheduleType { get; set; }
public TaskScheduleUnitType TaskScheduleUnitType { get; set; }
public string UnitNumber { get; set; }
public string CreationDateFa { get; set; }
public string ContractingPartyName { get; set; }
public string Title { get; set; }
public string Description { get; set; }
public List<MediaViewModel> Medias { get; set; }
}

View File

@@ -549,7 +549,8 @@ public class AccountApplication : IAccountApplication
return operation.Succcedded(2);
}
public AccountLeftWorkViewModel WorkshopList(long accountId)
public AccountLeftWorkViewModel WorkshopList(long accountId)
{
string fullname = this._accountRepository.GetById(accountId).Fullname;
List<WorkshopAccountlistViewModel> source =_accountLeftworkRepository.WorkshopList(accountId);
@@ -785,4 +786,10 @@ public class AccountApplication : IAccountApplication
//}
#endregion
public bool CheckExistClientAccount(string userName)
{
return _accountRepository.CheckExistClientAccount(userName);
}
}

View File

@@ -16,6 +16,7 @@ using System.Collections.Generic;
using System.Globalization;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
namespace AccountManagement.Application;
@@ -508,6 +509,11 @@ public class TaskApplication : ITaskApplication
return _taskRepository.GetTasksHaveTicket(searchModel);
}
public List<TaskViewModel> GetTaskScheduleList(TaskSearchModel searchModel)
{
return _taskRepository.GetTaskScheduleList(searchModel);
}
//ساخت درخواست مهلت
public OperationResult CreateRequestTime(CreateTaskTimeRequest command)
{
@@ -589,6 +595,9 @@ public class TaskApplication : ITaskApplication
{
return operation.Failed("تاریخی برای درخواست وظیفه ثبت نشده است");
}
assign.AcceptTimeRequest();
message = string.IsNullOrWhiteSpace(message) ? "درخواست شما مورد تایید قرار گرفت" : message;
var messageEntity = new TaskMessage(message, "تایید درخواست مهلت", assign.id);
@@ -865,14 +874,14 @@ public class TaskApplication : ITaskApplication
return _taskRepository.AllRequestedTasks(searchModel);
}
public int TasksHaveTicketCounts(long userId)
public async Task<int> TasksHaveTicketCounts(long userId)
{
return _taskRepository.TasksHaveTicketCounts(userId);
return await _taskRepository.TasksHaveTicketCounts(userId);
}
public int TasksHaveTicketRequestsCount(long userId)
public async Task<int> TasksHaveTicketRequestsCount(long userId)
{
return _taskRepository.TasksHaveTicketRequestsCount(userId);
return await _taskRepository.TasksHaveTicketRequestsCount(userId);
}
@@ -881,9 +890,9 @@ public class TaskApplication : ITaskApplication
return _taskMessageRepository.GetTaskMessages(assignId);
}
public int GetRequestedTasksCount()
public async Task<int> GetRequestedTasksCount()
{
return _taskRepository.GetRequestedTasksCount();
return await _taskRepository.GetRequestedTasksCount();
}
public OperationResult ChangeRequestTimeAndAccept(string time, long taskId, long assignedId, string message)
@@ -1007,15 +1016,15 @@ public class TaskApplication : ITaskApplication
return _assignRepository.GetAssignsByTaskId(taskId);
}
public int RequestedAndOverdueTasksCount(long userId)
public async Task<int> RequestedAndOverdueTasksCount(long userId)
{
return _taskRepository.RequestedAndOverdueTasksCount(userId);
return await _taskRepository.RequestedAndOverdueTasksCount(userId);
}
public int OverdueTasksCount(long userId)
public async Task<int> OverdueTasksCount(long userId)
{
return _taskRepository.OverdueTasksCount(userId);
return await _taskRepository.OverdueTasksCount(userId);
}
//public OperationResult MoveDataFRomTaskToAssign()

View File

@@ -4,222 +4,355 @@ using AccountManagement.Application.Contracts.TaskSchedule;
using AccountManagement.Domain.TaskScheduleAgg;
using System;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using System.Transactions;
using AccountManagement.Domain.TaskAgg;
using Company.Domain.HolidayItemAgg;
namespace AccountManagement.Application;
public class TaskScheduleApplication : ITaskScheduleApplication
{
private readonly ITaskApplication _taskApplication;
private readonly ITaskScheduleRepository _taskScheduleRepository;
private readonly IHolidayItemRepository _holidayItemRepository;
private readonly ITaskApplication _taskApplication;
private readonly ITaskScheduleRepository _taskScheduleRepository;
private readonly IHolidayItemRepository _holidayItemRepository;
private readonly ITaskRepository _taskRepository;
public TaskScheduleApplication(ITaskApplication taskApplication, ITaskScheduleRepository taskScheduleRepository, IHolidayItemRepository holidayItemRepository, ITaskRepository taskRepository)
{
_taskApplication = taskApplication;
_taskScheduleRepository = taskScheduleRepository;
_holidayItemRepository = holidayItemRepository;
_taskRepository = taskRepository;
}
public TaskScheduleApplication(ITaskApplication taskApplication, ITaskScheduleRepository taskScheduleRepository, IHolidayItemRepository holidayItemRepository)
{
_taskApplication = taskApplication;
_taskScheduleRepository = taskScheduleRepository;
_holidayItemRepository = holidayItemRepository;
}
public OperationResult Create(CreateTask command)
{
OperationResult operation = new OperationResult();
public OperationResult Create(CreateTask command)
{
OperationResult operation = new OperationResult();
if (command.HasSchedule)
{
switch (command.ScheduleType)
{
case "limited":
if (Convert.ToInt32(command.ScheduleCount) > 60)
{
return operation.Failed("تعداد وارد شده بیشتر از حد مجاز است");
}
return CreateLimitedTasks(command);
break;
if (command.HasSchedule)
{
switch (command.ScheduleType)
{
case TaskScheduleType.Limited:
if (Convert.ToInt32(command.ScheduleCount) > 60)
{
return operation.Failed("تعداد وارد شده بیشتر از حد مجاز است");
}
return CreateLimitedTasks(command);
break;
case "unlimited":
return CreateUnlimitedTasks(command);
break;
case TaskScheduleType.Unlimited:
return CreateUnlimitedTasks(command);
break;
default:
return operation.Failed("خطای سیستمی!");
default:
return operation.Failed("نوع وظیفه محول شده مشخص نمیباشد");
}
}
else
{
return operation.Failed("این تسک بصورت زمان بندی شده نمیباشد");
}
}
}
}
else
{
return operation.Failed("این تسک بصورت دوره ای نمیباشد");
}
}
public OperationResult CreateLimitedTasks(CreateTask command)
{
OperationResult operation = new OperationResult();
if (Convert.ToInt32(command.ScheduleCount) < 1 || string.IsNullOrWhiteSpace(command.ScheduleCount))
{
return operation.Failed("تعداد وارد شده باید بیشتر از 2 باشد");
}
public async Task<TaskScheduleDetailsViewModel> GetDetails(long id)
{
return await _taskScheduleRepository.GetDetails(id);
}
switch (command.ScheduleUnitType)
{
case "year":
if (Convert.ToInt32(command.ScheduleCount) != 1)
{
return operation.Failed("دوره نمیتواند بیشتر از 1 سال باشد");
}
break;
case "month":
if (Convert.ToInt32(command.ScheduleCount) > 12)
{
return operation.Failed("بازه وارد شده نا معتبر است");
}
break;
case "week":
if (command.ScheduleUnitNumber != "first" && command.ScheduleUnitNumber != "last")
{
return operation.Failed("بازه وارد شده نا معتبر است");
}
break;
case "day":
if (Convert.ToInt32(command.ScheduleUnitNumber) > 29)
{
return operation.Failed("بازه وارد شده نا معتبر است");
}
break;
default:
return operation.Failed("نوع بازه مشخص نمیباشد");
break;
public OperationResult Remove(long taskScheduleId)
{
var op = new OperationResult();
var taskSchedule = _taskScheduleRepository.Get(taskScheduleId);
if (taskSchedule == null)
return op.Failed("وظیفه مورد نظر یافت نشد");
var tasks = _taskRepository.GetTasksByTaskScheduleId(taskScheduleId);
var assigns = tasks.SelectMany(x => x.Assigns);
if (assigns.Any(x => x.IsCanceledRequest || x.IsDone || x.IsCancel || x.TimeRequest || x.AcceptedTimeRequest > 0))
{
taskSchedule.DeActive();
}
try
{
DateTime previousDateRaw = command.EndTaskDate.ToEndDayOfGeorgianDateTime();
DateTime previousDateEdited = command.EndTaskDate.ToEndDayOfGeorgianDateTime();
var removableTask = tasks.Where(x=>x.Assigns.All(a=>a.IsDone==false && a.IsCancel == false)).ToList();
_taskRepository.RemoveRange(removableTask);
}
else
{
_taskScheduleRepository.Remove(taskSchedule);
_taskRepository.RemoveRange(tasks);
}
_taskRepository.SaveChanges();
return op.Succcedded();
}
int count = Convert.ToInt32(command.ScheduleCount);
bool isInt = int.TryParse(command.ScheduleUnitNumber, out int unitNumber);
string kindOfWeekUnit = isInt ? "" : command.ScheduleUnitNumber;
var taskSchedule = new TaskSchedule(command.ScheduleCount, command.ScheduleType, command.ScheduleUnitType,
command.ScheduleUnitNumber, previousDateEdited);
_taskScheduleRepository.Create(taskSchedule);
_taskScheduleRepository.SaveChanges();
command.TaskScheduleId = taskSchedule.id;
private OperationResult CreateLimitedTasks(CreateTask command)
{
OperationResult operation = new OperationResult();
if (Convert.ToInt32(command.ScheduleCount) < 1 || string.IsNullOrWhiteSpace(command.ScheduleCount))
{
return operation.Failed("تعداد وارد شده باید بیشتر از 2 باشد");
}
if (string.IsNullOrWhiteSpace(command.ScheduleUnitNumber))
{
return operation.Failed("لطفا تعداد بازه خود را مشخص کنید");
}
switch (command.ScheduleUnitType)
{
case "year":
for (int i = 1; i <= count; i++)
{
command.EndTaskDate = previousDateEdited.ToFarsi();
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
switch (command.ScheduleUnitType)
{
case TaskScheduleUnitType.Year:
if (Convert.ToInt32(command.ScheduleCount) != 1)
{
return operation.Failed("دوره نمیتواند بیشتر از 1 سال باشد");
}
break;
case TaskScheduleUnitType.Month:
bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{
previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
if (Convert.ToInt32(command.ScheduleUnitNumber) is > 12 or < 1)
{
return operation.Failed("بازه وارد شده نا معتبر است");
}
}
previousDateRaw = previousDateRaw.AddYears(unitNumber);
previousDateEdited = previousDateRaw;
if (Convert.ToInt32(command.ScheduleCount) is > 60 or < 1)
{
return operation.Failed("تعداد دفعات وارد شده نامعتبر است");
}
break;
case TaskScheduleUnitType.Week:
if (command.ScheduleUnitNumber != "first" && command.ScheduleUnitNumber != "last")
{
return operation.Failed("بازه وارد شده نا معتبر است");
}
break;
case TaskScheduleUnitType.Day:
if (Convert.ToInt32(command.ScheduleUnitNumber) is > 29 or < 1)
{
return operation.Failed("بازه وارد شده نا معتبر است");
}
break;
default:
return operation.Failed("نوع بازه مشخص نمیباشد");
break;
}
break;
}
try
{
//using var transaction = new TransactionScope();
DateTime previousDateRaw = command.EndTaskDate.ToEndDayOfGeorgianDateTime();
DateTime previousDateEdited = command.EndTaskDate.ToEndDayOfGeorgianDateTime();
var day = Convert.ToInt32(command.EndTaskDate.Substring(8, 2));
var month = Convert.ToInt32(command.EndTaskDate.Substring(5, 2));
var year = Convert.ToInt32(command.EndTaskDate.Substring(0, 4));
case "month":
for (int i = 1; i <= count; i++)
{
command.EndTaskDate = previousDateEdited.ToFarsi();
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{
previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
int count = Convert.ToInt32(command.ScheduleCount);
bool isInt = int.TryParse(command.ScheduleUnitNumber, out int unitNumber);
string kindOfWeekUnit = isInt ? "" : command.ScheduleUnitNumber;
var taskSchedule = new TaskSchedule(command.ScheduleCount, command.ScheduleType, command.ScheduleUnitType,
command.ScheduleUnitNumber, previousDateEdited);
_taskScheduleRepository.Create(taskSchedule);
_taskScheduleRepository.SaveChanges();
command.TaskScheduleId = taskSchedule.id;
}
previousDateRaw = previousDateRaw.AddMonths(unitNumber);
previousDateEdited = previousDateRaw;
switch (command.ScheduleUnitType)
{
case TaskScheduleUnitType.Year:
for (int i = 1; i <= count; i++)
{
command.EndTaskDate = previousDateEdited.ToFarsi();
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
}
break;
bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{
previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
}
previousDateRaw = previousDateRaw.AddYears(unitNumber);
previousDateEdited = previousDateRaw;
}
break;
case "week":
for (int i = 1; i <= count; i++)
{
if (string.IsNullOrWhiteSpace(kindOfWeekUnit))
{
throw new InvalidDataException();
}
case TaskScheduleUnitType.Month:
bool endOfMonth = day == 31;
command.EndTaskDate = kindOfWeekUnit switch
{
"first" => previousDateRaw.GetNextDayOfWeek(DayOfWeek.Saturday).ToFarsi(),
"last" => previousDateRaw.GetNextDayOfWeek(DayOfWeek.Thursday).ToFarsi(),
_ => throw new InvalidDataException()
};
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{
previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
if (endOfMonth)
{
for (int i = 1; i <= count; i++)
{
command.EndTaskDate = previousDateEdited.ToFarsi();
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
if (month >= 12)
{
var extra = month - 12;
year++;
month = extra + unitNumber;
}
else
{
month = unitNumber + month;
}
previousDateRaw = $"{year:0000}/{month:00}/01".FindeEndOfMonth().ToGeorgianDateTime();
bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{
previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
}
previousDateRaw = command.EndTaskDate.ToGeorgianDateTime();
previousDateEdited = previousDateRaw;
}
}
break;
case "day":
previousDateEdited = previousDateRaw;
for (int i = 1; i <= count; i++)
{
command.EndTaskDate = previousDateEdited.ToFarsi();
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
previousDateRaw = previousDateRaw.AddDays(unitNumber);
bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{
previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
}
}
else
{
for (int i = 1; i < count; i++)
{
command.EndTaskDate = previousDateEdited.ToFarsi();
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
var endDay = 0;
}
if (month >= 12)
{
var extra = month - 12;
year++;
month = extra + unitNumber;
previousDateEdited = previousDateRaw;
}
break;
}
else
{
month = unitNumber + month;
}
}
_taskScheduleRepository.SaveChanges();
operation = operation.Succcedded();
return operation;
}
catch (Exception e)
{
return operation.Failed(e.ToString());
}
}
if (day == 30)
{
if (month == 12)
{
var lastYearDay = Convert.ToInt32($"{year:0000}/{month:00}/1".FindeEndOfMonth()
.Substring(8, 2));
endDay = lastYearDay == 30 ? lastYearDay : 29;
}
public OperationResult CreateUnlimitedTasks(CreateTask command)
{
var operation = _taskApplication.CreateTask(command);
if (!operation.IsSuccedded)
return operation;
var lastDate = command.EndTaskDate.ToGeorgianDateTime();
var taskSchedule = new TaskSchedule(command.ScheduleCount, command.ScheduleType, command.ScheduleUnitType,
command.ScheduleUnitNumber, lastDate);
_taskScheduleRepository.Create(taskSchedule);
_taskScheduleRepository.SaveChanges();
return operation.Succcedded();
}
}
previousDateEdited = endDay == 0
? $"{year:0000}/{month:00}/{day:00}".ToGeorgianDateTime()
: $"{year:0000}/{month:00}/{endDay:00}".ToGeorgianDateTime();
}
//for (int i = 1; i <= count; i++)
//{
// command.EndTaskDate = previousDateEdited.ToFarsi();
// operation = _taskApplication.CreateTask(command);
// taskSchedule.SetLastEndTaskDate(previousDateEdited);
// previousDateRaw = $"{year:0000}/{month:00}/01".FindeEndOfMonth().ToGeorgianDateTime();
// bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
// while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
// {
// previousDateEdited = previousDateRaw.AddDays(1);
// isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
// }
// previousDateEdited = previousDateRaw;
//}
}
break;
case TaskScheduleUnitType.Week:
for (int i = 1; i <= count; i++)
{
if (string.IsNullOrWhiteSpace(kindOfWeekUnit))
{
throw new InvalidDataException();
}
command.EndTaskDate = kindOfWeekUnit switch
{
"first" => previousDateRaw.GetNextDayOfWeek(DayOfWeek.Saturday).ToFarsi(),
"last" => previousDateRaw.GetNextDayOfWeek(DayOfWeek.Thursday).ToFarsi(),
_ => throw new InvalidDataException()
};
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{
previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
}
previousDateRaw = command.EndTaskDate.ToGeorgianDateTime();
previousDateEdited = previousDateRaw;
}
break;
case TaskScheduleUnitType.Day:
for (int i = 1; i <= count; i++)
{
command.EndTaskDate = previousDateEdited.ToFarsi();
operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited);
previousDateRaw = previousDateRaw.AddDays(unitNumber);
bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{
previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
}
previousDateEdited = previousDateRaw;
}
break;
}
_taskScheduleRepository.SaveChanges();
//transaction.Complete();
operation = operation.Succcedded();
return operation;
}
catch (Exception e)
{
return operation.Failed(e.ToString());
}
}
private OperationResult CreateUnlimitedTasks(CreateTask command)
{
using var transaction = new TransactionScope();
var lastDate = command.EndTaskDate.ToGeorgianDateTime();
var taskSchedule = new TaskSchedule(command.ScheduleCount, command.ScheduleType, command.ScheduleUnitType,
command.ScheduleUnitNumber, lastDate);
_taskScheduleRepository.Create(taskSchedule);
_taskScheduleRepository.SaveChanges();
command.TaskScheduleId = taskSchedule.id;
var operation = _taskApplication.CreateTask(command);
if (!operation.IsSuccedded)
return operation;
_taskScheduleRepository.SaveChanges();
transaction.Complete();
return operation.Succcedded();
}
}

View File

@@ -1,7 +1,9 @@
using System.Collections.Generic;
using System;
using System.Collections.Generic;
using _0_Framework.Application;
using AccountManagement.Application.Contracts.TaskSubject;
using AccountManagement.Domain.TaskSubjectAgg;
using static Microsoft.EntityFrameworkCore.DbLoggerCategory.Database;
namespace AccountManagement.Application;

View File

@@ -7,6 +7,7 @@ using AccountManagement.Application.Contracts.Role;
using AccountManagement.Application.Contracts.SubAccount;
using AccountManagement.Application.Contracts.SubAccountPermissionSubtitle;
using AccountManagement.Application.Contracts.Task;
using AccountManagement.Application.Contracts.TaskSchedule;
using AccountManagement.Application.Contracts.TaskSubject;
using AccountManagement.Application.Contracts.Ticket;
using AccountManagement.Application.Contracts.TicketAccessAccount;
@@ -25,6 +26,7 @@ using AccountManagement.Domain.SubAccountPermissionSubtitle4Agg;
using AccountManagement.Domain.SubAccountRoleAgg;
using AccountManagement.Domain.TaskAgg;
using AccountManagement.Domain.TaskMessageAgg;
using AccountManagement.Domain.TaskScheduleAgg;
using AccountManagement.Domain.TaskSubjectAgg;
using AccountManagement.Domain.TicketAccessAccountAgg;
using AccountManagement.Domain.TicketAgg;
@@ -62,6 +64,8 @@ namespace AccountManagement.Configuration
services.AddScoped<ITaskRepository, TaskRepository>();
services.AddTransient<ITaskApplication, TaskApplication>();
services.AddTransient<ITaskScheduleApplication, TaskScheduleApplication>();
services.AddTransient<ITaskScheduleRepository, TaskScheduleRepository>();
services.AddTransient<ITaskSubjectRepository, TaskSubjectRepository>();
services.AddTransient<ITaskSubjectApplication, TaskSubjectApplication>();

View File

@@ -33,6 +33,13 @@ namespace AccountManagement.Domain.AccountAgg
List<AccountViewModel> GetAccountsToEditWorkshop(long workshopId);
/// <summary>
/// چک میکند که اکانتی با این ام کاربری وجود دارد یا نه
/// </summary>
/// <param name="userName"></param>
/// <returns></returns>
public bool CheckExistClientAccount(string userName);
}
}

View File

@@ -8,7 +8,7 @@ namespace AccountManagement.Domain.AssignAgg;
public class Assign : EntityBase
{
public Assign(long taskId, long assignerId, long assignedId, int assignerPositionValue, string assignedName, int assignedPositionValue, DateTime endTaskDate, bool firstTimeCreation = false)
public Assign(long taskId, long assignerId, long assignedId, int assignerPositionValue, string assignedName, int assignedPositionValue, DateTime endTaskDate, bool firstTimeCreation=false)
{
TaskId = taskId;
AssignerId = assignerId;
@@ -18,7 +18,7 @@ public class Assign : EntityBase
AssignedPositionValue = assignedPositionValue;
EndTaskDate = endTaskDate;
FirstTimeCreation = firstTimeCreation;
}
}
//آیدی شخص ارسال کننده
public long TaskId { get; private set; }
@@ -52,7 +52,9 @@ public class Assign : EntityBase
public string? DoneDescription { get; private set; }
public bool IsCanceledRequest { get; private set; }
public bool FirstTimeCreation { get; private set; }
public Tasks Task { get; set; }
public List<TaskMessage> TaskMessageList { get; set; }
@@ -71,9 +73,9 @@ public class Assign : EntityBase
{
TimeRequest = false;
AcceptedTimeRequest++;
EndTaskDate = RequestDate.Value;
EndTaskDate = RequestDate < DateTime.Today ? DateTime.Today : RequestDate.Value;
}
}
public void RejectTimeRequest()
{
TimeRequest = false;

View File

@@ -1,5 +1,6 @@
using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework.Application;
using _0_Framework.Domain;
using AccountManagement.Application.Contracts.Task;
@@ -88,11 +89,22 @@ public interface ITaskRepository:IRepository<long,Tasks>
/// <returns></returns>
List<TaskViewModel> GetTasksHaveTicket(TaskSearchModel searchModel);
/// <summary>
/// لیست تسک های دوره ای ایجاد شده توسط کاربر
/// </summary>
/// <param name="searchModel"></param>
/// <returns></returns>
List<TaskViewModel> GetTaskScheduleList(TaskSearchModel searchModel);
/// <summary>
/// تعداد تسک های درخواستی. بدون تیکت
/// </summary>
/// <returns></returns>
int GetRequestedTasksCount();
Task<int> GetRequestedTasksCount();
/// <summary>
/// گرفتن جزئیات درخواست وظیفه
@@ -114,39 +126,38 @@ public interface ITaskRepository:IRepository<long,Tasks>
/// <returns></returns>
bool HasOverdueTasks(long userId);
/// <summary>
///مجوع تعداد تسک های عقب افتاده و درخواستی
/// </summary>
/// <param name="userId"></param>
/// <returns></returns>
int RequestedAndOverdueTasksCount(long userId);
/// <summary>
/// مجوع تعداد تسک های عقب افتاده و درخواستی
/// </summary>
/// <param name="userId"></param>
/// <returns></returns>
Task<int> RequestedAndOverdueTasksCount(long userId);
/// <summary>
/// تعداد تسک های دارای تیکت
/// </summary>
/// <param name="userId"></param>
/// <returns></returns>
int TasksHaveTicketCounts(long userId);
Task<int> TasksHaveTicketCounts(long userId);
/// <summary>
/// تعداد درخواست های تسک های دارا تیکت
/// </summary>
/// <param name="userId"></param>
/// <returns></returns>
int TasksHaveTicketRequestsCount(long userId);
Task<int> TasksHaveTicketRequestsCount(long userId);
/// <summary>
///تعداد تسک های شخصی و دریافتی برای امروز و یا عقب افتاده
/// </summary>
/// <param name="userId"></param>
/// <returns></returns>
int OverdueTasksCount(long userId);
/// <summary>
/// تعداد تسک های شخصی و دریافتی برای امروز و یا عقب افتاده
/// </summary>
/// <param name="userId"></param>
/// <returns></returns>
Task<int> OverdueTasksCount(long userId);
// گرفتن پیام های مربوط به هر تسک
List<Tasks> GetTasksByTaskScheduleId(long taskScheduleId);
//OperationResult MoveDataFRomTaskToAssign();
void RemoveRange(IEnumerable<Tasks> tasks);
}

View File

@@ -1,8 +1,11 @@
using _0_Framework.Domain;
using System.Threading.Tasks;
using _0_Framework.Domain;
using AccountManagement.Application.Contracts.TaskSchedule;
namespace AccountManagement.Domain.TaskScheduleAgg;
public interface ITaskScheduleRepository:IRepository<long,TaskSchedule>
public interface ITaskScheduleRepository : IRepository<long, TaskSchedule>
{
Task<TaskScheduleDetailsViewModel> GetDetails(long id);
void Remove(TaskSchedule entity);
}

View File

@@ -1,29 +1,38 @@
using System;
using System.Collections.Generic;
using _0_Framework.Application;
using _0_Framework.Domain;
using AccountManagement.Application.Contracts.Task;
using AccountManagement.Domain.TaskAgg;
namespace AccountManagement.Domain.TaskScheduleAgg;
public class TaskSchedule:EntityBase
{
public TaskSchedule(string count, string type, string unitType, string unitNumber, DateTime lastEndTaskDate)
public TaskSchedule(string count, TaskScheduleType type, TaskScheduleUnitType unitType, string unitNumber, DateTime lastEndTaskDate)
{
Count = count;
Type = type;
UnitType = unitType;
UnitNumber = unitNumber;
LastEndTaskDate = lastEndTaskDate;
IsActive = IsActive.False;
}
public string Count { get; private set; }
public string Type { get; private set; }
public string UnitType { get; private set; }
public TaskScheduleType Type { get; private set; }
public TaskScheduleUnitType UnitType { get; private set; }
public string UnitNumber { get; private set; }
public DateTime LastEndTaskDate { get; private set; }
public IsActive IsActive { get; private set; }
public List<Tasks> TasksList { get; set; }
public void SetLastEndTaskDate(DateTime lastEndTaskDate)
{
LastEndTaskDate = lastEndTaskDate;
}
public void DeActive()
{
IsActive = IsActive.False;
}
}

View File

@@ -27,6 +27,7 @@ using AccountManagement.Domain.SubAccountPermissionSubtitle3Agg;
using AccountManagement.Domain.SubAccountPermissionSubtitle4Agg;
using AccountManagement.Domain.SubAccountRoleAgg;
using AccountMangement.Infrastructure.EFCore.Seed;
using AccountManagement.Domain.TaskScheduleAgg;
namespace AccountMangement.Infrastructure.EFCore
{
@@ -57,6 +58,9 @@ namespace AccountMangement.Infrastructure.EFCore
public DbSet<TicketAccessAccount> TicketAccessAccounts { get; set; }
public DbSet<TaskSchedule> TaskSchedules { get; set; }
#endregion
#region Pooya

View File

@@ -12,9 +12,10 @@ public class TaskScheduleMapping : IEntityTypeConfiguration<TaskSchedule>
builder.HasKey(x => x.id);
builder.Property(x => x.Count).HasMaxLength(10);
builder.Property(x => x.Type).HasMaxLength(12);
builder.Property(x => x.Type).HasConversion<string>().HasMaxLength(12);
builder.Property(x => x.UnitNumber).HasMaxLength(10);
builder.Property(x => x.UnitType).HasMaxLength(10);
builder.Property(x => x.UnitType).HasConversion<string>().HasMaxLength(10);
builder.Property(x => x.IsActive).HasConversion<string>().HasMaxLength(5);
builder.HasMany(x => x.TasksList).WithOne(x => x.TaskSchedule)
.HasForeignKey(x => x.TaskScheduleId);

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,74 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace AccountMangement.Infrastructure.EFCore.Migrations
{
/// <inheritdoc />
public partial class addTaskSchedule : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<string>(
name: "UnitType",
table: "TaskSchedules",
type: "nvarchar(10)",
maxLength: 10,
nullable: false,
defaultValue: "",
oldClrType: typeof(string),
oldType: "nvarchar(10)",
oldMaxLength: 10,
oldNullable: true);
migrationBuilder.AlterColumn<string>(
name: "Type",
table: "TaskSchedules",
type: "nvarchar(12)",
maxLength: 12,
nullable: false,
defaultValue: "",
oldClrType: typeof(string),
oldType: "nvarchar(12)",
oldMaxLength: 12,
oldNullable: true);
migrationBuilder.AddColumn<string>(
name: "IsCanceled",
table: "TaskSchedules",
type: "nvarchar(5)",
maxLength: 5,
nullable: false,
defaultValue: "");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropColumn(
name: "IsCanceled",
table: "TaskSchedules");
migrationBuilder.AlterColumn<string>(
name: "UnitType",
table: "TaskSchedules",
type: "nvarchar(10)",
maxLength: 10,
nullable: true,
oldClrType: typeof(string),
oldType: "nvarchar(10)",
oldMaxLength: 10);
migrationBuilder.AlterColumn<string>(
name: "Type",
table: "TaskSchedules",
type: "nvarchar(12)",
maxLength: 12,
nullable: true,
oldClrType: typeof(string),
oldType: "nvarchar(12)",
oldMaxLength: 12);
}
}
}

View File

@@ -0,0 +1,28 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace AccountMangement.Infrastructure.EFCore.Migrations
{
/// <inheritdoc />
public partial class taskSchedulerenameisActive : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.RenameColumn(
name: "IsCanceled",
table: "TaskSchedules",
newName: "IsActive");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.RenameColumn(
name: "IsActive",
table: "TaskSchedules",
newName: "IsCanceled");
}
}
}

View File

@@ -759,10 +759,16 @@ namespace AccountMangement.Infrastructure.EFCore.Migrations
b.Property<DateTime>("CreationDate")
.HasColumnType("datetime2");
b.Property<string>("IsActive")
.IsRequired()
.HasMaxLength(5)
.HasColumnType("nvarchar(5)");
b.Property<DateTime>("LastEndTaskDate")
.HasColumnType("datetime2");
b.Property<string>("Type")
.IsRequired()
.HasMaxLength(12)
.HasColumnType("nvarchar(12)");
@@ -771,6 +777,7 @@ namespace AccountMangement.Infrastructure.EFCore.Migrations
.HasColumnType("nvarchar(10)");
b.Property<string>("UnitType")
.IsRequired()
.HasMaxLength(10)
.HasColumnType("nvarchar(10)");

View File

@@ -332,4 +332,9 @@ public class AccountRepository : RepositoryBase<long, Account>, IAccountReposito
#endregion
public bool CheckExistClientAccount(string userName)
{
return _context.Accounts.Any(x => x.Username == userName);
}
}

View File

@@ -4,6 +4,7 @@ using _0_Framework.InfraStructure;
using Microsoft.AspNetCore.Http;
using Microsoft.EntityFrameworkCore;
using System.Linq;
using System.Threading.Tasks;
using _0_Framework.Application;
using AccountManagement.Application.Contracts.Account;
using AccountManagement.Application.Contracts.Assign;
@@ -46,7 +47,6 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
public EditTask GetDetails(long TaskId)
{
var task = Get(TaskId);
var userId = _authHelper.CurrentAccountId();
@@ -94,7 +94,8 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
Fullname = a.Fullname,
Id = a.id,
}).FirstOrDefault()
}).FirstOrDefault(),
TaskScheduleId = x.TaskScheduleId ?? 0
}).FirstOrDefault();
@@ -112,6 +113,17 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
res.IsCancel = res.AssignViewModels.First(x => x.AssignedId == userId).IsCancel;
}
if (res.TaskScheduleId>0)
{
var taskSchedule = _accountContext.TaskSchedules.FirstOrDefault(x => x.id == res.TaskScheduleId);
res.ScheduleUnitType = taskSchedule.UnitType;
res.ScheduleType = taskSchedule.Type;
res.ScheduleCount = taskSchedule.Count;
res.ScheduleUnitNumber = taskSchedule.UnitNumber;
}
//_accountContext.Tasks.Where(x => x.id == TaskId).Select(x => new EditTask()
//{
// EndTaskDate = x.EndTaskDate.ToFarsi(),
@@ -968,7 +980,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
.ThenInclude(x => x.Media)
.Where(x =>
x.Task.IsActiveString == "true" && (x.AssignerId == accountId && x.AssignedId != accountId) && (!x.IsCanceledRequest && !x.TimeRequest && !x.IsDoneRequest) && x.Task.TicketId == null &&
x.Task.SenderId == accountId)
x.Task.SenderId == accountId && x.Task.TaskScheduleId == null)
.Select(x =>
new TaskViewModel()
{
@@ -1839,7 +1851,307 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
return final;
}
public List<TaskViewModel> GetTaskScheduleList(TaskSearchModel searchModel)
{
var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value);
var positionValue = int.Parse(_contextAccessor.HttpContext.User.FindFirst("PositionValue").Value);
var emptyAcc = new AccountViewModel()
{
Fullname = "-",
PositionValue = 0
};
var raw = _accountContext.Assigns.Include(x => x.Task).ThenInclude(x => x.TaskMedias)
.ThenInclude(x => x.Media)
.Include(x => x.Task).ThenInclude(x => x.TaskSchedule)
.Where(x =>
x.Task.IsActiveString == "true" && x.Task.SenderId == accountId
&& x.Task.TaskScheduleId != null && x.Task.TaskScheduleId > 0 && (!x.IsCanceledRequest && !x.TimeRequest && !x.IsDoneRequest));
if (!string.IsNullOrWhiteSpace(searchModel.GeneralSearch))
{
raw = raw.Where(x =>
(x.Task.Description != null && x.Task.Description.Contains(searchModel.GeneralSearch))
|| x.Task.ContractingPartyName.Contains(searchModel.GeneralSearch)
|| x.Task.Title.Contains(searchModel.GeneralSearch));
}
var query = raw.GroupBy(x => x.Task.TaskScheduleId).Select(x =>
new TaskViewModel()
{
AssignedId = x.First().AssignedId,
AssignerId = x.First().AssignerId,
CreateDate = x.First().Task.CreationDate.ToFarsi(),
EndTaskDateFA = x.First().EndTaskDate.ToFarsi(),
IsDone = x.First().IsDone,
EndTaskDateGE = x.First().EndTaskDate,
Name = x.First().Task.Title,
RequestCancel = x.First().IsCanceledRequest,
RequestTime = x.First().TimeRequest,
Id = x.First().Task.id,
CreateTaskDateGE = x.First().Task.CreationDate,
IsCancel = x.First().IsCancel,
AcceptedTimeRequest = x.First().AcceptedTimeRequest,
IsCancelRequest = x.First().IsCanceledRequest,
ContractingPartyName = x.First().Task.ContractingPartyName,
MediaCount = _accountContext.TaskMedias.Count(m => m.TaskId == x.First().Task.id),
Description = x.First().Task.Description,
IsDoneRequest = x.First().IsDoneRequest,
ScheduleType = x.First().Task.TaskSchedule.Type,
ScheduleUnitType = x.First().Task.TaskSchedule.UnitType,
TaskScheduleId = (long)x.First().Task.TaskScheduleId
}
);
if (!string.IsNullOrWhiteSpace(searchModel.GeneralSearch))
{
query = query.Where(x =>
(x.Description != null && x.Description.Contains(searchModel.GeneralSearch))
|| x.ContractingPartyName.Contains(searchModel.GeneralSearch)
|| x.Name.Contains(searchModel.GeneralSearch));
}
var res = query.Select(x => new TaskViewModel()
{
Sender = _accountContext.Accounts.Include(a => a.Position).Select(a => new AccountViewModel()
{
PositionValue = a.Position.PositionValue,
Id = a.id,
Fullname = a.Fullname,
}).FirstOrDefault(a => a.Id == x.AssignerId),
SelfName = _accountContext.Accounts.FirstOrDefault(a => a.id == accountId).Fullname,
Assigned = _accountContext.Assigns.Where(a => a.TaskId == x.Id)
.Where(a => a.AssignedPositionValue >= positionValue).Select(a => a.AssignedId)
.ToList(),
CreateDate = x.CreateDate,
EndTaskDateFA = x.EndTaskDateFA,
IsDone = x.IsDone,
EndTaskDateGE = x.EndTaskDateGE,
Name = x.Name,
RequestCancel = x.RequestCancel,
RequestTime = x.RequestTime,
Id = x.Id,
CreateTaskDateGE = x.CreateTaskDateGE,
IsCancel = x.IsCancel,
AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName,
MediaCount = x.MediaCount,
Description = x.Description,
IsDoneRequest = x.IsDoneRequest,
ScheduleType = x.ScheduleType,
ScheduleUnitType = x.ScheduleUnitType,
TaskScheduleId = x.TaskScheduleId
});
if (!string.IsNullOrWhiteSpace(searchModel.StartDate) && !string.IsNullOrWhiteSpace(searchModel.EndDate))
{
var start = searchModel.StartDate.ToGeorgianDateTime();
var end = searchModel.EndDate.ToGeorgianDateTime();
res = res.Where(x =>
((start > x.CreateTaskDateGE && x.CreateTaskDateGE < end) &&
(end > x.EndTaskDateGE && x.EndTaskDateGE > start))
|| ((start < x.CreateTaskDateGE && x.CreateTaskDateGE < end) &&
(end < x.EndTaskDateGE && x.EndTaskDateGE > start))
|| ((start < x.CreateTaskDateGE && x.CreateTaskDateGE < end) &&
(end > x.EndTaskDateGE && x.EndTaskDateGE > start))
|| ((start > x.CreateTaskDateGE && x.CreateTaskDateGE < end) &&
(end < x.EndTaskDateGE && x.EndTaskDateGE > end)));
}
if (!string.IsNullOrWhiteSpace(searchModel.IsDoneRequest))
{
bool isDoneReq = bool.Parse(searchModel.IsDoneRequest);
res = res.Where(x => x.IsDoneRequest == isDoneReq);
}
if (!string.IsNullOrWhiteSpace(searchModel.IsDone))
{
bool isDone = bool.Parse(searchModel.IsDone);
res = res.Where(x => x.IsDone == isDone);
}
if (!string.IsNullOrWhiteSpace(searchModel.IsCanceled))
{
bool isCancel = bool.Parse(searchModel.IsCanceled);
res = res.Where(x => x.IsCancel == isCancel);
}
if (!string.IsNullOrWhiteSpace(searchModel.IsTimeRequest))
{
bool isTimeRequest = bool.Parse(searchModel.IsTimeRequest);
res = res.Where(x => x.RequestTime == isTimeRequest);
}
if (!string.IsNullOrWhiteSpace(searchModel.TimeRequestAccepted))
{
res = res.Where(x => x.AcceptedTimeRequest > 0);
}
if (!string.IsNullOrWhiteSpace(searchModel.IsCancelRequest))
{
bool isCancelReq = bool.Parse(searchModel.IsCancelRequest);
res = res.Where(x => x.IsCancelRequest == isCancelReq);
}
var result = res.AsEnumerable();
if (searchModel.AccountId > 0)
{
result = result.Where(x =>
x.Sender.Id == searchModel.AccountId || x.Assigned.Contains(searchModel.AccountId));
}
var orderResult = result.OrderByDescending(x => x.IsCancel ? 0 : 1).ThenBy(x => x.IsDone ? 1 : 0)
.ThenBy(x => x.EndTaskDateGE);
var final = orderResult.Skip(searchModel.PageIndex).Take(30).ToList();
final = final.Select(x => new TaskViewModel()
{
AssignViewModels = _accountContext.Accounts.Include(x => x.Position)
.Where(a => x.Assigned.Contains(a.id) && accountId != a.id)
.Select(a => new AssignViewModel()
{
AssignedName = a.Fullname,
AssignedPositionValue = a.Position.PositionValue
}).ToList(),
Sender = x.Sender,
SelfAssigner = x.Sender.Id == accountId ? true : false,
Assigned = x.Assigned,
SelfAssigned = x.Assigned.Any(a => a == accountId) ? true : false,
CreateDate = x.CreateDate,
EndTaskDateFA = x.EndTaskDateFA,
IsDone = x.IsDone,
EndTaskDateGE = x.EndTaskDateGE,
Name = x.Name,
RequestCancel = x.RequestCancel,
RequestTime = x.RequestTime,
Id = x.Id,
CreateTaskDateGE = x.CreateTaskDateGE,
IsCancel = x.IsCancel,
AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName,
MediaCount = x.MediaCount,
SelfName = x.SelfName,
Description = x.Description,
IsDoneRequest = x.IsDoneRequest,
ScheduleType = x.ScheduleType,
ScheduleUnitType = x.ScheduleUnitType,
TaskScheduleId = x.TaskScheduleId
}).ToList();
final = final.Select(x => new TaskViewModel()
{
AssignList = x.AssignViewModels.GroupBy(a => a.AssignedPositionValue).Select(a => new AssignList()
{
AssignViewModels = a.ToList(),
PosValue = a.Key
}).ToList(),
Sender = x.Sender,
Assigned = x.Assigned,
CreateDate = x.CreateDate,
EndTaskDateFA = x.EndTaskDateFA,
IsDone = x.IsDone,
EndTaskDateGE = x.EndTaskDateGE,
Name = x.Name,
RequestCancel = x.RequestCancel,
RequestTime = x.RequestTime,
Id = x.Id,
CreateTaskDateGE = x.CreateTaskDateGE,
IsCancel = x.IsCancel,
AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName,
Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel),
MediaCount = x.MediaCount,
HasAttachment = x.MediaCount > 0,
SelfName = x.SelfName,
SelfAssigned = x.SelfAssigned,
SelfAssigner = x.SelfAssigner,
Description = x.Description,
IsDoneRequest = x.IsDoneRequest,
AssignViewModels = x.AssignViewModels,
ScheduleType = x.ScheduleType,
ScheduleUnitType = x.ScheduleUnitType,
TaskScheduleId = x.TaskScheduleId
}).ToList();
final = final.Select(x => new TaskViewModel()
{
AssignList = !(x.SelfAssigned || x.SelfAssigner)
? AddAssign(x.AssignList, x.Sender)
: x.AssignList,
Sender = !(x.SelfAssigned || x.SelfAssigner)
? new AccountViewModel()
{
PositionValue = 0,
Fullname = "-"
}
: x.Sender,
Assigned = x.Assigned,
CreateDate = x.CreateDate,
EndTaskDateFA = x.EndTaskDateFA,
IsDone = x.IsDone,
EndTaskDateGE = x.EndTaskDateGE,
Name = x.Name,
RequestCancel = x.RequestCancel,
RequestTime = x.RequestTime,
Id = x.Id,
CreateTaskDateGE = x.CreateTaskDateGE,
IsCancel = x.IsCancel,
AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName,
Color = x.Color,
MediaCount = x.MediaCount,
HasAttachment = x.HasAttachment,
SelfName = !(x.SelfAssigned || x.SelfAssigner) ? "-" : x.SelfName,
EndTaskTime = $"{x.EndTaskDateGE.Hour}:{x.EndTaskDateGE.Minute}:{x.EndTaskDateGE.Second}" != "23:59:59"
? $"{x.EndTaskDateGE.Hour}:{x.EndTaskDateGE.Minute}"
: "",
Description = x.Description,
IsDoneRequest = x.IsDoneRequest,
CanAssign = _positionRepository.GetLastPositionValue() != positionValue,
CanDelete = x.Sender.Id == accountId,
CanEdit = x.Sender.Id == accountId && !(_accountContext.Assigns.Any(a => a.TaskId == x.Id && (a.AcceptedTimeRequest > 0 || a.IsCanceledRequest
|| a.IsDoneRequest || a.TimeRequest || a.IsCancel || a.IsDone))),
Assigner = x.Sender.Id == accountId ? emptyAcc.Fullname : x.Sender.Fullname,
AssignedReceiverViewModel = x.AssignViewModels.Any()
? x.AssignViewModels.MinBy(a => a.AssignedPositionValue)
: new()
{
AssignedName = "-",
AssignedPositionValue = 0
},
ScheduleType = x.ScheduleType,
ScheduleUnitType = x.ScheduleUnitType,
TaskScheduleId = x.TaskScheduleId
}).ToList();
return final;
}
public string SetTasksColors(DateTime date, bool isCancel)
{
@@ -1888,23 +2200,23 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
}
public int GetRequestedTasksCount()
public async Task<int> GetRequestedTasksCount()
{
var positionValue = int.Parse(_contextAccessor.HttpContext.User.FindFirst("PositionValue").Value);
var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value);
if (positionValue == 1)
{
return _accountContext.Assigns.Include(x => x.Task).Where(x =>
return await _accountContext.Assigns.Include(x => x.Task).Where(x =>
!x.IsDone && x.Task.IsActiveString == "true" && !x.IsCancel &&
(x.IsCanceledRequest || x.TimeRequest || x.IsDoneRequest) && (accountId == x.Task.SenderId) && x.Task.TicketId == null).GroupBy(x => x.TaskId)
.Select(x => x.First()).Count();
.Select(x => x.First()).CountAsync();
}
else
{
return _accountContext.Assigns.Include(x => x.Task).Where(x =>
return await _accountContext.Assigns.Include(x => x.Task).Where(x =>
!x.IsDone && x.Task.IsActiveString == "true" && !x.IsCancel &&
(x.IsCanceledRequest || x.TimeRequest || x.IsDoneRequest) && (accountId == x.Task.SenderId) && x.Task.TicketId == null).GroupBy(x => x.TaskId)
.Select(x => x.First()).Count();
.Select(x => x.First()).CountAsync();
}
}
@@ -2001,7 +2313,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
}
public int RequestedAndOverdueTasksCount(long userId)
public async Task<int> RequestedAndOverdueTasksCount(long userId)
{
var account = _accountRepository.GetIncludePositions(userId);
if (account.Position == null)
@@ -2009,7 +2321,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
DateTime now = DateTime.Now;
var overdueTasksCount = OverdueTasksCount(userId);
var overdueTasksCount = await OverdueTasksCount(userId);
//overdueTasksCount = _accountContext.Tasks.Include(x =>
@@ -2018,10 +2330,10 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
// !x.Assigns.Any(a => a.TimeRequest)
// && x.Assigns.Any(a => a.AssignedId == userId) &&
// (x.Assigns.First(a => a.AssignedId == userId).EndTaskDate.Date <= DateTime.Now.Date));
var overdueRequestsCount = GetRequestedTasksCount();
var overdueRequestsCount = await GetRequestedTasksCount();
var ticketRequested = TasksHaveTicketRequestsCount(userId);
var overdueTicket = TasksHaveTicketCounts(userId);
var ticketRequested = await TasksHaveTicketRequestsCount(userId);
var overdueTicket = await TasksHaveTicketCounts(userId);
return overdueTasksCount + overdueRequestsCount + ticketRequested + overdueTicket;
}
@@ -2036,7 +2348,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
return overdueRequestsCount;
}
public int OverdueTasksCount(long userId)
public async Task<int> OverdueTasksCount(long userId)
{
var account = _accountRepository.GetIncludePositions(userId);
@@ -2048,12 +2360,12 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
int overdueTasksCount;
if (positionValue == 1)
{
overdueTasksCount = _accountContext.Assigns.Include(x => x.Task).Where(x => x.AssignedId == userId &&
overdueTasksCount = await _accountContext.Assigns.Include(x => x.Task).Where(x => x.AssignedId == userId &&
x.AssignerId == userId && x.Task.Assigns.Count == 1 &&
!x.IsCancel && !x.IsCanceledRequest &&
!x.IsDone && !x.TimeRequest && !x.IsDoneRequest && x.EndTaskDate.Date <= DateTime.Now.Date &&
x.Task.IsActiveString == "true" && x.Task.TicketId == null)
.GroupBy(x => x.TaskId).Select(x => x.First()).Count();
.GroupBy(x => x.TaskId).Select(x => x.First()).CountAsync();
//overdueTasksCount = _accountContext.Tasks.Include(x =>
// x.Assigns).Count(x => !x.Assigns.Any(a => a.IsCancel) && !x.Assigns.Any(a => a.IsCanceledRequest) &&
@@ -2065,43 +2377,49 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
}
else
{
overdueTasksCount = _accountContext.Assigns.Include(x => x.Task).Where(x => x.AssignedId == userId &&
overdueTasksCount = await _accountContext.Assigns.Include(x => x.Task).Where(x => x.AssignedId == userId &&
!x.IsCancel && !x.IsCanceledRequest &&
!x.IsDone && !x.TimeRequest && !x.IsDoneRequest && x.EndTaskDate.Date <= DateTime.Now.Date &&
x.Task.IsActiveString == "true" && x.Task.TicketId == null)
.GroupBy(x => x.TaskId).Select(x => x.First()).Count();
.GroupBy(x => x.TaskId).Select(x => x.First()).CountAsync();
;
}
return overdueTasksCount;
}
public int TasksHaveTicketCounts(long userId)
public List<Tasks> GetTasksByTaskScheduleId(long taskScheduleId)
{
return _accountContext.Assigns.Include(x => x.Task).Where(x =>
return _accountContext.Tasks.Include(x=>x.Assigns).Where(x => x.TaskScheduleId != null && x.TaskScheduleId == taskScheduleId).ToList();
}
public async Task<int> TasksHaveTicketCounts(long userId)
{
return await _accountContext.Assigns.Include(x => x.Task).Where(x =>
!x.IsDone && x.Task.IsActiveString == "true" && !x.IsCancel &&
!x.IsCanceledRequest && !x.IsDoneRequest &&
!x.TimeRequest && (x.AssignerId == userId || x.AssignedId == userId) &&
(x.Task.TicketId != null && x.Task.TicketId > 0)).GroupBy(x => x.TaskId).Count();
(x.Task.TicketId != null && x.Task.TicketId > 0)).GroupBy(x => x.TaskId).CountAsync();
}
public int TasksHaveTicketRequestsCount(long userId)
public async Task<int> TasksHaveTicketRequestsCount(long userId)
{
var positionValue = int.Parse(_contextAccessor.HttpContext.User.FindFirst("PositionValue").Value);
var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value);
if (positionValue == 1)
{
return _accountContext.Assigns.Include(x => x.Task).Where(x =>
return await _accountContext.Assigns.Include(x => x.Task).Where(x =>
!x.IsDone && x.Task.IsActiveString == "true" && !x.IsCancel &&
(x.IsCanceledRequest || x.TimeRequest || x.IsDoneRequest) && (accountId == x.Task.SenderId) && x.Task.TicketId != null && x.Task.TicketId > 0).GroupBy(x => x.TaskId)
.Select(x => x.First()).Count();
.Select(x => x.First()).CountAsync();
}
else
{
return _accountContext.Assigns.Include(x => x.Task).Where(x =>
return await _accountContext.Assigns.Include(x => x.Task).Where(x =>
!x.IsDone && x.Task.IsActiveString == "true" && !x.IsCancel &&
(x.IsCanceledRequest || x.TimeRequest || x.IsDoneRequest) && (accountId == x.Task.SenderId) && x.Task.TicketId != null && x.Task.TicketId > 0).GroupBy(x => x.TaskId)
.Select(x => x.First()).Count();
.Select(x => x.First()).CountAsync();
}
}

View File

@@ -0,0 +1,66 @@
using System.Linq;
using System.Threading.Tasks;
using _0_Framework.Application;
using _0_Framework.InfraStructure;
using AccountManagement.Application.Contracts.Media;
using AccountManagement.Application.Contracts.TaskSchedule;
using AccountManagement.Domain.TaskScheduleAgg;
using Microsoft.EntityFrameworkCore;
namespace AccountMangement.Infrastructure.EFCore.Repository;
public class TaskScheduleRepository: RepositoryBase<long, TaskSchedule>, ITaskScheduleRepository
{
private readonly AccountContext _accountContext;
public TaskScheduleRepository(AccountContext accountContext):base(accountContext)
{
_accountContext = accountContext;
}
public async Task<TaskScheduleDetailsViewModel> GetDetails(long id)
{
var taskSchedule=await _accountContext.TaskSchedules.Include(x=>x.TasksList).ThenInclude(x=>x.Assigns)
.Include(x=>x.TasksList).ThenInclude(x=>x.TaskMedias).ThenInclude(x=>x.Media).FirstOrDefaultAsync(x => x.id == id);
if (taskSchedule == null)
{
return null;
}
var firstTaskDetails = taskSchedule.TasksList.First();
var firstTimeAssigns = firstTaskDetails.Assigns.Where(x=>x.FirstTimeCreation).ToList();
var assignedIds = firstTimeAssigns.Select(x => x.AssignedId).ToList();
var senderId = firstTaskDetails.SenderId;
var assignedAccounts = await _accountContext.Accounts.Where(x => assignedIds.Contains(x.id)).ToListAsync();
var sender =
await _accountContext.Accounts.FirstOrDefaultAsync(x => senderId == x.id);
var viewModel = new TaskScheduleDetailsViewModel()
{
Title = firstTaskDetails.Title,
Description = firstTaskDetails.Description,
ContractingPartyName = firstTaskDetails.ContractingPartyName,
AssignedName = assignedAccounts.Select(x=>x.Fullname).ToList(),
CreationDateFa = firstTaskDetails.CreationDate.ToFarsi(),
SenderName = sender.Fullname,
TaskScheduleType = taskSchedule.Type,
TaskScheduleUnitType = taskSchedule.UnitType,
UnitNumber = taskSchedule.UnitNumber,
Medias = firstTaskDetails.TaskMedias.Select(x=> new MediaViewModel()
{
Category = x.Media.Category,
Id = x.MediaId,
Type = x.Media.Type,
Path = x.Media.Path,
}).ToList(),
};
return viewModel;
}
}

View File

@@ -1,6 +1,7 @@
using System;
using System.Collections.Generic;
using System.Security.Cryptography.X509Certificates;
using _0_Framework.Application;
using _0_Framework.Domain;
using Company.Domain.empolyerAgg;
using Company.Domain.RepresentativeAgg;
@@ -42,8 +43,44 @@ public class PersonalContractingParty : EntityBase
public string IsActiveString { get; private set; }
public string IsBlock { get; private set; }
public int BlockTimes {get; private set; }
#region NewProps
/// <summary>
/// سری شناسنامه
/// </summary>
public string IdNumberSeri { get; private set; }
/// <summary>
/// سریال شناسنامه
/// </summary>
public string IdNumberSerial { get; private set; }
/// <summary>
/// نام پدر
/// </summary>
public string FatherName { get; private set; }
/// <summary>
/// تاریخ تولد
/// </summary>
public DateTime? DateOfBirth { get; private set; }
/// <summary>
/// آیا از طریق ای پی ای احراز هویت شده است
/// </summary>
public bool IsAuthenticated { get; private set; }
/// <summary>
/// جنسیت
/// </summary>
public Gender Gender { get; private set; }
#endregion
public List<Employer> Employers { get; private set; }
public Representative Representative { get; set; }
@@ -159,5 +196,21 @@ public class PersonalContractingParty : EntityBase
this.IsActiveString = "false";
}
public void Authenticated()
{
IsAuthenticated = true;
}
public void Authentication(string fName, string lName, string fatherName,string idNumber, string idNumberSeri, string idNumberSerial, string dateOfBirth, Gender gender)
{
this.FName = fName;
this.LName = lName;
this.FatherName = fatherName;
this.IdNumberSeri = idNumberSeri;
this.IdNumberSerial = idNumberSerial;
this.DateOfBirth = !string.IsNullOrWhiteSpace(dateOfBirth) ? dateOfBirth.ToGeorgianDateTime() : null;
this.IdNumber = idNumber;
this.Gender = gender;
this.IsAuthenticated = true;
}
}

View File

@@ -1,11 +1,12 @@
using _0_Framework.Application;
using System;
using System.Collections.Generic;
using _0_Framework.Application;
using _0_Framework.Domain;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
using _0_Framework.Domain.CustomizeCheckoutShared.ValueObjects;
using Company.Domain.CustomizeCheckoutAgg.ValueObjects;
using Company.Domain.EmployeeAgg;
using Company.Domain.WorkshopAgg;
using System;
using System.Collections.Generic;
using Microsoft.AspNetCore.Authentication.Cookies;
namespace Company.Domain.CustomizeCheckoutAgg;
@@ -15,22 +16,23 @@ namespace Company.Domain.CustomizeCheckoutAgg;
public class CustomizeCheckout : EntityBase
{
private CustomizeCheckout()
{
}
{ }
public CustomizeCheckout(DateTime contractStart, DateTime contractEnd, long employeeId, string employeeFName,
string employeeLName, DateTime employeeDateOfBirth,
string employeeNationalCode, string workshopFullName, long workshopId, long? contractId,
double monthlySalary, double fridayPay, double overTimePay, double baseYearsPay, double bonusesPay,
double nightWorkPay,
double marriedAllowance, double shiftPay, double familyAllowance, double leavePay, double insuranceDeduction,
double fineAbsenceDeduction,
double lateToWorkDeduction, double earlyExitDeduction, double rewardPay, double salaryAidDeduction,
double installmentDeduction,
double fineDeduction, double taxDeduction, string sumOfWorkingDays, string totalClaims, string totalDeductions,
double totalPayment, string contractNo, ICollection<CustomizeCheckoutFine> checkoutFines,
ICollection<CustomizeCheckoutLoanInstallments> customizeCheckoutLoanInstallments,
ICollection<CustomizeCheckoutSalaryAid> customizeCheckoutSalaryAids,
ICollection<CustomizeCheckoutReward> customizeCheckoutRewards, TimeSpan lateToWorkValue)
string employeeLName, DateTime employeeDateOfBirth,
string employeeNationalCode, string workshopFullName, long workshopId, long? contractId,
double monthlySalary, double fridayPay, double overTimePay, double baseYearsPay, double bonusesPay,
double nightWorkPay,
double marriedAllowance, double shiftPay, double familyAllowance, double leavePay, double insuranceDeduction,
double fineAbsenceDeduction,
double lateToWorkDeduction, double earlyExitDeduction, double rewardPay, double salaryAidDeduction,
double installmentDeduction,
double fineDeduction, double taxDeduction, string sumOfWorkingDays, string totalClaims, string totalDeductions,
double totalPayment, string contractNo, ICollection<CustomizeCheckoutFine> checkoutFines,
ICollection<CustomizeCheckoutLoanInstallments> customizeCheckoutLoanInstallments,
ICollection<CustomizeCheckoutSalaryAid> customizeCheckoutSalaryAids,
ICollection<CustomizeCheckoutReward> customizeCheckoutRewards, TimeSpan lateToWorkValue, double settingSalary,
double dailyWage, WorkshopShiftStatus shiftStatus, IrregularShift irregularShift,
ICollection<CustomizeRotatingShift> customizeRotatingShifts, ICollection<CustomizeCheckoutRegularShift> employeeSettingsShifts)
{
YearInt = Convert.ToInt32(contractStart.ToFarsi().Substring(0, 4));
MonthInt = Convert.ToInt32(contractStart.ToFarsi().Substring(5, 2));
@@ -74,6 +76,12 @@ public class CustomizeCheckout : EntityBase
WorkshopFullName = workshopFullName;
LateToWorkValue = lateToWorkValue;
SettingSalary = settingSalary;
DailyWage = dailyWage;
ShiftStatus = shiftStatus;
IrregularShift = irregularShift;
CustomizeRotatingShifts = customizeRotatingShifts;
RegularShifts = employeeSettingsShifts;
}
@@ -249,6 +257,18 @@ public class CustomizeCheckout : EntityBase
/// </summary>
public double TotalPayment { get; private set; }
/// <summary>
/// مزد روزانه
/// </summary>
public double DailyWage { get; private set; }
/// <summary>
/// حقوق تعیین شده
/// </summary>
public double SettingSalary { get; private set; }
public WorkshopShiftStatus ShiftStatus { get; set; }
#region Values
@@ -266,6 +286,12 @@ public class CustomizeCheckout : EntityBase
public ICollection<CustomizeCheckoutSalaryAid> CustomizeCheckoutSalaryAids { get; set; }
public ICollection<CustomizeCheckoutReward> CustomizeCheckoutRewards { get; set; }
public IrregularShift IrregularShift { get; set; }
public ICollection<CustomizeRotatingShift> CustomizeRotatingShifts { get; set; }
public ICollection<CustomizeCheckoutRegularShift> RegularShifts { get; set; }
#endregion
#region Relations

View File

@@ -3,6 +3,7 @@ using _0_Framework.Domain;
using CompanyManagment.App.Contracts.CustomizeCheckout;
using System;
using System.Collections.Generic;
using _0_Framework.Application;
namespace Company.Domain.CustomizeCheckoutAgg
{

View File

@@ -19,6 +19,7 @@ public class CustomizeCheckoutLoanInstallments
public string Month { get; private set; }
public string Year { get; private set; }
public string LoanRemaining { get; set; }
public string LoanAmount { get; set; }
public IsActive IsActive { get; private set; }
public string LoanAmount { get; set; }
}

View File

@@ -0,0 +1,12 @@
using System;
using _0_Framework.Domain.CustomizeCheckoutShared.Base;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
namespace Company.Domain.CustomizeCheckoutAgg.ValueObjects;
public class CustomizeCheckoutRegularShift:CustomizeSifts
{
public CustomizeCheckoutRegularShift(TimeOnly startTime, TimeOnly endTime, ShiftPlacement placement) : base(startTime, endTime, placement)
{
}
}

View File

@@ -6,6 +6,8 @@ using Company.Domain.WorkshopAgg;
using System;
using System.Collections.Generic;
using Company.Domain.CustomizeCheckoutTempAgg.ValueObjects;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
using _0_Framework.Domain.CustomizeCheckoutShared.ValueObjects;
namespace Company.Domain.CustomizeCheckoutTempAgg;
@@ -18,15 +20,23 @@ public class CustomizeCheckoutTemp : EntityBase
{
LateToWorkValue = lateToWorkValue;
}
public CustomizeCheckoutTemp(DateTime contractStart, DateTime contractEnd, long employeeId, string employeeFName, string employeeLName, DateTime employeeDateOfBirth,
public CustomizeCheckoutTemp(DateTime contractStart, DateTime contractEnd, long employeeId, string employeeFName,
string employeeLName, DateTime employeeDateOfBirth,
string employeeNationalCode, string workshopFullName, long workshopId, long? contractId,
double monthlySalary, double fridayPay, double overTimePay, double baseYearsPay, double bonusesPay, double nightWorkPay,
double marriedAllowance, double shiftPay, double familyAllowance, double leavePay, double insuranceDeduction, double fineAbsenceDeduction,
double lateToWorkDeduction, double earlyExitDeduction, double rewardPay, double salaryAidDeduction, double installmentDeduction,
double fineDeduction, double taxDeduction, string sumOfWorkingDays, string totalClaims, string totalDeductions, double totalPayment, string contractNo,
ICollection<CustomizeCheckoutTempFine> checkoutFines, ICollection<CustomizeCheckoutTempLoanInstallments> customizeCheckoutLoanInstallments,
ICollection<CustomizeCheckoutTempSalaryAid> customizeCheckoutSalaryAids, ICollection<CustomizeCheckoutTempReward> customizeCheckoutRewards,
TimeSpan lateToWorkValue)
double monthlySalary, double fridayPay, double overTimePay, double baseYearsPay, double bonusesPay,
double nightWorkPay,
double marriedAllowance, double shiftPay, double familyAllowance, double leavePay, double insuranceDeduction,
double fineAbsenceDeduction,
double lateToWorkDeduction, double earlyExitDeduction, double rewardPay, double salaryAidDeduction,
double installmentDeduction,
double fineDeduction, double taxDeduction, string sumOfWorkingDays, string totalClaims, string totalDeductions,
double totalPayment, string contractNo,
ICollection<CustomizeCheckoutTempFine> checkoutFines,
ICollection<CustomizeCheckoutTempLoanInstallments> customizeCheckoutLoanInstallments,
ICollection<CustomizeCheckoutTempSalaryAid> customizeCheckoutSalaryAids,
ICollection<CustomizeCheckoutTempReward> customizeCheckoutRewards,
TimeSpan lateToWorkValue, double settingSalary, double dailyWage, WorkshopShiftStatus shiftStatus, IrregularShift irregularShift,
ICollection<CustomizeRotatingShift> customizeRotatingShifts, ICollection<CustomizeCheckoutRegularShift> employeeSettingsShifts)
{
YearInt = Convert.ToInt32(contractStart.ToFarsi().Substring(0, 4));
MonthInt = Convert.ToInt32(contractStart.ToFarsi().Substring(5, 2));
@@ -70,7 +80,13 @@ public class CustomizeCheckoutTemp : EntityBase
WorkshopFullName = workshopFullName;
LateToWorkValue = lateToWorkValue;
}
SettingSalary = settingSalary;
DailyWage = dailyWage;
ShiftStatus = shiftStatus;
IrregularShift = irregularShift;
CustomizeRotatingShifts = customizeRotatingShifts;
RegularShifts = employeeSettingsShifts;
}
#region Getters
/// <summary>
@@ -103,6 +119,10 @@ public class CustomizeCheckoutTemp : EntityBase
public ICollection<CustomizeCheckoutTempSalaryAid> CustomizeCheckoutSalaryAids { get; set; }
public ICollection<CustomizeCheckoutTempReward> CustomizeCheckoutRewards { get; set; }
public IrregularShift IrregularShift { get; set; }
public ICollection<CustomizeRotatingShift> CustomizeRotatingShifts { get; set; }
public ICollection<CustomizeCheckoutRegularShift> RegularShifts { get; set; }
#endregion
@@ -254,10 +274,22 @@ public class CustomizeCheckoutTemp : EntityBase
/// </summary>
public double TotalPayment { get; private set; }
/// <summary>
/// مزد روزانه
/// </summary>
public double DailyWage { get; private set; }
#region Values
/// <summary>
/// حقوق تعیین شده
/// </summary>
public double SettingSalary { get; private set; }
public WorkshopShiftStatus ShiftStatus { get; set; }
public TimeSpan LateToWorkValue { get; private set; }
#region Values
public TimeSpan LateToWorkValue { get; private set; }
#endregion

View File

@@ -13,5 +13,6 @@ public interface ICustomizeWorkshopEmployeeSettingsRepository : IRepository<long
List<CustomizeWorkshopEmployeeSettings> GetBy(long groupId);
List<CustomizeWorkshopEmployeeSettingsViewModel> GetEmployeeSettingsByWorkshopId(long workshopId);
List<CustomizeWorkshopEmployeeSettingsViewModel> GetEmployeeSettingNotInMainGroup(long entityWorkshopId);
void RemoveByWorkshopIdAndEmployeeId(long workshopId, long employeeId);
}

View File

@@ -21,11 +21,13 @@ public class Employee : EntityBase
public Employee(string fName, string lName, string fatherName,
DateTime dateOfBirth, DateTime dateOfIssue, string placeOfIssue,
string nationalCode, string idNumber, string gender, string nationality,
string phone, string address, string state, string city,
string maritalStatus, string militaryService, string levelOfEducation, string fieldOfStudy,
string bankCardNumber, string bankBranch, string insuranceCode, string insuranceHistoryByYear,
string insuranceHistoryByMonth, string numberOfChildren,string officePhone,
string mclsUserName, string mclsPassword, string eserviceUserName, string eservicePassword, string taxOfficeUserName, string taxOfficepassword, string sanaUserName, string sanaPassword)
string phone = null, string address = null, string state = null, string city = null,
string maritalStatus = null, string militaryService = null, string levelOfEducation = null, string fieldOfStudy = null,
string bankCardNumber = null, string bankBranch = null, string insuranceCode = null, string insuranceHistoryByYear = null,
string insuranceHistoryByMonth = null, string numberOfChildren = null, string officePhone = null,
string mclsUserName = null, string mclsPassword = null,
string eserviceUserName = null, string eservicePassword = null,
string taxOfficeUserName = null, string taxOfficepassword = null, string sanaUserName = null, string sanaPassword = null)
{
FName = fName;
LName = lName;
@@ -135,7 +137,16 @@ public class Employee : EntityBase
#region Pooya
public List<EmployeeDocuments> EmployeeDocuments { get; set; }
public EmployeeDocumentsAdminSelection EmployeeDocumentsAdminSelection { get; set; }
public List<EmployeeBankInformation> EmployeeBankInformationList { get; set; }
public List<EmployeeBankInformation> EmployeeBankInformationList { get; set; }
#endregion
#region Mahan
/// <summary>
/// آیا پرسنل احراز هویت شده است
/// </summary>
public bool IsAuthorized { get; set; }
#endregion
//public List<Checkout> Checkouts { get; set; }
@@ -211,4 +222,17 @@ public class Employee : EntityBase
this.IsActive = false;
this.IsActiveString = "false";
}
#region Mahan
public void EditFromEmployeeClientTemp(string maritalStatus)
{
MaritalStatus = maritalStatus;
}
public void Authorized()
{
IsAuthorized = true;
}
#endregion
}

View File

@@ -4,6 +4,7 @@ using System.Threading.Tasks;
using _0_Framework.Domain;
using Company.Domain.EmployeeInsuranceRecordAgg;
using CompanyManagment.App.Contracts.Employee;
using CompanyManagment.App.Contracts.Employee.DTO;
using CompanyManagment.App.Contracts.EmployeeInsuranceRecord;
namespace Company.Domain.EmployeeAgg;
@@ -47,6 +48,15 @@ public interface IEmployeeRepository : IRepository<long, Employee>
Employee GetByNationalCode(string nationalCode);
List<EmployeeViewModel> GetBy(List<long> employeeIds);
Employee GetByNationalCodeIgnoreQueryFilter(string nationalCode);
Task<ICollection<ClientStartedWorkEmployeesDto>> GetClientEmployeesStartWork(long workshopId);
Task<ICollection<ClientLeftWorkWorkEmployeesDto>> GetEmployeesForLeftWorkTemp(long workshopId);
Employee GetIgnoreQueryFilter(long id);
Task<List<EmployeeSelectListViewModel>> WorkedEmployeesInWorkshopSelectList(long workshopId);
#endregion
#region Pooya
@@ -54,7 +64,14 @@ public interface IEmployeeRepository : IRepository<long, Employee>
List<EmployeeViewModel> GetWorkingEmployeesByWorkshopIdsAndNationalCodeAndDate(List<long> workshopIds, string nationalCode, DateTime date);
List<EmployeeViewModel> GetWorkingEmployeesByWorkshopId(long workshopId);
List<EmployeeViewModel> GetWorkedEmployeesByWorkshopIdsAndNationalCodeAndDate(List<long> workshopIds,
string nationalCode, DateTime date);
List<(long Id, string Name)> SimpleGetRangeByIds(IEnumerable<long> newEmployeeIds);
Task<GetEditEmployeeInEmployeeDocumentViewModel> GetEmployeeEditInEmployeeDocumentWorkFlow(long employeeId,
long workshopId);
#endregion
}

View File

@@ -0,0 +1,31 @@
using System;
using _0_Framework.Domain;
using Company.Domain.EmployeeAgg;
namespace Company.Domain.EmployeeClientTempAgg;
public class EmployeeClientTemp : EntityBase
{
public EmployeeClientTemp(long workshopId, DateTime startWorkDate, long employeeId, string maritalStatus,
string employeeFullName)
{
StartWorkDate = startWorkDate;
WorkshopId = workshopId;
EmployeeId = employeeId;
MaritalStatus = maritalStatus;
EmployeeFullName = employeeFullName;
}
public string EmployeeFullName { get; private set; }
public long WorkshopId { get; private set; }
public long EmployeeId { get; private set; }
public DateTime StartWorkDate { get; private set; }
public string MaritalStatus { get; private set; }
public void Edit(string maritalStatus)
{
MaritalStatus = maritalStatus;
}
}

View File

@@ -0,0 +1,11 @@
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.EmployeeClientTemp;
namespace Company.Domain.EmployeeClientTempAgg;
public interface IEmployeeClientTempRepository : IRepository<long, EmployeeClientTemp>
{
EmployeeClientTemp GetByEmployeeIdAndWorkshopId(long employeeId, long commandWorkshopId);
EmployeeClientTempGetDetailsViewModel GetDetails(long employeeId, long workshopId);
void Remove(EmployeeClientTemp entity);
}

View File

@@ -5,6 +5,7 @@ using System.Text;
using System.Threading.Tasks;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.EmployeeComputeOptions;
using CompanyManagment.App.Contracts.Workshop;
namespace Company.Domain.EmployeeComputeOptionsAgg
{
@@ -14,5 +15,7 @@ namespace Company.Domain.EmployeeComputeOptionsAgg
EmployeeComputeOptionsViewModel GetEmployeeOptions(long workshopId, long employeeId);
List<EmployeeComputeOptionsViewModel> GetAllByWorkshopId(long workshopId);
List<WorkshopViewModel> TestBonusesBugWorkshops();
}
}

View File

@@ -54,11 +54,12 @@ namespace Company.Domain.EmployeeDocumentsAgg
var currentItems = EmployeeDocumentItemCollection.Where(x => x.DocumentStatus != DocumentStatus.Unsubmitted)
.GroupBy(x => x.DocumentLabel).Select(x => x.OrderByDescending(y => y.CreationDate).First());
var currentItemsFiltered = currentItems.Where(x => x.DocumentStatus == DocumentStatus.Confirmed || x.DocumentStatus == DocumentStatus.SubmittedByAdmin)
.Select(x => new{x.DocumentStatus,x.DocumentLabel}).ToList();
var currentItemsFiltered = currentItems.Where(x => x.DocumentStatus is DocumentStatus.Confirmed or DocumentStatus.SubmittedByAdmin or DocumentStatus.SubmittedByClient)
.Select(x => new { x.DocumentStatus, x.DocumentLabel }).ToList();
// ReSharper disable once SimplifyLinqExpressionUseAll
if (!currentItemsFiltered.Any(x => x.DocumentStatus == DocumentStatus.SubmittedByAdmin))
if (!currentItemsFiltered.Any(x => x.DocumentStatus is DocumentStatus.SubmittedByAdmin or DocumentStatus.SubmittedByClient))
IsSentToChecker = false;
else

View File

@@ -26,9 +26,9 @@ namespace Company.Domain.EmployeeDocumentsAgg
List<WorkshopWithEmployeeDocumentsViewModel> GetWorkshopsWithDocumentsAwaitingReviewForAdminWorkFlow(List<long> workshops);
List<EmployeeDocumentsViewModel> GetByWorkshopIdWithItemsForAdminWorkFlow(long workshopId);
int GetCheckerWorkFlowCount();
//int GetAdminWorkFlowCountForNewEmployees(List<long> workshopIds);
int GetAdminWorkFlowCountForSubmittedAndRejectedDocuments(List<long> workshopIds);
Task<int> GetCheckerWorkFlowCount();
Task<int> GetAdminWorkFlowCountForNewEmployees(List<long> workshopIds);
Task<int> GetAdminWorkFlowCountForSubmittedAndRejectedDocuments(List<long> workshopIds);
List<EmployeeDocumentsViewModel> GetDocumentsAwaitingReviewByWorkshopIdForCheckerWorkFlow(long workshopId);
}
}

View File

@@ -1,4 +1,5 @@
using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework_b.Domain;
using CompanyManagment.App.Contracts.Employee;
using CompanyManagment.App.Contracts.Employer;
@@ -16,4 +17,17 @@ public interface IFileRepository : IRepository<long, File1>
string GetEmployerFullNameById(long id);
List<EmployeeViewModel> GetAllEmploees();
List<EmployerViewModel> GetAllEmployers();
#region Mahan
Task<List<FileExcelViewModel>> GetExcelDetails();
Task<List<FileListViewModel>> GetList(GetFileSearchModel searchModel);
#endregion
Task<List<string>> GetAllArchiveNo();
Task<List<string>> GetAllClassFiles();
Task<List<EmployeeSelectListViewModel>> GetClientAndLitigation();
Task<EditEmployee> GetClientDetails(long fileId);
}

View File

@@ -1,4 +1,5 @@
using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework_b.Domain;
using CompanyManagment.App.Contracts.FileAlert;
@@ -10,4 +11,5 @@ public interface IFileAlertRepository : IRepository<long, FileAlert>
FileAlertViewModel GetDetails(long id);
void Remove(long id);
List<EditFileAlert> Search(FileAlertSearchModel searchModel);
Task<List<FileAlertViewModel>> GetFileAlerts(FileAlertSearchModel searchModel);
}

View File

@@ -6,7 +6,11 @@ namespace Company.Domain.FineAgg;
public class Fine:EntityBase
{
public Fine(long employeeId, long workshopId, string title, double amount,DateTime fineDate)
private Fine()
{
}
public Fine(long employeeId, long workshopId, string title, double amount,DateTime fineDate, long createdByAccountId, UserType createdByUserType)
{
EmployeeId = employeeId;
WorkshopId = workshopId;
@@ -15,6 +19,9 @@ public class Fine:EntityBase
IsActive = IsActive.True;
FineDate = fineDate;
CreatedByUserType = createdByUserType;
CreatedByAccountId = createdByAccountId;
}
public long EmployeeId { get; private set; }
@@ -24,7 +31,23 @@ public class Fine:EntityBase
public IsActive IsActive { get; private set; }
public DateTime FineDate { get; private set; }
public void DeActive()
/// <summary>
/// شخصی که جریمه را ساخته است
/// </summary>
public long CreatedByAccountId { get; private set; }
public UserType CreatedByUserType { get; private set; }
/// <summary>
/// شخصی که جریمه را ویرایش کرده است
/// </summary>
public long LastModifiedByAccountId { get; private set; }
public UserType LastModifiedByUserType { get; private set; }
public void DeActive()
{
IsActive = IsActive.False;
}
@@ -34,14 +57,15 @@ public class Fine:EntityBase
IsActive = IsActive.True;
}
public void Edit(long employeeId, long workshopId, string title, double amount,DateTime fineDate)
public void Edit(long employeeId, long workshopId, string title, double amount,DateTime fineDate, long modifiedByAccountId, UserType modifiedByUserType)
{
EmployeeId = employeeId;
WorkshopId = workshopId;
Title = title;
Amount = amount;
FineDate = fineDate;
LastModifiedByAccountId = modifiedByAccountId;
LastModifiedByUserType = modifiedByUserType;
}
}

View File

@@ -12,4 +12,14 @@ public interface IFineRepository : IRepository<long, Fine>
void Remove(Fine entity);
void RemoveRange(IEnumerable<Fine> entityEnumerable);
#region Pooya
/// <summary>
/// گروهبندی بر اساس ماه هنگام جستجو با انتخاب کارمند
/// </summary>
FinesGroupedViewModel GetSearchListAsGrouped(FineSearchViewModel searchModel);
#endregion
}

View File

@@ -0,0 +1,29 @@
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.InstitutionPlan;
using CompanyManagment.App.Contracts.TemporaryClientRegistration;
using System.Collections.Generic;
namespace Company.Domain.InstitutionPlanAgg;
public interface IPlanPercentageRepository : IRepository<long, PlanPercentage>
{
EditInstitutionPlanPercentage GetById(long id);
EditInstitutionPlanPercentage GetByFirst();
/// <summary>
/// دریافت لیست 30 تایی مبالغ سرویس ها به ازای هر نفر
/// </summary>
/// <param name="pageIndex"></param>
/// <param name="countPeron"></param>
/// <returns></returns>
List<InstitutionPlanViewModel> GetInstitutionPlanList(int pageIndex, int countPeron);
/// <summary>
/// دریافت مبالغ سرویس ها برای هر کارگاه
/// بر اساس تعداد پرسنل کارگاه
/// </summary>
/// <param name="command"></param>
/// <returns></returns>
InstitutionPlanViewModel GetInstitutionPlanForWorkshop(WorkshopTempViewModel command);
}

View File

@@ -0,0 +1,65 @@
using _0_Framework.Domain;
namespace Company.Domain.InstitutionPlanAgg;
public class PlanPercentage : EntityBaseWithoutCreationDate
{
public PlanPercentage(int contractAndCheckoutPercent, int insurancePercent, int rollCallPercent, int customizeCheckoutPercent, int contractAndCheckoutInPersonPercent, int insuranceInPersonPercent)
{
ContractAndCheckoutPercent = contractAndCheckoutPercent;
InsurancePercent = insurancePercent;
RollCallPercent = rollCallPercent;
CustomizeCheckoutPercent = customizeCheckoutPercent;
ContractAndCheckoutInPersonPercent = contractAndCheckoutInPersonPercent;
InsuranceInPersonPercent = insuranceInPersonPercent;
}
/// <summary>
/// قرارداد و تصفیه
/// درصد از مزد روزانه
/// </summary>
public int ContractAndCheckoutPercent { get; private set; }
/// <summary>
/// بیمه
/// درصد از مزد روزانه
/// </summary>
public int InsurancePercent { get; private set; }
/// <summary>
/// حضورغباب
/// درصد از مزد روزانه
/// </summary>
public int RollCallPercent { get; private set; }
/// <summary>
/// فیش غیر رسمی
/// درصد از مزد روزانه
/// </summary>
public int CustomizeCheckoutPercent { get; private set; }
/// <summary>
/// خدمات حضوری قرداد و تصفیه
/// درصد از مزد روزانه
/// </summary>
public int ContractAndCheckoutInPersonPercent { get; private set; }
/// <summary>
/// خدمات حضوری بیمه
/// درصد از مزد روزانه
/// </summary>
public int InsuranceInPersonPercent { get; private set; }
public void Edit(int contractAndCheckoutPercent, int insurancePercent, int rollCallPercent, int customizeCheckoutPercent, int contractAndCheckoutInPersonPercent, int insuranceInPersonPercent)
{
ContractAndCheckoutPercent = contractAndCheckoutPercent;
InsurancePercent = insurancePercent;
RollCallPercent = rollCallPercent;
CustomizeCheckoutPercent = customizeCheckoutPercent;
ContractAndCheckoutInPersonPercent = contractAndCheckoutInPersonPercent;
InsuranceInPersonPercent = insuranceInPersonPercent;
}
}

View File

@@ -8,7 +8,7 @@ public class Leave: EntityBase
{
public Leave(DateTime startLeave, DateTime endLeave,
string leaveHourses, long workshopId, long employeeId,
string paidLeaveType, string leaveType, string employeeFullName, string workshopName, bool isAccepted, string decription, int year, int month)
string paidLeaveType, string leaveType, string employeeFullName, string workshopName, bool isAccepted, string decription, int year, int month, TimeSpan shiftDuration, bool hasShiftDuration)
{
StartLeave = startLeave;
EndLeave = endLeave;
@@ -23,6 +23,8 @@ public class Leave: EntityBase
Decription = decription;
Year = year;
Month = month;
ShiftDuration = shiftDuration;
HasShiftDuration = hasShiftDuration;
}
public DateTime StartLeave { get; private set; }
@@ -38,9 +40,13 @@ public class Leave: EntityBase
public string Decription { get; private set; }
public int Year { get; private set; }
public int Month { get; private set; }
public TimeSpan ShiftDuration { get; private set; }
public bool HasShiftDuration { get; private set; }
public void Edit(DateTime startLeave, DateTime endLeave,
string leaveHourses, long workshopId, long employeeId,
string paidLeaveType, string leaveType, string employeeFullName, string workshopName, bool isAccepted, string decription, int year, int month)
string paidLeaveType, string leaveType, string employeeFullName, string workshopName, bool isAccepted, string decription, int year, int month,bool hasShiftDuration,TimeSpan shiftDuration)
{
StartLeave = startLeave;
EndLeave = endLeave;
@@ -55,5 +61,7 @@ public class Leave: EntityBase
Decription = decription;
Year = year;
Month = month;
ShiftDuration = shiftDuration;
HasShiftDuration = hasShiftDuration;
}
}

View File

@@ -27,6 +27,8 @@ public interface ILeftWorkRepository : IRepository<long, LeftWork>
/// <returns>یک کلاس از جنس اطلاعات ترک کار</returns>
LeftWorkViewModel GetByDateAndWorkshopIdAndEmployeeId(long workshopId, long employeeId, DateTime dateTime);
List<long> GetAllEmployeeIdsInWorkshop(long workshopId);
LeftWork GetLastLeftWorkByEmployeeIdAndWorkshopId(long workshopId, long employeeId);
#endregion
List<LeftWorkViewModel> GetLeftPersonelByWorkshopId(List<long> workshopIds);
@@ -40,7 +42,7 @@ public interface ILeftWorkRepository : IRepository<long, LeftWork>
bool IsEmployeeWorkingInDates(long employeeId, long workshopId, List<(DateTime, DateTime)> dates);
List<LeftWorkViewModel> GetByWorkshopIdInDates(long workshopId, DateTime startDateGr, DateTime endDateGr);
LeftWorkViewModel GetByWorkshopIdEmployeeIdInDates(long workshopId, long employeeId, DateTime start, DateTime end);
#endregion
#endregion
Task<LeftWork> GetLastLeftWork(long employeeId, long workshopId);
}

View File

@@ -0,0 +1,19 @@
using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.LeftWorkTemp;
namespace Company.Domain.LeftWorkTempAgg;
public interface ILeftWorkTempRepository:IRepository<long,LeftWorkTemp>
{
/// <summary>
/// گرفتن اطلاعات برای مودال جزئیات شروع به کار موقت یا ترک کار موقت
/// </summary>
/// <param name="employeeId"></param>
/// <param name="workshopId"></param>
/// <returns></returns>
Task<GetStartWorkTempDetails> GetStartAndLeftWorkDetails(long employeeId, long workshopId);
void Remove(LeftWorkTemp entity);
List<LeftWorkTempViewModel> GetLeftWorksByWorkshopId(long workshopId);
}

View File

@@ -0,0 +1,65 @@
using System;
using _0_Framework.Domain;
using Company.Domain.LeftWorkAgg;
using CompanyManagment.App.Contracts.LeftWorkTemp;
namespace Company.Domain.LeftWorkTempAgg;
public class LeftWorkTemp:EntityBase
{
private LeftWorkTemp()
{
}
/// <summary>
/// برای ایجاد ترک کار موقت
/// </summary>
/// <param name="leftWorkId"></param>
/// <param name="startWorkDate"></param>
/// <param name="leftWork"></param>
/// <param name="lastDayStanding"></param>
/// <param name="workshopId"></param>
/// <param name="employeeId"></param>
/// <param name="jobId"></param>
public static LeftWorkTemp CreateLeftWork(long leftWorkId, DateTime startWorkDate, DateTime leftWork, DateTime lastDayStanding, long workshopId, long employeeId,long jobId)
{
var leftWorkTemp = new LeftWorkTemp
{
LeftWorkId = leftWorkId,
LeftWork = leftWork,
LastDayStanding = lastDayStanding,
WorkshopId = workshopId,
EmployeeId = employeeId,
StartWork = startWorkDate,
LeftWorkType = LeftWorkTempType.LeftWork,
JobId = jobId
};
return leftWorkTemp;
}
public static LeftWorkTemp CreateStartWork(long workshopId, long employeeId, DateTime startDate,long jobId)
{
var leftWorkTemp = new LeftWorkTemp
{
StartWork = startDate,
WorkshopId = workshopId,
EmployeeId = employeeId,
JobId = jobId,
LeftWorkType = LeftWorkTempType.StartWork
};
return leftWorkTemp;
}
public long LeftWorkId { get; private set; }
public DateTime StartWork { get; private set; }
public DateTime LeftWork { get; private set; }
public DateTime LastDayStanding { get; private set; }
public long WorkshopId { get; private set; }
public long EmployeeId { get; private set; }
public long JobId { get; private set; }
public LeftWorkTempType LeftWorkType { get; private set; }
}

View File

@@ -9,12 +9,14 @@ namespace Company.Domain.LoanAgg.Entities;
public class Loan : EntityBase
{
private Loan()
private Loan(long createdByAccountId, UserType createdByUserType)
{
CreatedByAccountId = createdByAccountId;
CreatedByUserType = createdByUserType;
}
public Loan(long employeeId, long workshopId, DateTime startDateTime,
string count, double amount, double amountPerMonth,ICollection<LoanInstallment> loanInstallments, bool getRounded, DateTime loanGrantDate)
string count, double amount, double amountPerMonth,ICollection<LoanInstallment> loanInstallments, bool getRounded, DateTime loanGrantDate, long createdByAccountId, UserType createdByUserType)
{
EmployeeId = employeeId;
WorkshopId = workshopId;
@@ -25,6 +27,8 @@ public class Loan : EntityBase
LoanInstallments = loanInstallments;
GetRounded = getRounded;
LoanGrantDate = loanGrantDate;
CreatedByAccountId = createdByAccountId;
CreatedByUserType = createdByUserType;
//for (int i = 0; i < Convert.ToInt32(count); i++)
//{
// LoanInstallment newInstallment = new(amountPerMonth, month.ToString("00"), year.ToString("0000"));
@@ -64,7 +68,11 @@ public class Loan : EntityBase
public bool GetRounded { get; private set; }
public ICollection<LoanInstallment> LoanInstallments { get; private set; }
public void DeActiveInstallment(string year, string month)
public long CreatedByAccountId { get; private set; }
public UserType CreatedByUserType { get; private set; }
public void DeActiveInstallment(string year, string month)
{
var installment = LoanInstallments.FirstOrDefault(x => x.Month == month && x.Year == year);

View File

@@ -2,14 +2,17 @@
using Company.Domain.LoanAgg.Entities;
using CompanyManagment.App.Contracts.Loan;
using System.Collections.Generic;
using System.Threading.Tasks;
namespace Company.Domain.LoanAgg;
public interface ILoanRepository:IRepository<long,Loan>
{
List<LoanViewModel> GetSearchList(LoanSearchViewModel searchViewModel);
LoanViewModel GetDetails(long id);
Task<LoanDetailsViewModel> GetDetails(long id);
void Remove(Loan entity);
List<Loan> GetBy(IEnumerable<long> ids);
void RemoveRange(IEnumerable<Loan> loans);
LoanGroupedViewModel GetSearchListAsGrouped(LoanSearchViewModel searchModel);
}

View File

@@ -18,4 +18,11 @@ public interface IPersonnelCodeRepository : IRepository<long, PersonnelCodeDomai
long GetPSCodeByWorkshopIdAndEmployeeId(long workshopId, long employeeId);
long GetEmployeeIdByPersonelCode(long personleCode, long workshopId);
#region Mahan
long GetLastPersonnelCodeByWorkshop(long workshopId);
#endregion
}

View File

@@ -18,6 +18,6 @@ public interface IRewardRepository : IRepository<long, Reward>
/// <summary>
/// گروهبندی بر اساس ماه هنگام جستجو با انتخاب کارمند
/// </summary>
List<MonthlyGroupedEmployeeRewardsViewModel> GetSearchListByEmployee(RewardSearchModel searchModel);
RewardsGroupedViewModel GetSearchListAsGrouped(RewardSearchModel searchModel);
#endregion
}

View File

@@ -8,18 +8,19 @@ namespace Company.Domain.RewardAgg;
public class Reward:EntityBase
{
private Reward(string title)
private Reward()
{
Title = title;
}
public Reward(long employeeId, long workshopId, double amount, string description, long rewardedByAccountId, DateTime grantDate, string title , RewardType type = RewardType.None)
public Reward(long employeeId, long workshopId, double amount, string description, long rewardedByAccountId,UserType userType, DateTime grantDate, string title , RewardType type = RewardType.None)
{
EmployeeId = employeeId;
WorkshopId = workshopId;
Amount = amount;
Description = description;
RewardedByAccountId = rewardedByAccountId;
CreatedByAccountId = rewardedByAccountId;
CreatedByUserType = userType;
GrantDate = grantDate;
Title = title;
IsActive = IsActive.True;
@@ -45,24 +46,35 @@ public class Reward:EntityBase
public string Description { get; private set; }
/// <summary>
/// شخصی که پاداش را داده است
/// شخصی که پاداش را ساخته است
/// </summary>
public long RewardedByAccountId { get; private set; }
public long CreatedByAccountId { get; private set; }
public UserType CreatedByUserType { get;private set; }
/// <summary>
/// تاریخ اعطای پاداش
/// شخصی که پاداش را ویرایش کرده است
/// </summary>
public DateTime GrantDate { get; set; }
public long LastModifiedByAccountId { get; private set; }
public UserType LastModifiedByUserType { get; private set; }
/// <summary>
/// تاریخ اعطای پاداش
/// </summary>
public DateTime GrantDate { get; set; }
public RewardType RewardType { get; set; }
public IsActive IsActive { get; private set; }
public void Edit(double amount, string description, long rewardedByAccountId, DateTime grantDate,string title)
public void Edit(double amount, string description, long modifiedByAccountId, UserType userType, DateTime grantDate,string title)
{
Amount = amount;
Description = description;
RewardedByAccountId = rewardedByAccountId;
LastModifiedByAccountId = modifiedByAccountId;
LastModifiedByUserType = userType;
GrantDate = grantDate;
Title = title;
}

View File

@@ -25,7 +25,7 @@ public interface IRollCallDomainService
long workshopId);
TimeOnly GetEmployeeOffSetForRegularSettings(long employeeId, long workshopId);
DateTime GetEmployeeShiftDateByRollCallStartDate(long workshopId, long employeeId, DateTime rollCallStartDate);
DateTime GetEmployeeShiftDateByRollCallStartDate(long workshopId, long employeeId, DateTime rollCallStartDate,DateTime rollCallEndDate);
void CalculateTimeDifferences(RollCall rollCall);
@@ -173,16 +173,16 @@ public class RollCallDomainService : IRollCallDomainService
}
public DateTime GetEmployeeShiftDateByRollCallStartDate(long workshopId, long employeeId,
DateTime rollCallStartDate)
DateTime rollCallStartDate,DateTime rollCallEndDate)
{
var shiftDetails = GetEmployeeShiftDetails(employeeId, workshopId);
var offset = GetEmployeeOffSetForRegularSettings(employeeId, workshopId);
return shiftDetails.shiftType switch
{
WorkshopShiftStatus.Regular => CalculateRegularShiftDate(rollCallStartDate, offset),
WorkshopShiftStatus.Rotating => rollCallStartDate.Date,
WorkshopShiftStatus.Rotating => FindRotatingShift(rollCallEndDate,rollCallEndDate,shiftDetails.rotatingShifts).start.Date,
WorkshopShiftStatus.Irregular => rollCallStartDate.Date,
_ => throw new ArgumentOutOfRangeException()
};
@@ -209,7 +209,8 @@ public class RollCallDomainService : IRollCallDomainService
var shiftDetails = GetEmployeeShiftDetails(employeeId, workshopId);
List<RollCall> rollCalls = GetRollCallsInShiftDate(rollCall.ShiftDate,employeeId, workshopId).GetAwaiter().GetResult();
List<RollCall> rollCalls = GetRollCallsInShiftDate(rollCall.ShiftDate, employeeId, workshopId).GetAwaiter().GetResult();
var deletedRollCall = rollCalls.FirstOrDefault(x => x.id == rollCall.id);
rollCalls.Remove(deletedRollCall);
@@ -255,7 +256,7 @@ public class RollCallDomainService : IRollCallDomainService
var lateEntryRollCall = rollCallsInShift.OrderBy(x => x.StartDate).FirstOrDefault(x => x.StartDate > employeeShift.start);
var previousShift = employeeShifts.OrderByDescending(x => x.start)
.FirstOrDefault(x => x.end < employeeShift.start);
@@ -298,6 +299,8 @@ public class RollCallDomainService : IRollCallDomainService
var lateExitRollCall = rollCallsInShift.OrderBy(x => x.EndDate).FirstOrDefault(x => x.EndDate > employeeShift.end);
// تعجیل در خروج - زود رفتن
var nextShift = employeeShifts.OrderBy(x => x.start)
.FirstOrDefault(x => x.start > employeeShift.end);
@@ -371,8 +374,7 @@ public class RollCallDomainService : IRollCallDomainService
var lateEntryRollCallRotating = rollCallsInRotatingShift.OrderBy(x => x.StartDate).FirstOrDefault(x => x.StartDate > shift.start);
if (earlyEntryRollCallRotating != null)
{
@@ -403,6 +405,7 @@ public class RollCallDomainService : IRollCallDomainService
var lateExitRollCallRotating = rollCallsInRotatingShift.OrderBy(x => x.EndDate).FirstOrDefault(x => x.EndDate > shift.end);
if (earlyExitRollCallRotating != null && (rollCallsInRotatingShift.Any(x =>
x.StartDate < rotatingShiftEnd && x.StartDate > earlyExitRollCallRotating.EndDate) == false))
@@ -434,7 +437,7 @@ public class RollCallDomainService : IRollCallDomainService
_rollCallRepository.SaveChanges();
}
private async Task<List<RollCall>> GetRollCallsInShiftDate(DateTime rollCallShiftDate,long employeeId,long workshopId)
private async Task<List<RollCall>> GetRollCallsInShiftDate(DateTime rollCallShiftDate, long employeeId, long workshopId)
{
return await _rollCallRepository.GetRollCallsInShiftDate(rollCallShiftDate, employeeId, workshopId);
}

View File

@@ -27,8 +27,6 @@ namespace Company.Domain.RollCallAgg
Month = month;
RollCallModifyType = rollCallModifyType;
SetShiftDate(service);
var shiftDetails = service.GetEmployeeShiftDetails(employeeId, workshopId);
if (shiftDetails is { shiftType: WorkshopShiftStatus.Irregular, irregularShift: null } or
@@ -229,6 +227,8 @@ namespace Company.Domain.RollCallAgg
{
EndDate = endDate;
SetShiftDate(service);
ShiftDurationTimeSpan = CalculateShiftDuration(StartDate!.Value, EndDate.Value, service);
NightWorkTimeSpan = CalculateNightWorkDuration(StartDate.Value, endDate);
@@ -278,7 +278,7 @@ namespace Company.Domain.RollCallAgg
private void SetShiftDate(IRollCallDomainService service)
{
ShiftDate = service.GetEmployeeShiftDateByRollCallStartDate(WorkshopId, EmployeeId, StartDate!.Value);
ShiftDate = service.GetEmployeeShiftDateByRollCallStartDate(WorkshopId, EmployeeId, StartDate!.Value,EndDate.Value);
}
private TimeSpan CalculateShiftDuration(DateTime startRollCall, DateTime endRollCall, IRollCallDomainService service)
@@ -515,8 +515,21 @@ namespace Company.Domain.RollCallAgg
FridayWorkTimeSpan = CalculateFridayWorkDuration(StartDate.Value, EndDate.Value);
}
/// <summary>
/// جیزه
/// </summary>
public void ClearTimeDiff()
{
LateExitDuration = TimeSpan.Zero;
EarlyExitDuration = TimeSpan.Zero;
LateEntryDuration = TimeSpan.Zero;
EarlyEntryDuration = TimeSpan.Zero;
}
}
public enum RollCallModifyType
{
None,

View File

@@ -28,6 +28,8 @@ public interface IRollCallEmployeeRepository : IRepository<long, RollCallEmploye
bool HasEmployees(long workshopId);
(int activeEmployees, int deActiveEmployees) GetActiveAndDeActiveRollCallEmployees(long workshopId);
RollCallEmployee GetBy(long employeeId, long workshopId);
#endregion

View File

@@ -15,14 +15,16 @@ namespace Company.Domain.RollCallEmployeeStatusAgg
///
/// <returns></returns>
void AdjustRollCallStatusEndDates(List<AdjustRollCallEmployeesWithEmployeeLeftWork> command);
/// <summary>
/// دریافت وضعیت حضور غیاب پرسنل در تاریخ مشخص
/// </summary>
/// <param name="rollCallEmployeeId"></param>
/// <param name="date"></param>
/// <returns></returns>
/// <summary>
/// دریافت وضعیت حضور غیاب پرسنل در تاریخ مشخص
/// </summary>
/// <param name="rollCallEmployeeId"></param>
/// <param name="date"></param>
/// <returns></returns>
RollCallEmployeeStatus GetByRollCallEmployeeIdAndDate(long rollCallEmployeeId, DateTime date);
List<RollCallEmployeeStatusViewModel> GetActiveByWorkshopIdInDate(long workshopId, DateTime startDateGr, DateTime endDateGr);
List<RollCallEmployeeStatusViewModel> GetByWorkshopIdInDates(long workshopId, DateTime start, DateTime end);
bool IsActiveInPeriod(long employeeId, long workshopId, DateTime startDate, DateTime endDate);
}
}

View File

@@ -17,4 +17,5 @@ public interface IRollCallServiceRepository : IRepository<long, RollCallService>
List<RollCallServiceViewModel> GetAllServiceByAccountId(long accountId);
bool IsExistActiveServiceByWorkshopId(long workshopId);
}

View File

@@ -1,5 +1,6 @@
using System.Collections.Generic;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.Reward;
using CompanyManagment.App.Contracts.SalaryAid;
namespace Company.Domain.SalaryAidAgg;
@@ -11,4 +12,13 @@ public interface ISalaryAidRepository:IRepository<long,SalaryAid>
void Remove(SalaryAid entity);
List<SalaryAid> GetBy(IEnumerable<long> ids);
void RemoveRange(IEnumerable<SalaryAid> salaryAids);
#region Pooya
/// <summary>
/// گروهبندی بر اساس ماه هنگام جستجو با انتخاب کارمند
/// </summary>
SalaryAidsGroupedViewModel GetSearchListAsGrouped(SalaryAidSearchViewModel searchModel);
#endregion
}

View File

@@ -1,4 +1,5 @@
using System;
using _0_Framework.Application;
using _0_Framework.Domain;
using Hangfire.Annotations;
@@ -6,15 +7,18 @@ namespace Company.Domain.SalaryAidAgg;
public class SalaryAid:EntityBase
{
private SalaryAid(){}
public SalaryAid(long employeeId, long workshopId, double amount, DateTime salaryAidDateTime)
private SalaryAid()
{
}
public SalaryAid(long employeeId, long workshopId, double amount, DateTime salaryAidDateTime, long createdByAccountId, UserType createdByUserType)
{
EmployeeId = employeeId;
WorkshopId = workshopId;
Amount = amount;
SalaryAidDateTime = salaryAidDateTime;
CreatedByUserType = createdByUserType;
CreatedByAccountId = createdByAccountId;
}
public long EmployeeId { get; private set; }
@@ -22,9 +26,21 @@ public class SalaryAid:EntityBase
public double Amount { get; private set; }
public DateTime SalaryAidDateTime { get; private set; }
public void Edit(double amount, DateTime salaryAidTime)
public long CreatedByAccountId { get; private set; }
public UserType CreatedByUserType { get; private set; }
public long LastModifiedByAccountId { get; private set; }
public UserType LastModifiedByUserType { get; private set; }
public void Edit(double amount, DateTime salaryAidTime, long modifiedByAccountId, UserType modifiedByUserType)
{
Amount = amount;
SalaryAidDateTime = salaryAidTime;
LastModifiedByAccountId = modifiedByAccountId;
LastModifiedByUserType = modifiedByUserType;
}
}

View File

@@ -0,0 +1,100 @@
using System;
using _0_Framework.Application;
using _0_Framework.Domain;
namespace Company.Domain.TemporaryClientRegistrationAgg;
public class ContractingPartyTemp : EntityBase
{
public ContractingPartyTemp(string fName, string lName, string nationalCode, string idNumber, string phone, string fatherName, string state, string city, string address, string idNumberSeri, string idNumberSerial, Gender gender, DateTime dateOfBirth)
{
FName = fName;
LName = lName;
NationalCode = nationalCode;
IdNumber = idNumber;
Phone = phone;
FatherName = fatherName;
State = state;
City = city;
Address = address;
IdNumberSeri = idNumberSeri;
IdNumberSerial = idNumberSerial;
Gender = gender;
DateOfBirth = dateOfBirth;
}
/// <summary>
/// نام
/// </summary>
public string FName { get; private set; }
/// <summary>
/// نام خانوادگی
/// </summary>
public string LName { get; private set; }
/// <summary>
/// نام پدر
/// </summary>
public string FatherName { get; private set; }
/// <summary>
/// جنسیت
/// </summary>
public Gender Gender { get; private set; }
/// <summary>
/// کد ملی
/// </summary>
public string NationalCode { get; private set; }
/// <summary>
///تاریخ تولد
/// </summary>
public DateTime DateOfBirth { get; private set; }
/// <summary>
/// سری شناسنامه
/// </summary>
public string IdNumberSeri { get; private set; }
/// <summary>
/// سریال شناسنامه
/// </summary>
public string IdNumberSerial { get; private set; }
/// <summary>
/// شماره شناسنامه
/// </summary>
public string IdNumber { get; private set; }
/// <summary>
/// شماره همراه
/// </summary>
public string Phone { get; private set; }
/// <summary>
/// استان
/// </summary>
public string State { get; private set; }
/// <summary>
/// شهر
/// </summary>
public string City { get; private set; }
/// <summary>
/// نشانی
/// </summary>
public string Address { get; private set; }
public void UpdateAddress(string state, string city, string address)
{
this.State = state;
this.City = city;
this.Address = address;
}
}

View File

@@ -0,0 +1,30 @@
using System.Threading.Tasks;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.TemporaryClientRegistration;
namespace Company.Domain.TemporaryClientRegistrationAgg;
public interface IContractingPartyTempRepository :IRepository<long, ContractingPartyTemp>
{
/// <summary>
/// چک میکند که آیا طرف حساب با این کد ملی قبلا ایجاد شده است یا خبر
/// اگر ایجاد شده احراز هویت نشده احراز هویت میشود
/// </summary>
/// <param name="nationalCode"></param>
/// <returns></returns>
Task<bool> CheckExistOrAuthenticated(string nationalCode, string dateOfBirth);
/// <summary>
/// دریافت اطلاعات طرف حساب موقت با کد ملی
/// </summary>
/// <param name="nationalCode"></param>
/// <returns></returns>
ContractingPartyTempViewModel GetByNationalCode(string nationalCode);
/// <summary>
/// دریافت اطلاعات طرف حساب موقت با کد ملی
/// </summary>
/// <param name="nationalCode"></param>
/// <returns></returns>
ContractingPartyTempViewModel GetByContractingPartyTempId(long contractingPartyTempId);
}

View File

@@ -0,0 +1,18 @@
using System.Threading.Tasks;
using _0_Framework_b.Domain;
using CompanyManagment.App.Contracts.TemporaryClientRegistration;
namespace Company.Domain.TemporaryClientRegistrationAgg;
public interface IInstitutionContractTempRepository : IRepository<long, InstitutionContractTemp>
{
/// <summary>
/// دریافت قرارداد موقت
/// با توجه به آیدی طرف حساب
/// یا آیدی قرارداد
/// </summary>
/// <param name="id"></param>
/// <param name="contractingPartyId"></param>
/// <returns></returns>
Task<InstitutionContractTempViewModel> GetInstitutionContractTemp(long id,long contractingPartyTempId);
}

View File

@@ -0,0 +1,14 @@
using System.Collections.Generic;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.TemporaryClientRegistration;
namespace Company.Domain.TemporaryClientRegistrationAgg;
public interface IWorkshopServicesTempRepository : IRepository<long, WorkshopServicesTemp>
{
/// <summary>
/// حذف کامل سرویس های کارگاه
/// </summary>
/// <param name="workshopTempId"></param>
public void RemoveServices(long workshopTempId);
}

View File

@@ -0,0 +1,18 @@
using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.TemporaryClientRegistration;
namespace Company.Domain.TemporaryClientRegistrationAgg;
public interface IWorkshopTempRepository : IRepository<long, WorkshopTemp>
{
/// <summary>
/// دریافت کارگاه های ذخیره شده
/// </summary>
/// <param name="contractingPartyTemp"></param>
/// <returns></returns>
Task<List<WorkshopTempViewModel>> GetWorkshopTemp(long contractingPartyTemp);
}

View File

@@ -0,0 +1,134 @@
using System;
using System.Threading.Tasks;
using _0_Framework.Application.UID;
using _0_Framework.Domain;
namespace Company.Domain.TemporaryClientRegistrationAgg;
public class InstitutionContractTemp : EntityBase
{
public InstitutionContractTemp(long contractingPartyTempId, string paymentModel, string periodModel, double totalPayment, DateTime contractStartGr, DateTime contractEndGr, string officialCompany, double valueAddedTax, string verifyCode, string registrationStatus, int messageId, DateTime? sendVerifyCodeTime, DateTime? verifyCodeEndTime)
{
ContractingPartyTempId = contractingPartyTempId;
PaymentModel = paymentModel;
PeriodModel = periodModel;
TotalPayment = totalPayment;
ContractStartGr = contractStartGr;
ContractEndGr = contractEndGr;
OfficialCompany = officialCompany;
ValueAddedTax = valueAddedTax;
VerifyCode = verifyCode;
RegistrationStatus = registrationStatus;
MessageId = messageId;
SendVerifyCodeTime = sendVerifyCodeTime;
VerifyCodeEndTime = verifyCodeEndTime;
}
/// <summary>
/// آیدی طرف حساب
/// </summary>
public long ContractingPartyTempId { get; private set; }
/// <summary>
/// مدل پرداخت
/// بصورت یکجا
/// -
/// بصئورت ماهیانه
/// </summary>
public string PaymentModel { get; private set; }
/// <summary>
/// مدت قرارداد
/// چند ماهه؟
/// </summary>
public string PeriodModel { get; private set; }
/// <summary>
/// مبلغ کل قرارداد
/// </summary>
public double TotalPayment { get; private set; }
/// <summary>
/// تاریخ شرع قراداد
/// میلادی
/// </summary>
public DateTime ContractStartGr { get; private set; }
/// <summary>
/// تاریخ پایان قراداد شمسی
/// </summary>
public DateTime ContractEndGr { get; private set; }
/// <summary>
/// پرداخت بصورت رسمی با غیر رسمی
/// </summary>
public string OfficialCompany { get; private set; }
/// <summary>
/// مبلغ مالیات بر ارزش افزوده
/// </summary>
public double ValueAddedTax { get; private set; }
/// <summary>
/// کد شش رقمی ثبت قرارداد
/// </summary>
public string VerifyCode { get; set; }
/// <summary>
/// وضعیت ثبت نام
/// -
/// BeforeSendVerifyCode قبل از ارسال کد
/// -
/// VerifyCodeSent کد ارسال شده
/// -
/// Completed ثبت نام تکمیل شده
/// </summary>
public string RegistrationStatus { get; private set; }
/// <summary>
/// آی دی پیامک ارسال شده
/// </summary>
public int MessageId { get; private set; }
/// <summary>
/// ثبت زمان ارسال کد
/// </summary>
public DateTime? SendVerifyCodeTime { get; private set; }
/// <summary>
/// زمان پایان مهلت ارسال کد
/// </summary>
public DateTime? VerifyCodeEndTime{ get; private set; }
public void Edit(long contractingPartyTempId, string paymentModel, string periodModel, double totalPayment, DateTime contractStartGr, DateTime contractEndGr, string officialCompany, double valueAddedTax, string verifyCode, string registrationStatus, int messageId, DateTime? sendVerifyCodeTime, DateTime? verifyCodeEndTime)
{
ContractingPartyTempId = contractingPartyTempId;
PaymentModel = paymentModel;
PeriodModel = periodModel;
TotalPayment = totalPayment;
ContractStartGr = contractStartGr;
ContractEndGr = contractEndGr;
OfficialCompany = officialCompany;
ValueAddedTax = valueAddedTax;
VerifyCode = verifyCode;
RegistrationStatus = registrationStatus;
MessageId = messageId;
SendVerifyCodeTime = sendVerifyCodeTime;
VerifyCodeEndTime = verifyCodeEndTime;
}
public void Update(string verifyCode, string registrationStatus, int messageId, DateTime? sendVerifyCodeTime, DateTime? verifyCodeEndTime)
{
VerifyCode = verifyCode;
RegistrationStatus = registrationStatus;
MessageId = messageId;
SendVerifyCodeTime = sendVerifyCodeTime;
VerifyCodeEndTime = verifyCodeEndTime;
}
}

View File

@@ -0,0 +1,34 @@
using _0_Framework.Domain;
namespace Company.Domain.TemporaryClientRegistrationAgg;
public class WorkshopServicesTemp : EntityBase
{
public WorkshopServicesTemp(string serviceName, int countPerson, long workshopTempId)
{
ServiceName = serviceName;
CountPerson = countPerson;
WorkshopTempId = workshopTempId;
}
/// <summary>
/// نام سرویس
/// </summary>
public string ServiceName { get; private set; }
/// <summary>
/// تعداد پرسنل
/// </summary>
public int CountPerson { get; private set; }
/// <summary>
/// آی دی کارگاه موقت
/// </summary>
public long WorkshopTempId { get; private set; }
public WorkshopTemp WorkshopTemp { get; private set; }
public void UpdateService(int countPerson)
{
this.CountPerson = countPerson;
}
}

View File

@@ -0,0 +1,48 @@
using System.Collections.Generic;
using _0_Framework.Domain;
namespace Company.Domain.TemporaryClientRegistrationAgg;
public class WorkshopTemp : EntityBase
{
public WorkshopTemp(string workshopName, int countPerson, long contractingPartyTempId, double workshopServicesAmount)
{
WorkshopName = workshopName;
CountPerson = countPerson;
ContractingPartyTempId = contractingPartyTempId;
WorkshopServicesAmount = workshopServicesAmount;
}
/// <summary>
/// نام کارگاه
/// </summary>
public string WorkshopName { get; private set; }
/// <summary>
/// تعداد پرسنل
/// </summary>
public int CountPerson { get; private set; }
/// <summary>
/// ای دی طرف حساب
/// </summary>
public long ContractingPartyTempId { get; private set; }
/// <summary>
/// جمع کل مبالغ سرویس ها برای کارگاه
/// </summary>
public double WorkshopServicesAmount { get; private set; }
public List<WorkshopServicesTemp> WorkshopServicesTemps { get; private set; }
public void Edit(string workshopName, int countPerson, double workshopServicesAmount)
{
this.WorkshopName = workshopName;
this.CountPerson = countPerson;
this.WorkshopServicesAmount = workshopServicesAmount;
}
}

View File

@@ -1,9 +1,11 @@
using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework.Application;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.Contract;
using CompanyManagment.App.Contracts.PersonalContractingParty;
using CompanyManagment.App.Contracts.Workshop;
using CompanyManagment.App.Contracts.Workshop.DTOs;
namespace Company.Domain.WorkshopAgg;
@@ -59,18 +61,23 @@ public interface IWorkshopRepository : IRepository<long, Workshop>
List<PrintListWorkshop> PrintWorkshopList(WorkshopSearchModel searchModel);
#endregion
#region Mahan
PersonalContractingPartyViewModel GetPersonalContractingPartyByWorkshopId(long workshopId);
List<WorkshopViewModel> GetWorkshopsByClientAccountId(long clientAccountId);
Task<List<WorkshopWithStartedEmployeesDto>> GetWorkshopsForEmployeeStartWork(long accountId);
Task<int> GetWorkshopsForEmployeeStartWorkCount(long accountId);
Task<List<WorkshopWithLeftWorkTempEmployeesDto>> GetWorkshopsForLeftWorkTemp(long accountId);
Task<int> GetWorkshopsForLeftWorkTempCount(long accountId);
#endregion
#endregion
#region Insurance
/// <summary>
/// لیست انتخاب کارگاه در مودال ایجاد بیمه
/// </summary>
/// <returns></returns>
List<WorkshopViewModel> GetWorkshopSelectListInsuransce();
#region Insurance
/// <summary>
/// لیست انتخاب کارگاه در مودال ایجاد بیمه
/// </summary>
/// <returns></returns>
List<WorkshopViewModel> GetWorkshopSelectListInsuransce();
#endregion
/// <summary>
@@ -87,4 +94,13 @@ public interface IWorkshopRepository : IRepository<long, Workshop>
/// <param name="workshopId"></param>
/// <returns></returns>
OperationResult EditAccountLeftWorkAndWorkshopAccounts(List<long> accountIds, long workshopId);
#region Pooya
List<PersonnelInfoViewModel> GetPersonnelInfoRemastered(long searchModelWorkshopId);
#endregion
}

View File

@@ -11,6 +11,10 @@ namespace Company.Domain.YearlySalaryAgg;
public interface IYearlySalaryRepository : IRepository<long, YearlySalary>
{
/// <summary>
/// تست محاسبه مزد پایه
/// </summary>
void TestDayliFeeCompute();
List<string> GetYears();
List<YearlySalaryViewModel> GetYearlySalary();
MontlywageBunosYearsViewModel GetMontlyBunosYears(TimeSpan weeklyTime, DateTime contractStart,DateTime contractEnd, double daylyWage, string weeklyWorkingTime, int officialholiday, int friday, string totalHoursH, string totalHorsM, string basic, int fridayStartToEnd, double dayliFeeComplete, bool hasRollCall, bool holidaysWorking);

View File

@@ -0,0 +1,134 @@
using System.Drawing;
using OfficeOpenXml.Style;
using OfficeOpenXml;
using CompanyManagement.Infrastructure.Excel.Checkout;
using CompanyManagment.App.Contracts.File1;
using Microsoft.AspNetCore.Server.HttpSys;
using _0_Framework.Application;
namespace CompanyManagement.Infrastructure.Excel.CaseManagement;
public class CaseManagementExcelGenerator
{
public static Dictionary<string, string> Header { get; set; } = new()
{
{"ArchiveNumber","شماره بایگانی"},
{"FileClass","کلاسه پرونده"},
{"Client","موکل"},
{"LitigationParty","طرف دعوی"},
{"DiagnosisPetitionTotalPenalty","مبلغ دادنامه تشخیص"},
{"DisputeResolutionTotalPenalty","مبلغ دادنامه حل اختلاف"},
{"MclsUsername","نام کاربری"},
{"MclsPassword","رمز عبور"},
};
public static byte[] GenerateCheckoutTempExcelInfo(List<FileExcelViewModel> data)
{
OfficeOpenXml.ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
using var package = new ExcelPackage();
CreateSheet(data, package,"همه");
CreateSheet(data.Where(x=>x.Status ==2).ToList(), package,"فعال");
CreateSheet(data.Where(x=>x.Status == 1).ToList(), package,"غیرفعال");
CreateSheet(data.Where(x=>x.Status == 3).ToList(), package,"خروج موقت");
return package.GetAsByteArray();
}
private static void CreateSheet(List<FileExcelViewModel> data, ExcelPackage package,string sheetName)
{
var worksheet = package.Workbook.Worksheets.Add(sheetName);
var indexCell = worksheet.Cells[1, 1];
indexCell.Value = "ردیف";
ApplyHeaderStyle(indexCell);
for (int i = 0; i < Header.Count; i++)
{
worksheet.Cells[1, i + 2].Value = Header.ElementAt(i).Value;
ApplyHeaderStyle(worksheet.Cells[1, i + 2]);
}
var dataRow = 2;
foreach (var item in data)
{
var column = 2;
foreach (var header in Header)
{
var property = item.GetType().GetProperty(header.Key);
var value = property.GetValue(item, null)?.ToString();
var cell = worksheet.Cells[dataRow, column];
// Check if the property requires MoneyToDouble()
if (RequiresMoneyToDouble(property.Name))
{
cell.Value = MoneyToDouble(value);
cell.Style.Numberformat.Format = "#,##0";
}
else
{
cell.Value = value;
}
ApplyGeneralDataStyle(worksheet.Cells[dataRow, column]);
switch (item.Status)
{
case 1:
cell.Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.Gray);
break;
case 2:
cell.Style.Fill.BackgroundColor.SetColor(Color.White);
break;
case 3:
cell.Style.Fill.BackgroundColor.SetColor(Color.Orange);
break;
}
column++;
}
var rowCounter = worksheet.Cells[dataRow, 1];
rowCounter.Value = dataRow - 1;
dataRow++;
}
worksheet.Cells[worksheet.Dimension.Address].AutoFitColumns();
worksheet.View.RightToLeft = true;
}
private static bool RequiresMoneyToDouble(string propertyName)
{
var propertiesRequiringConversion = new HashSet<string>
{
"DiagnosisPetitionTotalPenalty", "DisputeResolutionTotalPenalty"
};
return propertiesRequiringConversion.Contains(propertyName);
}
private static double MoneyToDouble(string value)
{
Console.WriteLine(value);
var min = value.Length > 1 ? value.Substring(0, 2) : "";
var test = min == "\u200e\u2212" ? value.MoneyToDouble() * -1 : value.MoneyToDouble();
Console.WriteLine(test);
return test;
}
private static void ApplyHeaderStyle(ExcelRange cell)
{
cell.Style.Font.Bold = true;
cell.Style.Fill.PatternType = ExcelFillStyle.Solid;
cell.Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.LightGray);
cell.Style.HorizontalAlignment = ExcelHorizontalAlignment.Center;
cell.Style.Border.BorderAround(ExcelBorderStyle.Thin);
}
private static void ApplyGeneralDataStyle(ExcelRange cell)
{
cell.Style.Border.BorderAround(ExcelBorderStyle.Thin);
cell.Style.HorizontalAlignment = ExcelHorizontalAlignment.Center;
cell.Style.VerticalAlignment = ExcelVerticalAlignment.Center;
cell.Style.Fill.PatternType = ExcelFillStyle.Solid;
}
}

View File

@@ -0,0 +1,229 @@
using System.Drawing;
using _0_Framework.Application;
using OfficeOpenXml;
using OfficeOpenXml.Style;
namespace CompanyManagement.Infrastructure.Excel.Checkout;
public class CustomizeCheckoutExcelGenerator
{
public static Dictionary<string, string> Header { get; set; } = new() {
{ "Month", "ماه" },
{ "Year", "سال" },
{ "EmployeeFullName", "نام و نام خانوادگی" },
{ "PersonnelCodeString", "شماره پرسنلی" },
{ "NationalCode", "کدملی" },
{ "SumOfWorkingDays", "روز کارکرد" },
{ "MonthlySalary", "حقوق ماهانه" },
{ "BaseYearsPay", "سنوات" },
{ "MarriedAllowance", "حق تاهل" },
{ "OvertimePay", "اضافه کاری" },
{ "NightworkPay", "شب کاری" },
{ "FridayPay", "جمعه کاری" },
{ "MissionPay", "مأموریت" },
{ "ShiftPay", "نوبت کاری" },
{ "FamilyAllowance", "حق فرزند" },
{ "BonusesPay", "پاداش" },
{ "LeavePay", "مزد مرخصی" },
{ "RewardPay", "پاداش" },
{ "FineDeduction", "جریمه" },
{ "InsuranceDeduction", "حق بیمه" },
{ "TaxDeducation", "مالیات" },
{ "InstallmentDeduction", "قسط وام" },
{ "SalaryAidDeduction", "مساعده" },
{ "AbsenceDeduction", "غیبت" },
{ "EarlyExitDeduction", "تعجیل در خروج" },
{ "LateToWorkDeduction", "تاخیر در ورود" },
{ "TotalClaims", "جمع مطالبات" },
{ "TotalDeductions", "جمع کسورات" },
{ "TotalPayment", "مبلغ قابل پرداخت" },
{ "CardNumber", "شماره کارت" },
{ "ShebaNumber", "شماره شبا" },
{ "BankAccountNumber", "شماره حساب" },
{ "BankName", "نام بانک" },
};
public static byte[] GenerateCheckoutTempExcelInfo(List<CustomizeCheckoutTempExcelViewModel> data, List<string> selectedParameters)
{
OfficeOpenXml.ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
using var package = new ExcelPackage();
var worksheet = package.Workbook.Worksheets.Add("Sheet1");
// Define headers
Dictionary<string, string> filteredHeaders;
if (!selectedParameters.Any())
{
filteredHeaders = Header;
}
else
{
// Filter headers based on selected parameters
filteredHeaders = Header.Where(h => selectedParameters.Contains(h.Key)).ToDictionary();
}
var indexCell = worksheet.Cells[1, 1];
indexCell.Value = "ردیف";
ApplyHeaderStyle(indexCell);
// Add headers to worksheet
for (int i = 0; i < filteredHeaders.Count; i++)
{
worksheet.Cells[1, i + 2].Value = filteredHeaders.ElementAt(i).Value;
ApplyHeaderStyle(worksheet.Cells[1, i + 2]);
}
var dataRow = 2;
int totalPaymentColumnIndex = -1;
foreach (var item in data)
{
var column = 2;
foreach (var header in filteredHeaders)
{
var property = item.GetType().GetProperty(header.Key);
var value = property.GetValue(item, null)?.ToString();
// Check if the property requires MoneyToDouble()
if (RequiresMoneyToDouble(property.Name))
{
worksheet.Cells[dataRow, column].Value = MoneyToDouble(value);
}
else
{
worksheet.Cells[dataRow, column].Value = value;
}
ApplyGeneralDataStyle(worksheet.Cells[dataRow, column]);
ApplySpecificStyle(worksheet.Cells[dataRow, column], column, worksheet); // Apply specific styles
if (header.Key == "TotalPayment")
{
totalPaymentColumnIndex = column;
}
column++;
}
var rowCounter = worksheet.Cells[dataRow, 1];
rowCounter.Value = dataRow - 1;
ApplyGeneralDataStyle(rowCounter);
ApplySpecificStyle(rowCounter, 1, worksheet);
dataRow++;
}
worksheet.Cells[worksheet.Dimension.Address].AutoFitColumns();
worksheet.PrinterSettings.PaperSize = ePaperSize.A4;
worksheet.PrinterSettings.Orientation = eOrientation.Landscape;
worksheet.PrinterSettings.FitToPage = true;
worksheet.PrinterSettings.FitToWidth = 1;
worksheet.PrinterSettings.FitToHeight = 0;
worksheet.PrinterSettings.Scale = 85;
worksheet.View.RightToLeft = true;
if (totalPaymentColumnIndex != -1)
{
ApplyConditionalFormatting(worksheet, dataRow, totalPaymentColumnIndex);
}
return package.GetAsByteArray();
}
// Method to check if a property requires MoneyToDouble()
private static bool RequiresMoneyToDouble(string propertyName)
{
var propertiesRequiringConversion = new HashSet<string>
{
"MonthlySalary", "RewardPay", "FridayPay", "OvertimePay", "ShiftPay", "NightWorkPay",
"MarriedAllowance", "FamilyAllowance", "BonusesPay", "BaseYearsPay", "LeavePay",
"AbsenceDeduction", "LateToWorkDeduction", "EarlyExitDeduction", "SalaryAidDeduction",
"InstallmentDeduction", "FineDeduction", "InsuranceDeduction", "TaxDeduction",
"TotalClaims", "TotalDeductions", "TotalPayment"
};
return propertiesRequiringConversion.Contains(propertyName);
}
// Placeholder for the MoneyToDouble() method
private static double MoneyToDouble(string value)
{
Console.WriteLine(value);
var min = value.Length > 1 ? value.Substring(0, 2) : "";
var test = min == "\u200e\u2212" ? value.MoneyToDouble() * -1 : value.MoneyToDouble();
Console.WriteLine(test);
return test;
}
private static void ApplyHeaderStyle(ExcelRange cell)
{
cell.Style.Font.Bold = true;
cell.Style.Fill.PatternType = ExcelFillStyle.Solid;
cell.Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.LightGray);
cell.Style.HorizontalAlignment = ExcelHorizontalAlignment.Center;
cell.Style.Border.BorderAround(ExcelBorderStyle.Thin);
}
private static void ApplyGeneralDataStyle(ExcelRange cell)
{
cell.Style.Border.BorderAround(ExcelBorderStyle.Thin);
cell.Style.HorizontalAlignment = ExcelHorizontalAlignment.Center;
cell.Style.VerticalAlignment = ExcelVerticalAlignment.Center;
cell.Style.Fill.PatternType = ExcelFillStyle.Solid;
}
private static void ApplySpecificStyle(ExcelRange cell, int columnIndex, ExcelWorksheet worksheet)
{
var headerCell = worksheet.Cells[1, columnIndex].Value.ToString();
var index = Header.Values.ToList().IndexOf(headerCell);
index += 2;
switch (index)
{
case int n when (n >= 1 && n <= 8):
cell.Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.LightYellow);
break;
case int n when (n >= 9 && n <= 19):
cell.Style.Fill.BackgroundColor.SetColor(1, 208, 248, 208);
cell.Style.Numberformat.Format = "#,##0";
break;
case int n when (n >= 20 && n <= 27):
cell.Style.Fill.BackgroundColor.SetColor(1, 246, 176, 176);
cell.Style.Numberformat.Format = "#,##0";
break;
case 28:
cell.Style.Fill.BackgroundColor.SetColor(1, 169, 208, 142);
cell.Style.Numberformat.Format = "#,##0";
break;
case 29:
cell.Style.Fill.BackgroundColor.SetColor(1, 241, 143, 143);
cell.Style.Numberformat.Format = "#,##0";
break;
case 30:
cell.Style.Fill.BackgroundColor.SetColor(1, 168, 186, 254);
cell.Style.Numberformat.Format = "#,##0";
break;
case >= 31 and <= 34:
cell.Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.LightYellow);
break;
}
}
private static void ApplyConditionalFormatting(ExcelWorksheet worksheet, int dataRow, int totalPaymentColumnIndex)
{
for (int rowIndex = 2; rowIndex < dataRow; rowIndex++)
{
var totalPaymentValue = worksheet.Cells[rowIndex, totalPaymentColumnIndex].Value;
if (totalPaymentValue != null && double.TryParse(totalPaymentValue.ToString(), out double payment))
{
if (payment < 0)
{
var rowRange = worksheet.Cells[rowIndex, 1, rowIndex, worksheet.Dimension.End.Column];
rowRange.Style.Fill.PatternType = ExcelFillStyle.Solid; rowRange.Style.Fill.BackgroundColor.SetColor(Color.Red);
foreach (var cell in rowRange)
{
cell.Style.Font.Color.SetColor(Color.White);
}
}
}
}
}
}

View File

@@ -1,6 +1,4 @@
using System;
namespace _0_Framework.Excel.Checkout;
namespace CompanyManagement.Infrastructure.Excel.Checkout;
public class CustomizeCheckoutTempExcelViewModel
{
@@ -52,5 +50,7 @@ public class CustomizeCheckoutTempExcelViewModel
public string CardNumber { get; set; }
public string ShebaNumber { get; set; }
public string BankName { get; set; }
}

View File

@@ -13,5 +13,8 @@
<ProjectReference Include="..\AccountMangement.Infrastructure.EFCore\AccountMangement.Infrastructure.EFCore.csproj" />
<ProjectReference Include="..\CompanyManagment.EFCore\CompanyManagment.EFCore.csproj" />
</ItemGroup>
<ItemGroup>
<Folder Include="CaseManagement\" />
</ItemGroup>
</Project>

View File

@@ -1,11 +1,7 @@
using System.Collections.Generic;
using System.Drawing;
using OfficeOpenXml;
using OfficeOpenXml;
using OfficeOpenXml.Style;
using System.Linq;
using OfficeOpenXml.Table.PivotTable;
namespace _0_Framework.Excel.EmployeeBankInfo;
namespace CompanyManagement.Infrastructure.Excel.EmployeeBankInfo;
public class EmployeeBankInfoExcelGenerator
{

View File

@@ -1,7 +1,5 @@

using System.Collections.Generic;
namespace _0_Framework.Excel.EmployeeBankInfo;
namespace CompanyManagement.Infrastructure.Excel.EmployeeBankInfo;
public class EmployeeBankInfoExcelViewModel
{

View File

@@ -1,7 +1,4 @@
using System.Collections.Generic;
using System;
namespace _0_Framework.Excel.RollCall;
namespace CompanyManagement.Infrastructure.Excel.RollCall;

View File

@@ -1,8 +1,4 @@
using System.Collections.Generic;
using System;
using System.Security.Cryptography;
namespace _0_Framework.Excel.RollCall;
namespace CompanyManagement.Infrastructure.Excel.RollCall;
public class CaseHistoryRollCallForOneDayViewModel
{

View File

@@ -1,11 +1,8 @@
using System;
using System.Collections.Generic;
using System.IO;
using System.Reflection;
using _0_Framework.Excel;
using OfficeOpenXml;
using OfficeOpenXml.Drawing;
namespace _0_Framework.Excel.RollCall;
namespace CompanyManagement.Infrastructure.Excel.RollCall;
public class RollCallExcelGenerator : ExcelGenerator
{

View File

@@ -1,5 +1,5 @@
using System.Collections.Generic;
using _0_Framework_b.Application;
using _0_Framework.Application;
namespace CompanyManagment.App.Contracts.Board;

View File

@@ -10,4 +10,6 @@ public class MainViewModel
{
public List<CheckoutViewModel> MainList { get; set; }
public string WorkshopSearch { get; set; }
public bool IsSysManager { get; set; }
}

View File

@@ -1,7 +1,12 @@
using System;
using System.Collections.Generic;
using System.Security.AccessControl;
using _0_Framework.Application;
using _0_Framework.Domain.CustomizeCheckoutShared.Base;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
using _0_Framework.Domain.CustomizeCheckoutShared.ValueObjects;
using CompanyManagment.App.Contracts.CustomizeWorkshopSettings;
using CompanyManagment.App.Contracts.File1;
using CompanyManagment.App.Contracts.Fine;
using CompanyManagment.App.Contracts.Loan;
@@ -12,10 +17,13 @@ namespace CompanyManagment.App.Contracts.CustomizeCheckout;
public class CustomizeCheckoutMandatoryViewModel
{
/// <summary>
/// حقوق ماهانه
/// </summary>
public double MonthlySalary { get; set; }
/// <summary>
/// حقوق ماهانه
/// </summary>
public double MonthlySalary { get; set; }
#region Payments
@@ -105,6 +113,8 @@ public class CustomizeCheckoutMandatoryViewModel
public double EarlyExitDeduction { get; set; }
/// <summary>
/// مساعده
@@ -130,6 +140,7 @@ public class CustomizeCheckoutMandatoryViewModel
#region Values
public TimeSpan LateToWorkValue { get; set; }
#endregion
/// <summary>
/// تعداد روزهای کارکرد
/// </summary>
@@ -141,14 +152,14 @@ public class CustomizeCheckoutMandatoryViewModel
/// مجموع مطالبات
/// </summary>
public double TotalClaimsDouble => MonthlySalary + FridayPay + OverTimePay + BaseYearsPay + BonusesPay + NightWorkPay +
MarriedAllowance + ShiftPay + FamilyAllowance + LeavePay + RewardPay;
MarriedAllowance + ShiftPay + FamilyAllowance + LeavePay + RewardPay;
/// <summary>
/// مجموع کسورات
/// </summary>
public double TotalDeductionsDouble => FineAbsenceDeduction + InsuranceDeduction + LateToWorkDeduction +
EarlyExitDeduction + SalaryAidDeduction + InstallmentDeduction +
FineDeduction + TaxDeduction;
EarlyExitDeduction + SalaryAidDeduction + InstallmentDeduction +
FineDeduction + TaxDeduction;
/// <summary>
/// مجموع مطالبات
@@ -163,7 +174,7 @@ public class CustomizeCheckoutMandatoryViewModel
/// <summary>
/// مجموع پرداختی
/// </summary>
public double TotalPayment => TotalClaimsDouble - TotalDeductionsDouble;
public double TotalPayment => Math.Truncate(TotalClaimsDouble - TotalDeductionsDouble);
#region Employee Information
@@ -182,10 +193,20 @@ public class CustomizeCheckoutMandatoryViewModel
public int Year { get; set; }
public int Month { get; set; }
#endregion
public List<FineViewModel> FineViewModels { get; set; }
public List<RewardViewModel> RewardViewModels { get; set; }
public List<LoanInstallmentViewModel> InstallmentViewModels{ get; set; }
public List<SalaryAidViewModel> SalaryAidViewModels { get; set; }
public List<FineViewModel> FineViewModels { get; set; } = [];
public List<RewardViewModel> RewardViewModels { get; set; } = [];
public List<LoanInstallmentViewModel> InstallmentViewModels { get; set; } = [];
public List<SalaryAidViewModel> SalaryAidViewModels { get; set; } = [];
public double SettingSalary { get; set; }
public double DailyWage { get; set; }
public WorkshopShiftStatus ShiftStatus { get; set; }
public IrregularShift IrregularShift { get; set; }
public ICollection<CustomizeRotatingShift> CustomizeRotatingShifts { get; set; } = [];
public ICollection<CustomizeSifts> EmployeeSettingsShifts { get; set; } = [];
}

View File

@@ -2,6 +2,11 @@
using CompanyManagment.App.Contracts.RollCall;
using System;
using System.Collections.Generic;
using System.Runtime;
using System.Security.AccessControl;
using _0_Framework.Domain.CustomizeCheckoutShared.Base;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
using _0_Framework.Domain.CustomizeCheckoutShared.ValueObjects;
using CompanyManagment.App.Contracts.Fine;
using CompanyManagment.App.Contracts.Loan;
using CompanyManagment.App.Contracts.Reward;
@@ -66,7 +71,7 @@ namespace CompanyManagment.App.Contracts.CustomizeCheckout
public string LeavePay { get; set; }
public string RewardPay { get; set; }
public bool IsBirthday { get; set; } = true;
public string FineDeduction { get; set; }
public string InsuranceDeduction { get; set; }
public string TaxDeducation { get; set; }
@@ -86,24 +91,32 @@ namespace CompanyManagment.App.Contracts.CustomizeCheckout
public List<LoanInstallmentViewModel> InstallmentViewModels { get; set; }
public List<SalaryAidViewModel> SalaryAidViewModels { get; set; }
public bool TotalPaymentHide { get; set; }
public PersonnelCheckoutDailyRollCallViewModel MonthlyRollCall { get; set; }
public double TotalPaymentD { get; set; }
public PersonnelCheckoutDailyRollCallViewModel MonthlyRollCall { get; set; }
public string TotalLateToWorkDeduction { get; set; }
public string TotalLateToWorkDeduction { get; set; }
public string LateToWorkValue { get; set; }
//public bool HasLeft { get; set; }
//public string IsBlockCantracingParty { get; set; }
//public string IsActiveString { get; set; }
//public long WorkingHoursId { get; set; }
//public string ArchiveCode { get; set; }
//public string ConsumableItems { get; set; }
//public string HousingAllowance { get; set; }
//public string YearsPay { get; set; }
public string SettingSalary { get; set; }
public string DailyWage { get; set; }
public WorkshopShiftStatus ShiftStatus { get; set; }
}
public string EmployeePicture { get; set; }
public IrregularShift IrregularShift { get; set; }
public List<CustomizeRotatingShift> CustomizeRotatingShifts { get; set; }
public List<CustomizeSifts> RegularShift { get; set; }
//public bool HasLeft { get; set; }
//public string IsBlockCantracingParty { get; set; }
//public string IsActiveString { get; set; }
//public long WorkingHoursId { get; set; }
//public string ArchiveCode { get; set; }
//public string ConsumableItems { get; set; }
//public string HousingAllowance { get; set; }
//public string YearsPay { get; set; }
}
}

View File

@@ -7,7 +7,8 @@ namespace CompanyManagment.App.Contracts.CustomizeCheckout
{
public interface ICustomizeCheckoutApplication
{
public List<CustomizeCheckoutViewModel> Search(SearchCustomizeCheckout searchModel);
List<CustomizeCheckoutViewModel> Search(SearchCustomizeCheckout searchModel);
OperationResult<List<EligibleEmployeesForCustomizeCheckoutViewModel>>
GetWorkshopEmployeesEligibleForCheckoutInDates(long workshopId, int yearFa, int monthFa);

View File

@@ -4,9 +4,7 @@ public class SearchCustomizeCheckout
{
public long WorkshopId { get; set; }
public int Month { get; set; }
public int Year { get; set; }
@@ -14,6 +12,9 @@ public class SearchCustomizeCheckout
public string SearchEndFa { get; set; }
public long EmployeeId { get; set; }
public long BankId { get; set; }
public CustomizeCheckoutOrderByEnum OrderBy { get; set; } = CustomizeCheckoutOrderByEnum.ContractStartDesc;
public int PageIndex { get; set; }
}

Some files were not shown because too many files have changed in this diff Show More