Compare commits

...

463 Commits

Author SHA1 Message Date
b2cb3ae173 finish employee unauthorized 2025-06-22 15:05:38 +03:30
a6c25ec8e8 complete front but backend still not finished 2025-06-19 13:51:05 +03:30
7b2eefa954 create employee without auth for client p1 - not finished 2025-06-18 15:31:13 +03:30
3303d4b54a Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-06-17 13:47:41 +03:30
dba28b4d89 add move task changer in tester 2025-06-16 21:47:28 +03:30
SamSys
41ec3fb9cf InsuranceDeduction OverTime added for checkout 2025-06-16 17:58:55 +03:30
SamSys
7f98cf8f12 Create checkou bug fixed 2025-06-16 13:22:14 +03:30
SamSys
6c8385061e change 2025-06-15 21:02:26 +03:30
SamSys
a49467ee44 EmployeeComputeOption and Workshop new options merged 2025-06-15 21:02:07 +03:30
e9907650e9 fix - connected personnel on get to show the create and sign options for contract and checkout 2025-06-15 20:05:54 +03:30
SamSys
0e66c5e1a0 SaveRollcall checkout merged 2025-06-15 19:16:44 +03:30
SamSys
27a92f5796 changes 2025-06-15 14:32:48 +03:30
6e5788074c fix goverment list calculation for insurance 2025-06-12 00:27:42 +03:30
831b426f9f initialize options for create and sign in checkout and contract 2025-06-11 21:07:36 +03:30
b29b1335d3 finish saving rollcall to original 2025-06-11 19:00:17 +03:30
SamSys
befcc70d46 Client Sidebar bug fixed 2025-06-11 15:34:40 +03:30
SamSys
f249df5b49 RotatingShiftReport And Compute Changed - StaticWorkongHoures Interference bug fixed 2025-06-10 20:02:50 +03:30
24d41ffc68 add rollcall to checkout 2025-06-10 19:10:33 +03:30
SamSys
c6d4d7d473 add checkoutSaveData in MandatoryCompute 2025-06-09 18:46:46 +03:30
c594cbf523 change checkout application 2025-06-09 17:47:23 +03:30
996adec188 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-06-09 16:52:17 +03:30
6f47948e40 merge from goverment list calculation 2025-06-09 16:52:10 +03:30
SamSys
d135eb73ea Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-06-09 16:45:30 +03:30
SamSys
86143a044c report bug fixed 2025-06-09 16:45:23 +03:30
8a6d4e0af6 add insurance list changes 2025-06-09 16:38:46 +03:30
3b2fd137e4 fix some style bug 2025-06-09 16:37:57 +03:30
52976d8965 add calculation for create checkout 2025-06-09 16:07:22 +03:30
ec97274d5e add checkout rollcall domain to Checkout 2025-06-09 15:07:06 +03:30
c9183fb57e add goverment list calculation 2025-06-09 13:51:31 +03:30
SamSys
c4d21be4aa new inurancelist bug fixed - FiexedSalary changes added 2025-06-08 16:20:30 +03:30
SamSys
e9386708dc Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-06-08 16:17:16 +03:30
SamSys
d70abb60d7 guid for application download link 2025-06-08 16:17:08 +03:30
2098e843a5 fix conflict 2025-06-08 16:10:03 +03:30
f6b6dfa046 merge from team work 2025-06-08 16:04:54 +03:30
36cdde7e6a change insurance govermentlist 2025-06-08 14:32:43 +03:30
SamSys
34358a36c9 change upload apk 2025-06-07 19:21:34 +03:30
SamSys
babecda188 add new permission to InsuranceList 2025-06-07 16:09:50 +03:30
SamSys
98c3e7c821 New-Insurance-Opration Merged 2025-06-05 02:05:24 +03:30
SamSys
5d91b29f2b Create File Bug Fixed 2025-06-03 21:45:20 +03:30
SamSys
c948498307 merged changes 2025-06-03 21:27:14 +03:30
87b0d248a3 Convert checkoutPrintOne to CheckoutPrintAll for best performance 2025-06-03 19:38:18 +03:30
a410d0c216 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-06-03 19:11:52 +03:30
a640f91703 fix leave hours bugs 2025-06-03 19:11:44 +03:30
SamSys
99c8dcb764 add comment to InsuranceList metod 2025-06-03 16:32:12 +03:30
f35aca8e44 add migration 2025-06-02 22:48:59 +03:30
16d45c6dc4 merge from master 2025-06-02 22:21:30 +03:30
45e746b194 merge from team work 2025-06-02 22:20:04 +03:30
SamSys
d44935329f checkoutBug Fixed 2025-06-02 22:06:41 +03:30
SamSys
3a7fc7087b changesAuthHelper 2025-06-02 22:05:21 +03:30
925f43214c fix checkout bug 2025-06-02 22:02:33 +03:30
SamSys
c2fc7dabc1 print bug fixed 2025-06-02 21:38:56 +03:30
SamSys
dec5666eb7 changes 2025-06-02 21:37:27 +03:30
e3b6d5f1c9 fix task schedule bug 2025-06-02 16:37:23 +03:30
7c1fe65cf2 add sync employee status with left work method on rollcall employee upload picture 2025-06-02 16:29:03 +03:30
f26fcba165 add permissions for mahan 2025-06-02 15:41:06 +03:30
SamSys
de2a6203df LeavePayAndAbsence merged 2025-06-02 13:34:10 +03:30
SamSys
2208834a0e refactor LeavePayMetotds 2025-06-02 13:33:21 +03:30
de52a0be98 change thumbnails for list 2025-06-01 19:00:57 +03:30
SamSys
5bebec3fde Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-06-01 17:50:56 +03:30
SamSys
cad808d73c permission change on menu 2025-06-01 17:50:50 +03:30
abef053f56 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-06-01 17:47:37 +03:30
6469bf5a50 fix createEmployee personnel code bug 2025-06-01 17:43:53 +03:30
SamSys
4fd5ef52ef Permission changed 2025-06-01 16:50:27 +03:30
SamSys
61e2bdaaf5 add permission 2025-06-01 16:42:35 +03:30
8ab22d9948 fix admin monthly overview 2025-06-01 16:40:09 +03:30
SamSys
17b5f5fee5 add new Permission 2025-06-01 16:34:31 +03:30
9e7e4ca655 change create condition for contract 2025-06-01 15:56:49 +03:30
SamSys
100c9367ed editRole 2025-06-01 15:30:02 +03:30
fdb6799c65 change modal left work permission 2025-06-01 15:27:48 +03:30
SamSys
c81da3e787 started 2025-05-31 21:05:01 +03:30
SamSys
d8c0471878 Client CameraAccounts new permission added 2025-05-31 17:40:42 +03:30
MahanCh
8418c2edc4 fix sub account bugs 2025-05-31 13:56:02 +03:30
SamSys
e109a41b90 subAccountRole merged 2025-05-31 00:45:26 +03:30
SamSys
158fc91a67 changes 2025-05-31 00:43:50 +03:30
SamSys
d1fb6e933d Merge branch 'Feature/SubAccount/ChangeRole' of https://github.com/syntax24/OriginalGozareshgir into Feature/SubAccount/ChangeRole 2025-05-31 00:34:43 +03:30
SamSys
0811482370 add selected workshops on editRole subAccount 2025-05-31 00:34:36 +03:30
24982e11d3 add tomam 2025-05-30 23:34:08 +03:30
394d65db31 changes 2025-05-30 23:23:53 +03:30
59deae29c2 add workshopIds to role get details 2025-05-30 23:14:38 +03:30
SamSys
46833f93da changes 2025-05-30 19:06:21 +03:30
SamSys
8d78ea548a Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-30 19:06:04 +03:30
SamSys
ffbadc5a96 checkout changes 2025-05-30 19:05:55 +03:30
e889b61d27 test 2025-05-30 18:04:12 +03:30
b492aa39e8 changes 2025-05-30 18:03:47 +03:30
2201ade168 merge from teamwork 2025-05-30 15:45:12 +03:30
SamSys
baeeec183b Color change 2025-05-29 14:55:50 +03:30
SamSys
3142a80b44 completed 2 2025-05-29 05:04:57 +03:30
SamSys
7c2354b386 institutionContract bug 0 fixed add new date coler for expiered 2025-05-29 03:05:52 +03:30
SamSys
175158a3d7 Completed 1 2025-05-29 01:31:28 +03:30
MahanCh
b79abcb175 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-28 16:50:37 +03:30
MahanCh
7388fd8a81 change order by for abcents rollcall workflows 2025-05-28 16:50:27 +03:30
SamSys
a9c489b43d change 2025-05-27 21:33:09 +03:30
SamSys
66ada45d29 change metod 2025-05-27 20:44:25 +03:30
MahanCh
04e51fe3b5 Kebab mahdi VIP group 2025-05-27 20:06:06 +03:30
SamSys
e486f20a5a chekcoutRepository GetContractResultToCreateCheckout changes NOT FINISHED 2025-05-27 19:21:49 +03:30
MahanCh
2db6a9695c add access accounts to search 2025-05-27 18:40:42 +03:30
MahanCh
cea68fce49 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-27 18:06:36 +03:30
MahanCh
3f2c0c5531 fix subAccount Workshop Personnel Count 2025-05-27 18:06:28 +03:30
SamSys
22f13aea0b metode change 2025-05-27 16:18:39 +03:30
0ec62e5e83 change amo logic 2025-05-27 12:47:19 +03:30
SamSys
86a3a21d5b changes 2025-05-26 21:48:09 +03:30
MahanCh
e02bc9adc5 bug Amo Fixed Part 1502 2025-05-26 21:34:21 +03:30
SamSys
39bc95731e front chang amo 2025-05-26 21:28:51 +03:30
SamSys
759792b44b add new permissions to amo 2025-05-26 21:13:50 +03:30
SamSys
1409d30dfd Amo bug fixed 2025-05-26 20:53:56 +03:30
SamSys
ad9f747027 Amo BackEnd Bug fixed And new fron Feature 2025-05-26 17:42:45 +03:30
SamSys
b021636913 add perrmision to AMO on Menu - AdminEmployee Document front Bug Fixed 2025-05-26 17:40:37 +03:30
MahanCh
3007a87104 fix conflict 2025-05-26 17:32:57 +03:30
MahanCh
d7eb8517f7 change sort 2025-05-26 17:32:02 +03:30
MahanCh
eaaab56421 merge from teamwork 2025-05-26 17:30:14 +03:30
SamSys
7d763715cd merge from daylibug 2025-05-25 22:01:09 +03:30
SamSys
7d1eb780a5 amo merged 2025-05-25 21:56:13 +03:30
SamSys
3e1758d35c Optimise AMO Speed 2025-05-25 21:40:07 +03:30
SamSys
88a9a62dd3 Add new View model : CreateCheckoutListViewModel 2025-05-25 21:20:26 +03:30
MahanCh
7bcc052ec6 finish AMO 2025-05-25 21:19:31 +03:30
SamSys
6fd9b336a9 From Master 2025-05-25 19:09:38 +03:30
SamSys
44d5225ff3 Static Chekoout Bug Fixed 2025-05-25 19:08:49 +03:30
SamSys
03e4f7e8c1 metod Extend 2025-05-25 18:29:18 +03:30
MahanCh
2c6512faa2 task create modal changes 2025-05-25 18:17:39 +03:30
MahanCh
406212a1f0 fix task 2025-05-25 18:01:41 +03:30
MahanCh
53e93bd410 cahnge salaryAidOrderBy 2025-05-25 17:40:36 +03:30
SamSys
19f109254d Autoextention except vipGroup kaba mahd 2025-05-25 17:38:57 +03:30
SamSys
9311d68a91 create change 2025-05-25 15:33:42 +03:30
SamSys
9e91214941 Master changes Transfer to Current 2025-05-25 15:33:23 +03:30
SamSys
aded6b2839 statice print view some bugs fixed 2025-05-24 21:35:55 +03:30
SamSys
08d40ae299 Fix print Bugs 2025-05-24 19:03:50 +03:30
SamSys
659f647b31 static print merged 2025-05-24 18:45:39 +03:30
SamSys
0ddcb3653a FirstDayOfMonth 2025-05-24 17:16:02 +03:30
SamSys
3e3eccf0f0 add new metod to rcheckoutRepository 2025-05-24 16:33:02 +03:30
MahanCh
22d7c49379 fix search problem 2025-05-24 13:52:31 +03:30
MahanCh
ca7e46907c fix rollcallMandatory repository bugs 2025-05-24 13:37:34 +03:30
SamSys
ed7e6a3dee InsuranceJobItem Change 2025-05-23 22:55:35 +03:30
SamSys
40482e167a Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-23 22:35:49 +03:30
SamSys
3807b213bb insuranceJobItem last Step completed 2025-05-23 22:35:45 +03:30
2719639333 change CWS for kebab mahdi 2025-05-23 20:30:41 +03:30
SamSys
3aa6c6d1ed InsuranceJobItems change 2025-05-23 16:30:19 +03:30
SamSys
0112772d3f InsuranceJobItems Start End Added - merged 2025-05-23 16:10:32 +03:30
SamSys
7eb8255215 InsuranceJobe Add Start End Completed 2025-05-23 16:07:30 +03:30
SamSys
3650caabfa Camera Icon Task Merged 2025-05-21 21:52:22 +03:30
SamSys
faac2bf707 changes 2025-05-21 21:36:35 +03:30
MahanCh
f04749043e start new insurancelist operations 2025-05-21 18:25:09 +03:30
MahanCh
e8a9a674a1 merge from job Item 2025-05-21 15:54:53 +03:30
MahanCh
d8b6b0f5e8 New Operation InsuranceList Started! 2025-05-21 15:53:05 +03:30
SamSys
3058f95e0e EmployeDocment Upload change size 2025-05-20 22:37:21 +03:30
SamSys
8fa8c33415 ReCalculate Values meged 2025-05-20 22:19:54 +03:30
SamSys
9393993755 Recovery Data Completed 2025-05-20 22:15:06 +03:30
MahanCh
4d81de755e add camera modal for task 2025-05-20 20:38:05 +03:30
MahanCh
f02aa4e217 complete 2025-05-20 20:30:50 +03:30
MahanCh
6cce3f5321 checkout static style changed 2025-05-20 20:00:39 +03:30
MahanCh
59112d9635 add static checkout style 2025-05-20 18:34:30 +03:30
MahanCh
987c1b51fa merge from loan added to checkout 2025-05-20 17:47:34 +03:30
MahanCh
5e186a2352 clear tester 2025-05-20 16:54:48 +03:30
MahanCh
f68739cc22 change the Admin monthly overview by figma - add tester 2025-05-20 16:48:18 +03:30
SamSys
db8bb247b3 Task Merged 2025-05-19 21:05:34 +03:30
SamSys
9cc3bb07f1 Insurance confirm merged 2025-05-19 20:49:25 +03:30
SamSys
4fd71690d5 RotatingShiftReport Merged 2025-05-19 20:43:23 +03:30
SamSys
8078d8bfdd dateSalary create 2025-05-19 20:34:44 +03:30
MahanCh
3b38b80a28 add list pending 2025-05-19 20:32:15 +03:30
MahanCh
0cd8d5b4cf change confirm insurance style 2025-05-19 18:29:36 +03:30
MahanCh
4b23448cc1 change rotating shift report style 2025-05-19 17:55:58 +03:30
MahanCh
aeebb983a4 recalculate values grouping 2025-05-19 17:48:13 +03:30
MahanCh
43c56aa4a1 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-19 17:34:45 +03:30
MahanCh
349c374ca3 fix rollcall recalculate bug 2025-05-19 17:34:37 +03:30
SamSys
c81cafa228 New Permission WorkFlow Admin 2025-05-19 01:23:42 +03:30
SamSys
2fffa67ff6 CopyFromLastYear OnGet 2025-05-18 21:06:18 +03:30
SamSys
c0e438aa6d insurane nane caspian 1403 esfand 2025-05-18 18:57:41 +03:30
MahanCh
acb6764271 add amin monthly review backend 2025-05-18 18:24:23 +03:30
MahanCh
c0f9fb6389 add color to rotating shift 2025-05-18 17:43:34 +03:30
MahanCh
e17ca40df6 Merge branch 'master' into Feature/Checkout/RotatingShiftReport 2025-05-18 17:26:04 +03:30
SamSys
abc8f408a7 add new metods 2025-05-18 16:43:24 +03:30
SamSys
fc43e97cc4 insurance Exeption 2025-05-18 12:10:07 +03:30
SamSys
eeea868c05 Arbaic fixed ToPersian metod 2025-05-17 22:58:32 +03:30
SamSys
b8937ef79c create 2025-05-17 22:56:53 +03:30
SamSys
789b0fbc24 started 2025-05-17 18:18:22 +03:30
MahanCh
65ce181001 add employer insurance confirm print feature 2025-05-17 16:45:31 +03:30
SamSys
140adb2588 Version Added to AutoExtention 2025-05-17 00:31:28 +03:30
SamSys
afb07aa90f AutoExtention-startworkcheck merged 2025-05-17 00:24:03 +03:30
SamSys
ee2adf1c13 DateChange LeftWorkCheck Completed 2025-05-15 17:30:51 +03:30
SamSys
986092135f change temp 2025-05-15 15:02:36 +03:30
SamSys
ab2c1124ca checkout change shift work 2025-05-14 20:42:27 +03:30
SamSys
bc36d8e151 change 2025-05-14 19:57:01 +03:30
SamSys
f7f44b98fb add new ajax metod 2025-05-14 19:31:56 +03:30
SamSys
b8e831ce4d RotatingShiftReport BackEnd Changed 2025-05-14 18:51:36 +03:30
SamSys
8aa8ffe8c8 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-14 18:49:55 +03:30
SamSys
5a8bccb98f checkout complex chang - rotatingShiftReport change - add new Description to contract print 2025-05-14 18:49:44 +03:30
MahanCh
3c73a277ce fix case history bug 2025-05-14 18:36:46 +03:30
MahanCh
56def568b5 fix bugs 2025-05-14 16:26:53 +03:30
MahanCh
f4961a46eb add recalculateVaues 2025-05-14 13:50:18 +03:30
MahanCh
ffa728d05d send missed merge 2025-05-13 22:05:41 +03:30
SamSys
75da32167e Sepration js merged 2025-05-13 21:31:07 +03:30
SamSys
d99e69fa5b Revert "seperate left work and leftwork insurance"
This reverts commit da738054df.
2025-05-13 21:28:05 +03:30
MahanCh
30c70c83b2 recalculte values group 2025-05-13 19:39:19 +03:30
SamSys
d90e01d733 Sepration js Admin\ContractinParty 2025-05-13 19:27:47 +03:30
MahanCh
ec0996f53c Add rotating shift report 2025-05-13 19:21:26 +03:30
MahanCh
5f71cf829b Merge branch 'sepration-js' of https://github.com/syntax24/OriginalGozareshgir into sepration-js 2025-05-13 18:52:57 +03:30
MahanCh
da738054df seperate left work and leftwork insurance 2025-05-13 18:52:26 +03:30
SamSys
521aa9b6ee Sepration js Admin\Contracts All 2025-05-13 18:34:50 +03:30
SamSys
bb2802002a delete some No Useable file in Admin\Contracts 2025-05-13 17:59:27 +03:30
SamSys
2049d8b2eb Sepration Contracts Index js 2025-05-13 17:48:18 +03:30
SamSys
2c6a39bf67 delete craete 5 2025-05-13 17:09:31 +03:30
SamSys
88a0552a07 Sepration js client/Contract/index 2025-05-13 15:39:49 +03:30
SamSys
429b9aad27 changes 2025-05-12 21:20:22 +03:30
SamSys
60052f6cd2 ConvertStatic ckeckout and BreakTime merged to master 2025-05-12 21:16:51 +03:30
SamSys
c7ac3ac7cb BreakTime Merged 2025-05-12 21:14:26 +03:30
SamSys
48f7a7f975 merge from master 2025-05-12 19:42:19 +03:30
SamSys
e0793bc300 convert completed 2025-05-12 19:36:58 +03:30
MahanCh
541f60d6cd finish loan and salaryAid to Checkout 2025-05-12 17:40:46 +03:30
MahanCh
0aebb8c498 merge from master 2025-05-12 17:40:15 +03:30
SamSys
601511ef77 DailyBug Fixed merged 2025-05-12 15:43:51 +03:30
SamSys
020b46f911 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-12 15:41:43 +03:30
SamSys
ac1bb05515 Insuranc IsManager condition set for new props 2025-05-12 15:41:35 +03:30
MahanCh
2a8d2d5581 remove toturial 2025-05-12 15:28:34 +03:30
MahanCh
71c55cd779 fix new employee bug 2025-05-12 15:20:52 +03:30
MahanCh
3c8f212825 CHANGE FIND ROTATING SHIFT FOR TIME DIFFERENCES 2025-05-12 15:12:20 +03:30
SamSys
73feb3dd78 convert static complex shift 2025-05-11 21:13:07 +03:30
SamSys
8d175920d5 Fixed some bugs [rotatingshift cal - subAccountPass] 2025-05-11 19:52:10 +03:30
SamSys
6857ba6bc1 convet 12-24 2025-05-11 19:47:37 +03:30
MahanCh
a9c2f09f9e FIX SubAccountChangePassword 2025-05-11 18:13:39 +03:30
MahanCh
22b722e3dc show the TimeDifferences in Customize Checkout to three number 2025-05-11 17:20:12 +03:30
MahanCh
c168843afc add new find rotating shifts 2025-05-11 17:02:48 +03:30
SamSys
1b7af456b0 change 2025-05-11 16:46:05 +03:30
SamSys
51291d6de7 Merge Edit CustomizeChekout after change salaryAid or .... 2025-05-10 20:49:49 +03:30
SamSys
97ac0e440c Insurance Completed merge 2025-05-10 20:37:38 +03:30
SamSys
586f0a29c2 Insurance New Change Completed 2025-05-10 20:29:08 +03:30
MahanCh
a620872de1 remove leftWork for rejected employeedocument rejected 2025-05-10 19:53:20 +03:30
MahanCh
cebb525968 fix bugs and add tomam for salaryAid calculation date 2025-05-10 19:50:01 +03:30
SamSys
666964609d PrintListWorkshop added sort by ArchiveCode 2025-05-10 17:16:57 +03:30
SamSys
5ef277d604 Insurance changes 2025-05-10 16:59:59 +03:30
MahanCh
802f9a39c5 fix small front bugs for salaryAid and edit checkout 2025-05-10 16:40:42 +03:30
SamSys
8cc26936cd DateSalary - GetDateSalaryViewModel metod bug fixed 2025-05-10 16:33:15 +03:30
SamSys
b0293bf25c DateSalary bug fix [کمک دولت پورعلی ابر 1403] 2025-05-10 16:30:55 +03:30
SamSys
5b97f79fbd JsBugs merged 2025-05-10 15:28:17 +03:30
MahanCh
a9c5c8f8ca fix js bugs 2025-05-10 14:08:18 +03:30
SamSys
9e60c12212 Insurance New Change 2025-05-10 13:06:16 +03:30
SamSys
ff339b9eee ConvertStatic ADD 12-24 2025-05-10 11:55:23 +03:30
SamSys
86c7113987 commented 2025-05-08 17:12:52 +03:30
SamSys
552ee74d56 Merge FindRotatingShift 2025-05-08 16:26:39 +03:30
MahanCh
d1e5adf96f add salaryAid calculation Date and
edit checkout on cahnge salary & ...
2025-05-08 14:08:28 +03:30
MahanCh
fbf367677c Change rollcall rotating shift TimeDifferences 2025-05-08 12:16:26 +03:30
SamSys
612dd99bfe ConvertStaticChekout - shift4 completed 2025-05-07 22:50:42 +03:30
MahanCh
8e8e9ef5de Revert "changes"
This reverts commit 1e18fe1067.
2025-05-07 22:39:25 +03:30
MahanCh
1e18fe1067 changes 2025-05-07 22:39:09 +03:30
SamSys
d1aef862cf merge ModalCamera change Clinet 2025-05-06 21:52:29 +03:30
SamSys
fb2f7ba7c1 ConvertStaticHourse to RollCall - FindStaticShiftsStatus Metod 2025-05-06 21:38:40 +03:30
SamSys
fc18985334 change kabise 365 counter 2025-05-06 20:16:32 +03:30
SamSys
92d36f2966 Front changes 2025-05-06 19:19:52 +03:30
SamSys
0c6a8821ac Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-06 19:18:24 +03:30
SamSys
4b9d39f1e7 InsuranceJob Bug fix 2025-05-06 19:18:18 +03:30
SamSys
5daa36cfb5 start Convert Static compute to rollCall Compute 2025-05-06 19:16:40 +03:30
MahanCh
9e5e7b57c7 fix permissions for employee document workflow 2025-05-06 18:47:22 +03:30
MahanCh
a6984e5f1b fix little bugs 2025-05-06 18:33:15 +03:30
MahanCh
fe8eb5d92b fix cleave js bug 2025-05-06 18:18:20 +03:30
MahanCh
24e661252c add sms report loading 2025-05-06 17:20:20 +03:30
SamSys
e7d5716317 EmployeeDocument Refactor 2025-05-06 15:26:52 +03:30
SamSys
a6be044dbb temporary change sms onget 2025-05-06 15:25:40 +03:30
MahanCh
c91f7e7a90 fix employee Document Style Bug 2025-05-06 15:21:04 +03:30
MahanCh
42de15b3db add try catch for sms 2025-05-06 14:40:10 +03:30
MahanCh
ffcfb4ea3f Merge branch 'Feature/EmployeeDocuments/V2' of https://github.com/syntax24/OriginalGozareshgir into Feature/EmployeeDocuments/V2 2025-05-06 14:16:59 +03:30
MahanCh
a49e2dbb75 complete employeeDocument Query(Tomam) 2025-05-06 14:16:55 +03:30
MahanCh
d8cd33732a fix deleting task schedule 2025-05-05 22:24:07 +03:30
SamSys
5aa714e81d set roleid Permission for employeedocument workflow admin 2025-05-05 22:05:30 +03:30
SamSys
62502fcede add HasCheckout Validation in InsuranceList 2025-05-05 20:30:36 +03:30
MahanCh
6eec454685 employeeDocument Refactor 2025-05-05 18:09:53 +03:30
SamSys
4022a1afd8 Add new Checkbox for Insurance in CreateWorshopp And EditWorkshop 2025-05-05 16:43:35 +03:30
SamSys
86cd776c4d merge from master 2025-05-05 15:18:28 +03:30
MahanCh
13cad28356 add WorkshopSettingsPage in client 2025-05-05 14:03:33 +03:30
SamSys
9cdb922aa1 Employee Validation For MarritalStatus CaseHistory 2025-05-04 21:27:46 +03:30
SamSys
6699909b2f overTimePay static changes 2025-05-04 21:26:01 +03:30
MahanCh
718a7d42b7 fix case history bug 2025-05-04 20:03:04 +03:30
MahanCh
9637b6a581 add employee Validation 2025-05-04 20:00:32 +03:30
SamSys
ec29d3b869 add permission to ScheduleTadk Button 2025-05-04 18:30:42 +03:30
SamSys
4648113a28 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-04 17:30:06 +03:30
SamSys
f4f6fd1bf6 remove Insurance job salarey validation 2025-05-04 17:29:58 +03:30
MahanCh
d9b7245cee Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-05-03 20:52:48 +03:30
MahanCh
85bec9d7fb add validation for cws in edit rotating shifts 2025-05-03 20:52:45 +03:30
SamSys
f93d0b7e89 CustomizeCheckoutMandatoryComputeForKebabMahdi bug fixed 2025-05-03 20:13:19 +03:30
SamSys
f8f7e7d3cf report change 2025-05-03 20:12:05 +03:30
MahanCh
e159738b3d Add group exception for create customzie Checkout 2025-05-03 18:38:06 +03:30
SamSys
ebde36ad8d uid Autorize for create Employee admin Side 2025-05-03 17:48:47 +03:30
SamSys
6f160a85ab rollcallService foreignKey bug fixed 2025-05-03 17:45:54 +03:30
SamSys
ebaef13c4d merge ReCalculate Values 2025-05-03 17:45:09 +03:30
MahanCh
a29e148753 fix edit employee bug in admin 2025-05-03 14:45:13 +03:30
MahanCh
625200bed1 add uid authorize in crearte client 2025-05-01 15:01:36 +03:30
SamSys
4e81b6a2ef WorkFlow EmployeeDocument Fixed Bugs 2025-04-30 20:38:25 +03:30
SamSys
e03aabf88b RotatingShiftReport changes 2025-04-30 20:15:11 +03:30
MahanCh
d1158b95cb fix Employee doc workflow 2025-04-30 19:51:19 +03:30
MahanCh
dbc73509b5 Finish recalculation on change CWES 2025-04-30 17:14:02 +03:30
MahanCh
b6ac3073d3 fix speed workflow employeeDocuments 2025-04-30 16:48:52 +03:30
MahanCh
9592960a40 add recalculate values 2025-04-30 14:55:38 +03:30
SamSys
01f06530c7 add insurance new prop to workshop 2025-04-29 21:33:29 +03:30
SamSys
4ec4935a1d RotatingShiftReport and RotatingShiftCompute Bug Fixed 2025-04-29 20:42:10 +03:30
SamSys
e423df6fbb Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-29 18:39:02 +03:30
SamSys
7bc7cd3422 WebConfig Added - Financia;Statmet create bug Fixed 2025-04-29 18:38:55 +03:30
MahanCh
dec934214d Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-29 18:23:27 +03:30
MahanCh
dd922a72d5 add kestrel limit bodySize 2025-04-29 18:23:19 +03:30
SamSys
76f32c5c38 RotatingShiftRepor completed 2025-04-28 20:58:58 +03:30
SamSys
8f015aa124 DesktopView and MobileView 2025-04-28 20:58:08 +03:30
SamSys
1a8886be50 InsuranceJob Duplication Validation to EconomicCode removed 2025-04-28 19:51:52 +03:30
SamSys
cf6f677816 ExcelGrouping Merge 2025-04-28 19:49:59 +03:30
SamSys
366d42dec9 styling RotatingShiftReport modal 2025-04-28 19:48:54 +03:30
MahanCh
5bce350701 add excel for rollcall grouping 2025-04-28 19:47:12 +03:30
SamSys
d322f2b8db Merge remote-tracking branch 'origin/Fix/RollCall/GroupingValidationLeftWorkBug' 2025-04-28 19:21:21 +03:30
SamSys
cd83ca4379 RotatingShiftReport Modal 2025-04-28 19:20:10 +03:30
MahanCh
edc017b4d4 Left work bug fixed 2025-04-28 19:12:58 +03:30
SamSys
4a0153e1e8 customizeCheckout create bug 2025-04-28 18:50:04 +03:30
SamSys
7f9a2ac597 add partial 2025-04-28 18:48:19 +03:30
SamSys
f9298e1320 toumam changes 2025-04-28 17:00:34 +03:30
SamSys
ce088fc432 save changes tomam 2025-04-28 16:59:35 +03:30
MahanCh
3e02cd711f fix shiftDateBug 2025-04-28 16:23:09 +03:30
MahanCh
64dffd6d25 change condition in customize checkout eligible employees 2025-04-28 13:57:24 +03:30
SamSys
ffdc71401e hasRollCall change 2025-04-27 22:11:39 +03:30
SamSys
21f8a399b4 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-27 21:24:09 +03:30
SamSys
cad2c152e5 .eye z-index 2025-04-27 21:23:56 +03:30
SamSys
247e2f2069 RotatingShitReport - RollCall 2025-04-27 21:22:11 +03:30
MahanCh
cb845afdf6 Merge branch 'master' of https://github.com/syntax24/OriginalGozareshgir 2025-04-27 20:55:10 +03:30
MahanCh
530a263fd8 fix task size validation 2025-04-27 20:54:38 +03:30
SamSys
aba8960b1d Validation for Check Workflow aboat LeftworkTemp 2025-04-27 15:36:08 +03:30
MahanCh
e2ba7d9450 add validation to onget 2025-04-27 14:20:16 +03:30
SamSys
a316b2a5f1 Duplicate LeftWorkTemp Bug Fixed 2025-04-26 22:36:31 +03:30
SamSys
4b045440c4 sepration js : EditTransaction - Extention - DinancialStatment - Index 2025-04-26 22:33:17 +03:30
10c35f6f10 add validation and change the list of employees 2025-04-26 20:44:24 +03:30
SamSys
af30c7f088 Edit Sepration js 2025-04-26 17:57:45 +03:30
SamSys
d95ca28cd4 seprate Create js 2025-04-26 17:13:08 +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
MahanCh
dbb0b2e53a fix total deduction and total payment problem 2025-04-23 19:00:08 +03:30
MahanCh
7f900755be add loan and salaryAid to checkout 2025-04-23 17:06:12 +03:30
SamSys
dc39f30c21 checkout Stored Procedure changed 2025-04-23 16:15:14 +03:30
MahanCh
8dd9ee508a add salary and loan checkout 2025-04-23 15:34:01 +03:30
MahanCh
9f42af6a23 add calculation date to customize checkouts salaryAid 2025-04-23 14:51:30 +03:30
MahanCh
4449195aed add calculationdate to salaryAid 2025-04-23 14:22:39 +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
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
1449e83a0f fix bug! 2025-03-30 18:28:39 +03:30
1094 changed files with 471495 additions and 90779 deletions

View File

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

View File

@@ -150,7 +150,13 @@ public class AuthHelper : IAuthHelper
{ {
#region MahanChanges #region MahanChanges
if (account.Id == 322)
account.Permissions.AddRange([3060301, 30603, 30604, 30605]);
var permissions = account.Permissions is { Count: > 0 } ? Tools.SerializeToBson(account.Permissions) : ""; var permissions = account.Permissions is { Count: > 0 } ? Tools.SerializeToBson(account.Permissions) : "";
var workshopBson = account.WorkshopList is { Count: > 0 } ? Tools.SerializeToBson(account.WorkshopList) : ""; var workshopBson = account.WorkshopList is { Count: > 0 } ? Tools.SerializeToBson(account.WorkshopList) : "";
var slug = account.WorkshopSlug ?? ""; var slug = account.WorkshopSlug ?? "";
@@ -245,21 +251,24 @@ public class AuthHelper : IAuthHelper
#region Pooya #region Pooya
public (long Id, UserType userType) GetUserTypeWithId() public (long Id, UserType userType, long roleId) GetUserTypeWithId()
{ {
if (!IsAuthenticated()) if (!IsAuthenticated())
return (0, UserType.Anonymous); return (0, UserType.Anonymous, 0);
var claims = _contextAccessor.HttpContext.User.Claims.ToList(); var claims = _contextAccessor.HttpContext.User.Claims.ToList();
var subAccountId = long.Parse(claims.FirstOrDefault(x => x.Type == "SubAccountId")?.Value ?? "0"); var subAccountId = long.Parse(claims.FirstOrDefault(x => x.Type == "SubAccountId")?.Value ?? "0");
if (subAccountId > 0) if (subAccountId > 0)
return (subAccountId, UserType.SubAccount); return (subAccountId, UserType.SubAccount, 0);
var id = long.Parse(_contextAccessor.HttpContext.User.Claims.First(x => x.Type == "AccountId")?.Value); var id = long.Parse(_contextAccessor.HttpContext.User.Claims.First(x => x.Type == "AccountId")?.Value);
if (claims.FirstOrDefault(x => x.Type == "AdminAreaPermission")?.Value == "true") if (claims.FirstOrDefault(x => x.Type == "AdminAreaPermission")?.Value == "true")
return (id, UserType.Admin); {
var roleId = long.Parse(claims.FirstOrDefault(x => x.Type == ClaimTypes.Role)?.Value ?? "0");
return (id, UserType.Admin, roleId);
}
return (id, UserType.Client); return (id, UserType.Client, 0);
} }
#endregion #endregion

View File

@@ -23,5 +23,5 @@ public interface IAuthHelper
long CurrentSubAccountId(); long CurrentSubAccountId();
string GetWorkshopSlug(); string GetWorkshopSlug();
string GetWorkshopName(); string GetWorkshopName();
(long Id, UserType userType) GetUserTypeWithId(); (long Id, UserType userType, long roleId) GetUserTypeWithId();
} }

View File

@@ -4,5 +4,5 @@ public enum IsActive
{ {
False, False,
True, True,
None
} }

View File

@@ -51,4 +51,11 @@ public class OperationResult<T>
Message = message; Message = message;
return this; return this;
} }
public OperationResult<T> Failed(string message, T data)
{
IsSuccedded = false;
Message = message;
Data = data;
return this;
}
} }

View File

@@ -9,10 +9,24 @@ public interface ISmsService
void Send(string number, string message); void Send(string number, string message);
bool VerifySend(string number, string message); bool VerifySend(string number, string message);
bool LoginSend(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); bool SendAccountsInfo(string number,string fullName, string userName);
Task<ApiResultViewModel> GetByMessageId(int messId); Task<ApiResultViewModel> GetByMessageId(int messId);
Task<List<ApiResultViewModel>> GetApiResult(string startDate, string endDate); Task<List<ApiResultViewModel>> GetApiResult(string startDate, string endDate);
string DeliveryStatus(byte? dv); string DeliveryStatus(byte? dv);
string DeliveryColorStatus(byte? dv); string DeliveryColorStatus(byte? dv);
string UnixTimeStampToDateTime(int? unixTimeStamp); 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.Requests;
using IPE.SmsIrClient.Models.Results; using IPE.SmsIrClient.Models.Results;
using Microsoft.Extensions.Configuration; using Microsoft.Extensions.Configuration;
using static System.Runtime.InteropServices.JavaScript.JSType;
namespace _0_Framework.Application.Sms; namespace _0_Framework.Application.Sms;
@@ -16,10 +17,14 @@ namespace _0_Framework.Application.Sms;
public class SmsService : ISmsService public class SmsService : ISmsService
{ {
private readonly IConfiguration _configuration; private readonly IConfiguration _configuration;
public SmsIr SmsIr { get; set; }
public SmsService(IConfiguration configuration) public SmsService(IConfiguration configuration)
{ {
_configuration = configuration; _configuration = configuration;
SmsIr = new SmsIr("Og5M562igmzJRhQPnq0GdtieYdLgtfikjzxOmeQBPxJjZtyge5Klc046Lfw1mxSa");
} }
public void Send(string number, string message) 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) public bool SendAccountsInfo(string number, string fullName, string userName)
{ {
@@ -285,4 +315,23 @@ public class SmsService : ISmsService
//var tokenService = new Token(); //var tokenService = new Token();
//return tokenService.GetToken("x-api-key", "Og5M562igmzJRhQPnq0GdtieYdLgtfikjzxOmeQBPxJjZtyge5Klc046Lfw1mxSa"); //return tokenService.GetToken("x-api-key", "Og5M562igmzJRhQPnq0GdtieYdLgtfikjzxOmeQBPxJjZtyge5Klc046Lfw1mxSa");
} }
#region Mahan
public async Task<double> GetCreditAmount()
{
try
{
var credit = await SmsIr.GetCreditAsync();
return (double)credit.Data;
}
catch
{
return -1;
}
}
#endregion
} }

View File

@@ -14,14 +14,24 @@ public static class StaticWorkshopAccounts
/// </summary> /// </summary>
public static List<long> SelectedAccountsRoleIds = [3, 5, 7, 8]; public static List<long> SelectedAccountsRoleIds = [3, 5, 7, 8];
/// <summary>
/// لیستی آی دی نقش هایی که دردسترسی به تب افزودن پرسنل و مدارک کلاینت دارند
/// 3 : قرارداد ارشد
/// 5 : قرارداد ساده
/// 19 : برنامه نویسان
/// 1 : مدیر سیستم
/// </summary>
public static List<long> EmployeeDocumentWorkFlowRoleIds = [1,3, 5, 19];
/// <summary> /// <summary>
/// لیست اکانتهایی که به همه کارگاه ها باید دسترسی داشته باشند /// لیست اکانتهایی که به همه کارگاه ها باید دسترسی داشته باشند
/// 2 - صادق فرخی /// 2 - صادق فرخی
/// 3 - میلاد مصباح /// 3 - میلاد مصباح
/// 380 - افروز نظری /// 380 - افروز نظری
/// 381 - مهدی قربانی /// 381 - مهدی قربانی
/// 392 - عمار حسن دوست
/// </summary> /// </summary>
public static List<long> StaticAccountIds = [2, 3, 380, 381]; public static List<long> StaticAccountIds = [2, 3, 380, 381, 392];
/// <summary> /// <summary>
/// این تاریخ در جدول اکانت لفت ورک به این معنیست /// این تاریخ در جدول اکانت لفت ورک به این معنیست

View File

@@ -385,11 +385,27 @@
/// </summary> /// </summary>
public const int SetWorkshopWorkingHoursPermissionCode = 10606; public const int SetWorkshopWorkingHoursPermissionCode = 10606;
#region حساب کاربری دوربین
/// <summary> /// <summary>
/// تنظیمات حساب کاربری دوربین /// تنظیمات حساب کاربری دوربین
/// </summary> /// </summary>
public const int CameraAccountSettingsPermissionCode = 10607; public const int CameraAccountSettingsPermissionCode = 10607;
/// <summary>
/// فعال/غیرفعال اکانت دوربین
/// </summary>
public const int CameraAccountActivationBtnPermissionCode = 1060701;
/// <summary>
/// ویرایش اکانت دوربین
/// </summary>
public const int CameraAccountEditPermissionCode = 1060702;
#endregion
#endregion #endregion
#region کارپوشه #region کارپوشه
@@ -744,6 +760,22 @@
Code = CameraAccountSettingsPermissionCode, Code = CameraAccountSettingsPermissionCode,
ParentId = RollCallOperationsPermissionCode ParentId = RollCallOperationsPermissionCode
}; };
public static SubAccountPermissionDto CameraAccountActivationBtn { get; } = new()
{
Id = CameraAccountActivationBtnPermissionCode,
Name = "فعال/غیرفعال حساب کاربری دوربین",
Code = CameraAccountActivationBtnPermissionCode,
ParentId = CameraAccountSettingsPermissionCode
};
public static SubAccountPermissionDto CameraAccountEdit { get; } = new()
{
Id = CameraAccountEditPermissionCode,
Name = "ویراش حساب کاربری دوربین",
Code = CameraAccountEditPermissionCode,
ParentId = CameraAccountSettingsPermissionCode
};
#endregion #endregion
#region کارپوشه,ParentId = WorkFlowOperationsPermissionCode #region کارپوشه,ParentId = WorkFlowOperationsPermissionCode

View File

@@ -397,9 +397,9 @@ public static class Tools
public static DateTime ToGeorgianDateTime(this string persianDate) public static DateTime ToGeorgianDateTime(this string persianDate)
{ {
persianDate = persianDate.ToEnglishNumber();
try try
{ {
persianDate = persianDate.ToEnglishNumber();
var year = Convert.ToInt32(persianDate.Substring(0, 4)); var year = Convert.ToInt32(persianDate.Substring(0, 4));
var month = Convert.ToInt32(persianDate.Substring(5, 2)); var month = Convert.ToInt32(persianDate.Substring(5, 2));
var day = Convert.ToInt32(persianDate.Substring(8, 2)); var day = Convert.ToInt32(persianDate.Substring(8, 2));
@@ -458,25 +458,30 @@ public static class Tools
public static double MoneyToDouble(this string myMoney) public static double MoneyToDouble(this string myMoney)
{ {
string bb = string.Empty; string bb = string.Empty;
bool isNegative = false;
for (int x = 0; x < myMoney.Length; x++) for (int x = 0; x < myMoney.Length; x++)
{ {
if (char.IsDigit(myMoney[x])) if (char.IsDigit(myMoney[x]))
{
bb += myMoney[x]; bb += myMoney[x];
} }
else if (myMoney[x] == '-' && bb.Length == 0)
{
// اگر علامت منفی قبل از اولین عدد آمد، در نظر بگیر
isNegative = true;
}
}
if (bb.Length > 0) if (bb.Length > 0)
{ {
double res = double.Parse(bb); double res = double.Parse(bb);
return res; return isNegative ? -res : res;
} }
else else
{ {
return 0; return 0;
} }
} }
public static string ToFileName(this DateTime date) public static string ToFileName(this DateTime date)
{ {
@@ -598,90 +603,90 @@ public static class Tools
/// <returns></returns> /// <returns></returns>
public static int YearTotalDays(this string date) public static int YearTotalDays(this string date)
{ {
int y2 = 365; int y2 = 366;
var year = Convert.ToInt32(date.Substring(0, 4)); var year = Convert.ToInt32(date.Substring(0, 4));
switch (year) switch (year)
{ {
case 1346: case 1346:
y2 = 366; y2 = 367;
break; break;
case 1350: case 1350:
y2 = 366; y2 = 367;
break; break;
case 1354: case 1354:
y2 = 366; y2 = 367;
break; break;
case 1358: case 1358:
y2 = 366; y2 = 367;
break; break;
case 1362: case 1362:
y2 = 366; y2 = 367;
break; break;
case 1366: case 1366:
y2 = 366; y2 = 367;
break; break;
case 1370: case 1370:
y2 = 366; y2 = 367;
break; break;
case 1375: case 1375:
y2 = 366; y2 = 367;
break; break;
case 1379: case 1379:
y2 = 366; y2 = 367;
break; break;
case 1383: case 1383:
y2 = 366; y2 = 367;
break; break;
case 1387: case 1387:
y2 = 366; y2 = 367;
break; break;
case 1391: case 1391:
y2 = 366; y2 = 367;
break; break;
case 1395: case 1395:
y2 = 366; y2 = 367;
break; break;
case 1399: case 1399:
y2 = 366; y2 = 367;
break; break;
case 1403: case 1403:
y2 = 366; y2 = 367;
break; break;
case 1408: case 1408:
y2 = 366; y2 = 367;
break; break;
case 1412: case 1412:
y2 = 366; y2 = 367;
break; break;
case 1416: case 1416:
y2 = 366; y2 = 367;
break; break;
case 1420: case 1420:
y2 = 366; y2 = 367;
break; break;
case 1424: case 1424:
y2 = 366; y2 = 367;
break; break;
case 1428: case 1428:
y2 = 366; y2 = 367;
break; break;
case 1432: case 1432:
y2 = 366; y2 = 367;
break; break;
case 1436: case 1436:
y2 = 366; y2 = 367;
break; break;
case 1441: case 1441:
y2 = 366; y2 = 367;
break; break;
case 1445: case 1445:
y2 = 366; y2 = 367;
break; break;
default: default:
y2 = 365; y2 = 366;
break; break;
} }
@@ -884,30 +889,39 @@ public static class Tools
string result = ""; string result = "";
switch (value) switch (value)
{ {
case "1":
case "01": case "01":
result = "فروردین"; result = "فروردین";
break; break;
case "2":
case "02": case "02":
result = "اردیبهشت"; result = "اردیبهشت";
break; break;
case "3":
case "03": case "03":
result = "خرداد"; result = "خرداد";
break; break;
case "4":
case "04": case "04":
result = "تیر"; result = "تیر";
break; break;
case "5":
case "05": case "05":
result = "مرداد"; result = "مرداد";
break; break;
case "6":
case "06": case "06":
result = "شهریور"; result = "شهریور";
break; break;
case "7":
case "07": case "07":
result = "مهر"; result = "مهر";
break; break;
case "8":
case "08": case "08":
result = "آبان"; result = "آبان";
break; break;
case "9":
case "09": case "09":
result = "آذر"; result = "آذر";
break; break;
@@ -1382,6 +1396,73 @@ public static class Tools
return false; return false;
return true; return true;
} }
/// <summary>
/// چک میکند که در دو شیفت استاتیک تداخل زمانی وجود دارد یا خیر
/// چک میکند که آیا ساعات وارد شده ولید هستند یا خیر
/// </summary>
/// <param name="start1"></param>
/// <param name="end1"></param>
/// <param name="start2"></param>
/// <param name="end2"></param>
/// <returns></returns>
public static bool InterferenceTime(string start1, string end1, string start2, string end2)
{
if (!CheckValidHm(start1))
return true;
if (!CheckValidHm(end1))
return true;
if (!CheckValidHm(start2))
return true;
if (!CheckValidHm(end2))
return true;
//اگه دو شیفت نبود
if (string.IsNullOrWhiteSpace(start1) || string.IsNullOrWhiteSpace(start2))
return false;
try
{
var start1Gr = Convert.ToDateTime(start1);
var end1Gr = Convert.ToDateTime(end1);
if (end1Gr < start1Gr)
end1Gr = end1Gr.AddDays(1);
var start2Gr = Convert.ToDateTime(start2);
var end2Gr = Convert.ToDateTime(end2);
start2Gr = new DateTime(end1Gr.Year, end1Gr.Month, end1Gr.Day, start2Gr.Hour, start2Gr.Minute,
start2Gr.Second);
end2Gr = new DateTime(end1Gr.Year, end1Gr.Month, end1Gr.Day, end2Gr.Hour, end2Gr.Minute,
end2Gr.Second);
if (end2Gr < start2Gr)
end2Gr = end2Gr.AddDays(1);
var diff = (end1Gr - start1Gr).Add((end2Gr - start2Gr));
if (diff > new TimeSpan(24,0,0))
return true;
if (start2Gr <= end1Gr)
return true;
return false;
}
catch (Exception)
{
return true;
}
}
public static DateTime FindFirstDayOfMonthGr(this DateTime date) public static DateTime FindFirstDayOfMonthGr(this DateTime date)
{ {
var pc = new PersianCalendar(); var pc = new PersianCalendar();
@@ -1403,6 +1484,8 @@ public static class Tools
if (@char == char.Parse("ي")) if (@char == char.Parse("ي"))
res += "ی"; res += "ی";
else if (@char == char.Parse("ك"))
res += "ک";
else else
res += @char; res += @char;
} }
@@ -1680,6 +1763,10 @@ public static class Tools
} }
#endregion #endregion
#region Pooya #region Pooya
@@ -1873,5 +1960,44 @@ public static class Tools
return true; 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 #endregion
} }

View File

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

View File

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

View File

@@ -0,0 +1,9 @@
namespace AccountManagement.Application.Contracts.Account;
public class AccountSelectListViewModel
{
public long Id { get; set; }
public string Name { get; set; }
public long RoleId { get; set; }
}

View File

@@ -41,6 +41,8 @@ public interface IAccountApplication
List<AccountViewModel> GetAccountsByPositionId(long positionId); List<AccountViewModel> GetAccountsByPositionId(long positionId);
List<AccountViewModel> GetAccountEqualToLowerPositionValue(); List<AccountViewModel> GetAccountEqualToLowerPositionValue();
Task<List<AccountSelectListViewModel>> GetAdminSelectList();
OperationResult ReLogin(); OperationResult ReLogin();
#endregion #endregion
@@ -55,4 +57,11 @@ public interface IAccountApplication
#endregion #endregion
OperationResult DirectCameraLogin(long cameraAccountId); OperationResult DirectCameraLogin(long cameraAccountId);
/// <summary>
/// چک میکند که آیا اکانتی با این نام کاربری وجود دارد یا نه
/// </summary>
/// <param name="userName"></param>
/// <returns></returns>
public bool CheckExistClientAccount(string userName);
} }

View File

@@ -7,7 +7,8 @@ namespace AccountManagement.Application.Contracts.Media
public interface IMediaApplication public interface IMediaApplication
{ {
MediaViewModel Get(long id); MediaViewModel Get(long id);
OperationResult UploadFile(IFormFile file, string fileLabel, string relativePath, int maximumFileLength, List<string> allowedExtensions); OperationResult UploadFile(IFormFile file, string fileLabel, string relativePath, int maximumFileLength,
List<string> allowedExtensions, string category);
OperationResult MoveFile(long mediaId, string newRelativePath); OperationResult MoveFile(long mediaId, string newRelativePath);
OperationResult DeleteFile(long mediaId); OperationResult DeleteFile(long mediaId);
List<MediaViewModel> GetRange(IEnumerable<long> select); List<MediaViewModel> GetRange(IEnumerable<long> select);

View File

@@ -15,6 +15,6 @@ namespace AccountManagement.Application.Contracts.SubAccount
public string PhoneNumber { get; set; } public string PhoneNumber { get; set; }
public string Username { get; set; } public string Username { get; set; }
public string ProfilePhoto { get; set; } public string ProfilePhoto { get; set; }
public List<long> WorkshopIds { get; set; } //public List<long> WorkshopIds { get; set; }
} }
} }

View File

@@ -8,5 +8,6 @@ namespace AccountManagement.Application.Contracts.SubAccount
public string Title { get; set; } public string Title { get; set; }
public long AccountId { get; set; } public long AccountId { get; set; }
public List<int> Permissions { get; set; } public List<int> Permissions { get; set; }
public List<long> WorkshopIds { get; set; }
} }
} }

View File

@@ -13,7 +13,7 @@ namespace AccountManagement.Application.Contracts.SubAccount
public string PhoneNumber { get; set; } public string PhoneNumber { get; set; }
public string RePassword { get; set; } public string RePassword { get; set; }
public long SubAccountRoleId { get; set; } public long SubAccountRoleId { get; set; }
public List<long> WorkshopIds { get; set; } //public List<long> WorkshopIds { get; set; }
} }

View File

@@ -7,5 +7,6 @@ namespace AccountManagement.Application.Contracts.SubAccount
public long Id { get; set; } public long Id { get; set; }
public string Title { get; set; } public string Title { get; set; }
public List<int> Permissions { get; set; } public List<int> Permissions { get; set; }
public List<long> WorkshopIds { get; set; }
} }
} }

View File

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

View File

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

View File

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

View File

@@ -48,7 +48,10 @@ public class TaskViewModel
public bool CanDelete { get; set; } public bool CanDelete { get; set; }
public bool CanAssign { get; set; } public bool CanAssign { get; set; }
public bool CanCheckRequests { get; set; } public bool CanCheckRequests { get; set; }
public bool HasRequest { get; set; }
public AssignViewModel AssignedReceiverViewModel { 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; using AccountManagement.Application.Contracts.Task;
namespace AccountManagement.Application.Contracts.TaskSchedule; namespace AccountManagement.Application.Contracts.TaskSchedule;
@@ -6,7 +8,8 @@ namespace AccountManagement.Application.Contracts.TaskSchedule;
public interface ITaskScheduleApplication public interface ITaskScheduleApplication
{ {
OperationResult Create(CreateTask command); 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,22 @@
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 string Count { get; set; }
public string FirstEndTaskDate { get; set; }
public List<MediaViewModel> Medias { get; set; }
}

View File

@@ -308,7 +308,7 @@ public class AccountApplication : IAccountApplication
{ {
Slug = _passwordHasher.SlugHasher(x.WorkshopId), Slug = _passwordHasher.SlugHasher(x.WorkshopId),
Name = x.WorkshopName, Name = x.WorkshopName,
PersonnelCount = 0, PersonnelCount = x.PersonnelCount,
Id = x.WorkshopId Id = x.WorkshopId
}).ToList(); }).ToList();
@@ -549,6 +549,7 @@ public class AccountApplication : IAccountApplication
return operation.Succcedded(2); return operation.Succcedded(2);
} }
public AccountLeftWorkViewModel WorkshopList(long accountId) public AccountLeftWorkViewModel WorkshopList(long accountId)
{ {
string fullname = this._accountRepository.GetById(accountId).Fullname; string fullname = this._accountRepository.GetById(accountId).Fullname;
@@ -626,7 +627,10 @@ public class AccountApplication : IAccountApplication
} }
public async Task<List<AccountSelectListViewModel>> GetAdminSelectList()
{
return await _accountRepository.GetAdminSelectList();
}
#endregion #endregion
#region Pooya #region Pooya
@@ -785,4 +789,10 @@ public class AccountApplication : IAccountApplication
//} //}
#endregion #endregion
public bool CheckExistClientAccount(string userName)
{
return _accountRepository.CheckExistClientAccount(userName);
}
} }

View File

@@ -28,48 +28,14 @@ namespace AccountManagement.Application
/// <param name="file">فایل</param> /// <param name="file">فایل</param>
/// <param name="fileLabel">برچسب فایل که در نام فایل ظاهر می شود</param> /// <param name="fileLabel">برچسب فایل که در نام فایل ظاهر می شود</param>
/// <param name="relativePath">مسیر فایل</param> /// <param name="relativePath">مسیر فایل</param>
/// <param name="allowedExtensions">[.png,.jpg,.jpeg] پسوند های مجاز مثلا </param>
/// <param name="maximumFileLength">حداکثر حجم فایل به مگابایت</param> /// <param name="maximumFileLength">حداکثر حجم فایل به مگابایت</param>
/// <param name="allowedExtensions">[.png,.jpg,.jpeg] پسوند های مجاز مثلا </param>
/// <param name="category"></param>
/// <returns></returns> /// <returns></returns>
public OperationResult UploadFile(IFormFile file, string fileLabel, string relativePath,int maximumFileLength,List<string> allowedExtensions) public OperationResult UploadFile(IFormFile file, string fileLabel, string relativePath, int maximumFileLength,
List<string> allowedExtensions, string category)
{ {
OperationResult op = new(); return _mediaRepository.UploadFile(file, fileLabel, relativePath, maximumFileLength, allowedExtensions, category);
var path = Path.Combine(_basePath, relativePath);
var fileExtension = Path.GetExtension(file.FileName);
if (file == null || file.Length == 0)
return op.Failed("خطای سیستمی");
if (file.Length > (maximumFileLength * 1024 * 1024))
return op.Failed($"حجم فایل نمی تواند بیشتر از " +
$"{maximumFileLength}" +
$"مگابایت باشد");
if (!allowedExtensions.Contains(fileExtension.ToLower()))
{
var operationMessage = ":فرمت فایل باید یکی از موارد زیر باشد";
operationMessage += "\n";
operationMessage += string.Join(" ", allowedExtensions);
return op.Failed(operationMessage);
}
Directory.CreateDirectory(path);
var extension = Path.GetExtension(file.FileName);
var uniqueFileName = $"{fileLabel}-{DateTime.Now.Ticks}{extension}";
var filePath = Path.Combine(path, uniqueFileName);
using (var fileStream = new FileStream(filePath, FileMode.CreateNew))
{
file.CopyTo(fileStream);
}
var mediaEntity = new Media(filePath, extension, "فایل", "EmployeeDocuments");
_mediaRepository.Create(mediaEntity);
_mediaRepository.SaveChanges();
return op.Succcedded(mediaEntity.id);
} }

View File

@@ -113,12 +113,12 @@ namespace AccountManagement.Application
if (cmd.PhoneNumber.Length != 11) if (cmd.PhoneNumber.Length != 11)
return op.Failed("شماره تلفن همراه نامعتبر است"); return op.Failed("شماره تلفن همراه نامعتبر است");
if (!cmd.WorkshopIds.Any()) //if (!cmd.WorkshopIds.Any())
return op.Failed("حداقل یک کارگاه را انتخاب کنید"); // return op.Failed("حداقل یک کارگاه را انتخاب کنید");
if (!cmd.WorkshopIds.All(x => accountWorkshopsList.Contains(x))) //if (!cmd.WorkshopIds.All(x => accountWorkshopsList.Contains(x)))
return op.Failed("خطای سیستمی"); // return op.Failed("خطای سیستمی");
if (cmd.SubAccountRoleId == 0 || !_subAccountRoleRepository.Exists(x => cmd.SubAccountRoleId == x.id)) if (cmd.SubAccountRoleId == 0 || !_subAccountRoleRepository.Exists(x => cmd.SubAccountRoleId == x.id))
@@ -131,6 +131,10 @@ namespace AccountManagement.Application
_cameraAccountRepository.Exists(x => x.Username == cmd.Username)) _cameraAccountRepository.Exists(x => x.Username == cmd.Username))
return op.Failed("نام کاربری نمی تواند تکراری باشد"); return op.Failed("نام کاربری نمی تواند تکراری باشد");
var role = _subAccountRoleRepository.Get(cmd.SubAccountRoleId);
var workshopId = role.RoleWorkshops.Select(x => x.WorkshopId).ToList();
var entity = new SubAccount(cmd.AccountId, cmd.SubAccountRoleId, cmd.NationalCode, cmd.FName, cmd.LName, cmd.PhoneNumber, cmd.Username, _passwordHasher.Hash(cmd.Password), var entity = new SubAccount(cmd.AccountId, cmd.SubAccountRoleId, cmd.NationalCode, cmd.FName, cmd.LName, cmd.PhoneNumber, cmd.Username, _passwordHasher.Hash(cmd.Password),
cmd.ProfilePhoto); cmd.ProfilePhoto);
@@ -142,7 +146,7 @@ namespace AccountManagement.Application
_subAccountRepository.SaveChanges(); _subAccountRepository.SaveChanges();
var workshops = cmd.WorkshopIds.Select(x => new WorkshopSubAccount(x, entity.id)); var workshops = workshopId.Select(x => new WorkshopSubAccount(x, entity.id));
foreach (var w in workshops) foreach (var w in workshops)
_workshopSubAccountRepository.Create(w); _workshopSubAccountRepository.Create(w);
@@ -175,22 +179,22 @@ namespace AccountManagement.Application
if (!cmd.WorkshopIds.All(x => accountWorkshopsList.Contains(x))) //if (!cmd.WorkshopIds.All(x => accountWorkshopsList.Contains(x)))
return op.Failed("خطای سیستمی"); // return op.Failed("خطای سیستمی");
if (cmd.SubAccountRoleId == 0 || !_subAccountRoleRepository.Exists(x => cmd.SubAccountRoleId == x.id)) if (cmd.SubAccountRoleId == 0 || !_subAccountRoleRepository.Exists(x => cmd.SubAccountRoleId == x.id))
return op.Failed("نقش مورد نظر وجود ندارد"); return op.Failed("نقش مورد نظر وجود ندارد");
var workshopSubAccounts = _workshopSubAccountRepository.GetWorkshopsSubAccountEntityBySubAccountId(entity.id); //var workshopSubAccounts = _workshopSubAccountRepository.GetWorkshopsSubAccountEntityBySubAccountId(entity.id);
foreach (var workshopSubAccount in workshopSubAccounts) //foreach (var workshopSubAccount in workshopSubAccounts)
_workshopSubAccountRepository.Remove(workshopSubAccount); // _workshopSubAccountRepository.Remove(workshopSubAccount);
var workshops = cmd.WorkshopIds.Select(x => new WorkshopSubAccount(x, entity.id)); //var workshops = cmd.WorkshopIds.Select(x => new WorkshopSubAccount(x, entity.id));
foreach (var w in workshops) //foreach (var w in workshops)
_workshopSubAccountRepository.Create(w); // _workshopSubAccountRepository.Create(w);
entity.Edit(cmd.SubAccountRoleId, cmd.NationalCode, cmd.FName, cmd.LName, cmd.ProfilePhoto); entity.Edit(cmd.SubAccountRoleId, cmd.NationalCode, cmd.FName, cmd.LName, cmd.ProfilePhoto);
_workshopSubAccountRepository.SaveChanges(); _workshopSubAccountRepository.SaveChanges();
@@ -227,7 +231,8 @@ namespace AccountManagement.Application
{ {
Id = entity.id, Id = entity.id,
Title = entity.Title, Title = entity.Title,
Permissions = entity.RolePermissions.Select(x => x.PermissionCode).ToList() Permissions = entity.RolePermissions.Select(x => x.PermissionCode).ToList(),
WorkshopIds = entity.RoleWorkshops.Select(x=>x.WorkshopId).ToList()
}; };
} }
@@ -241,7 +246,7 @@ namespace AccountManagement.Application
OperationResult op = new(); OperationResult op = new();
if (_subAccountRoleRepository.Exists(x => x.AccountId == command.AccountId && x.Title.Trim() == command.Title.Trim())) if (_subAccountRoleRepository.Exists(x => x.AccountId == command.AccountId && x.Title.Trim() == command.Title.Trim()))
return op.Failed("یک نقش با این عنوان وجود دارد"); return op.Failed("یک نقش با این عنوان وجود دارد");
var role = new SubAccountRole(command.Title, command.Permissions, command.AccountId); var role = new SubAccountRole(command.Title, command.Permissions, command.AccountId,command.WorkshopIds);
_subAccountRoleRepository.Create(role); _subAccountRoleRepository.Create(role);
_subAccountRoleRepository.SaveChanges(); _subAccountRoleRepository.SaveChanges();
return op.Succcedded(role.id); return op.Succcedded(role.id);
@@ -254,8 +259,26 @@ namespace AccountManagement.Application
var entity = _subAccountRoleRepository.Get(cmd.Id); var entity = _subAccountRoleRepository.Get(cmd.Id);
if (entity == null) if (entity == null)
return op.Failed(ApplicationMessages.RecordNotFound); return op.Failed(ApplicationMessages.RecordNotFound);
entity.Edit(cmd.Title, cmd.Permissions); entity.Edit(cmd.Title, cmd.Permissions,cmd.WorkshopIds);
var subAccountRoles = _subAccountRepository.GetBySubAccountRole(cmd.Id);
foreach (var subAccount in subAccountRoles)
{
var workshopSubAccounts = _workshopSubAccountRepository.GetWorkshopsSubAccountEntityBySubAccountId(subAccount.id);
foreach (var workshopSubAccount in workshopSubAccounts)
_workshopSubAccountRepository.Remove(workshopSubAccount);
var workshops = cmd.WorkshopIds.Select(x => new WorkshopSubAccount(x, subAccount.id));
foreach (var w in workshops)
_workshopSubAccountRepository.Create(w);
}
_subAccountRoleRepository.SaveChanges(); _subAccountRoleRepository.SaveChanges();
_workshopSubAccountRepository.SaveChanges();
return op.Succcedded(); return op.Succcedded();
} }
public OperationResult AssignRoleToSubAccount(AssignSubAccountRole command) public OperationResult AssignRoleToSubAccount(AssignSubAccountRole command)

View File

@@ -16,6 +16,7 @@ using System.Collections.Generic;
using System.Globalization; using System.Globalization;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using System.Threading.Tasks;
namespace AccountManagement.Application; namespace AccountManagement.Application;
@@ -508,6 +509,11 @@ public class TaskApplication : ITaskApplication
return _taskRepository.GetTasksHaveTicket(searchModel); return _taskRepository.GetTasksHaveTicket(searchModel);
} }
public List<TaskViewModel> GetTaskScheduleList(TaskSearchModel searchModel)
{
return _taskRepository.GetTaskScheduleList(searchModel);
}
//ساخت درخواست مهلت //ساخت درخواست مهلت
public OperationResult CreateRequestTime(CreateTaskTimeRequest command) public OperationResult CreateRequestTime(CreateTaskTimeRequest command)
{ {
@@ -589,6 +595,9 @@ public class TaskApplication : ITaskApplication
{ {
return operation.Failed("تاریخی برای درخواست وظیفه ثبت نشده است"); return operation.Failed("تاریخی برای درخواست وظیفه ثبت نشده است");
} }
assign.AcceptTimeRequest(); assign.AcceptTimeRequest();
message = string.IsNullOrWhiteSpace(message) ? "درخواست شما مورد تایید قرار گرفت" : message; message = string.IsNullOrWhiteSpace(message) ? "درخواست شما مورد تایید قرار گرفت" : message;
var messageEntity = new TaskMessage(message, "تایید درخواست مهلت", assign.id); var messageEntity = new TaskMessage(message, "تایید درخواست مهلت", assign.id);
@@ -613,6 +622,7 @@ public class TaskApplication : ITaskApplication
{ {
return operation.Failed("چنین وظیفه ای درخواستی برای مهلت ندارد"); return operation.Failed("چنین وظیفه ای درخواستی برای مهلت ندارد");
} }
assign.RejectTimeRequest(); assign.RejectTimeRequest();
if (assign.EndTaskDate.Date <= DateTime.Now.Date) if (assign.EndTaskDate.Date <= DateTime.Now.Date)
{ {
@@ -865,14 +875,14 @@ public class TaskApplication : ITaskApplication
return _taskRepository.AllRequestedTasks(searchModel); 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 +891,9 @@ public class TaskApplication : ITaskApplication
return _taskMessageRepository.GetTaskMessages(assignId); 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) public OperationResult ChangeRequestTimeAndAccept(string time, long taskId, long assignedId, string message)
@@ -1007,15 +1017,15 @@ public class TaskApplication : ITaskApplication
return _assignRepository.GetAssignsByTaskId(taskId); 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() //public OperationResult MoveDataFRomTaskToAssign()

View File

@@ -4,6 +4,10 @@ using AccountManagement.Application.Contracts.TaskSchedule;
using AccountManagement.Domain.TaskScheduleAgg; using AccountManagement.Domain.TaskScheduleAgg;
using System; using System;
using System.IO; using System.IO;
using System.Linq;
using System.Threading.Tasks;
using System.Transactions;
using AccountManagement.Domain.TaskAgg;
using Company.Domain.HolidayItemAgg; using Company.Domain.HolidayItemAgg;
namespace AccountManagement.Application; namespace AccountManagement.Application;
@@ -13,12 +17,13 @@ public class TaskScheduleApplication : ITaskScheduleApplication
private readonly ITaskApplication _taskApplication; private readonly ITaskApplication _taskApplication;
private readonly ITaskScheduleRepository _taskScheduleRepository; private readonly ITaskScheduleRepository _taskScheduleRepository;
private readonly IHolidayItemRepository _holidayItemRepository; private readonly IHolidayItemRepository _holidayItemRepository;
private readonly ITaskRepository _taskRepository;
public TaskScheduleApplication(ITaskApplication taskApplication, ITaskScheduleRepository taskScheduleRepository, IHolidayItemRepository holidayItemRepository) public TaskScheduleApplication(ITaskApplication taskApplication, ITaskScheduleRepository taskScheduleRepository, IHolidayItemRepository holidayItemRepository, ITaskRepository taskRepository)
{ {
_taskApplication = taskApplication; _taskApplication = taskApplication;
_taskScheduleRepository = taskScheduleRepository; _taskScheduleRepository = taskScheduleRepository;
_holidayItemRepository = holidayItemRepository; _holidayItemRepository = holidayItemRepository;
_taskRepository = taskRepository;
} }
public OperationResult Create(CreateTask command) public OperationResult Create(CreateTask command)
@@ -30,7 +35,7 @@ public class TaskScheduleApplication : ITaskScheduleApplication
{ {
switch (command.ScheduleType) switch (command.ScheduleType)
{ {
case "limited": case TaskScheduleType.Limited:
if (Convert.ToInt32(command.ScheduleCount) > 60) if (Convert.ToInt32(command.ScheduleCount) > 60)
{ {
return operation.Failed("تعداد وارد شده بیشتر از حد مجاز است"); return operation.Failed("تعداد وارد شده بیشتر از حد مجاز است");
@@ -38,51 +43,91 @@ public class TaskScheduleApplication : ITaskScheduleApplication
return CreateLimitedTasks(command); return CreateLimitedTasks(command);
break; break;
case "unlimited": case TaskScheduleType.Unlimited:
return CreateUnlimitedTasks(command); return CreateUnlimitedTasks(command);
break; break;
default: default:
return operation.Failed("خطای سیستمی!"); return operation.Failed("نوع وظیفه محول شده مشخص نمیباشد");
} }
} }
else else
{ {
return operation.Failed("این تسک بصورت زمان بندی شده نمیباشد"); return operation.Failed("این تسک بصورت دوره ای نمیباشد");
} }
} }
public OperationResult CreateLimitedTasks(CreateTask command) public async Task<TaskScheduleDetailsViewModel> GetDetails(long id)
{
return await _taskScheduleRepository.GetDetails(id);
}
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();
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();
}
private OperationResult CreateLimitedTasks(CreateTask command)
{ {
OperationResult operation = new OperationResult(); OperationResult operation = new OperationResult();
if (Convert.ToInt32(command.ScheduleCount) < 1 || string.IsNullOrWhiteSpace(command.ScheduleCount)) if (Convert.ToInt32(command.ScheduleCount) < 1 || string.IsNullOrWhiteSpace(command.ScheduleCount))
{ {
return operation.Failed("تعداد وارد شده باید بیشتر از 2 باشد"); return operation.Failed("تعداد وارد شده باید بیشتر از 2 باشد");
} }
if (string.IsNullOrWhiteSpace(command.ScheduleUnitNumber))
{
return operation.Failed("لطفا تعداد بازه خود را مشخص کنید");
}
switch (command.ScheduleUnitType) switch (command.ScheduleUnitType)
{ {
case "year": case TaskScheduleUnitType.Year:
if (Convert.ToInt32(command.ScheduleCount) != 1) if (Convert.ToInt32(command.ScheduleCount) != 1)
{ {
return operation.Failed("دوره نمیتواند بیشتر از 1 سال باشد"); return operation.Failed("دوره نمیتواند بیشتر از 1 سال باشد");
} }
break; break;
case "month": case TaskScheduleUnitType.Month:
if (Convert.ToInt32(command.ScheduleCount) > 12)
if (Convert.ToInt32(command.ScheduleUnitNumber) is > 12 or < 1)
{ {
return operation.Failed("بازه وارد شده نا معتبر است"); return operation.Failed("بازه وارد شده نا معتبر است");
} }
if (Convert.ToInt32(command.ScheduleCount) is > 60 or < 1)
{
return operation.Failed("تعداد دفعات وارد شده نامعتبر است");
}
break; break;
case "week": case TaskScheduleUnitType.Week:
if (command.ScheduleUnitNumber != "first" && command.ScheduleUnitNumber != "last") if (command.ScheduleUnitNumber != "first" && command.ScheduleUnitNumber != "last")
{ {
return operation.Failed("بازه وارد شده نا معتبر است"); return operation.Failed("بازه وارد شده نا معتبر است");
} }
break; break;
case "day": case TaskScheduleUnitType.Day:
if (Convert.ToInt32(command.ScheduleUnitNumber) > 29) if (Convert.ToInt32(command.ScheduleUnitNumber) is > 29 or < 1)
{ {
return operation.Failed("بازه وارد شده نا معتبر است"); return operation.Failed("بازه وارد شده نا معتبر است");
} }
@@ -94,8 +139,12 @@ public class TaskScheduleApplication : ITaskScheduleApplication
} }
try try
{ {
//using var transaction = new TransactionScope();
DateTime previousDateRaw = command.EndTaskDate.ToEndDayOfGeorgianDateTime(); DateTime previousDateRaw = command.EndTaskDate.ToEndDayOfGeorgianDateTime();
DateTime previousDateEdited = 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));
int count = Convert.ToInt32(command.ScheduleCount); int count = Convert.ToInt32(command.ScheduleCount);
bool isInt = int.TryParse(command.ScheduleUnitNumber, out int unitNumber); bool isInt = int.TryParse(command.ScheduleUnitNumber, out int unitNumber);
@@ -108,7 +157,7 @@ public class TaskScheduleApplication : ITaskScheduleApplication
switch (command.ScheduleUnitType) switch (command.ScheduleUnitType)
{ {
case "year": case TaskScheduleUnitType.Year:
for (int i = 1; i <= count; i++) for (int i = 1; i <= count; i++)
{ {
command.EndTaskDate = previousDateEdited.ToFarsi(); command.EndTaskDate = previousDateEdited.ToFarsi();
@@ -120,20 +169,33 @@ public class TaskScheduleApplication : ITaskScheduleApplication
{ {
previousDateEdited = previousDateRaw.AddDays(1); previousDateEdited = previousDateRaw.AddDays(1);
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited); isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
} }
previousDateRaw = previousDateRaw.AddYears(unitNumber); previousDateRaw = previousDateRaw.AddYears(unitNumber);
previousDateEdited = previousDateRaw; previousDateEdited = previousDateRaw;
} }
break; break;
case "month": case TaskScheduleUnitType.Month:
bool endOfMonth = day == 31;
if (endOfMonth)
{
for (int i = 1; i <= count; i++) for (int i = 1; i <= count; i++)
{ {
command.EndTaskDate = previousDateEdited.ToFarsi(); command.EndTaskDate = previousDateEdited.ToFarsi();
operation = _taskApplication.CreateTask(command); operation = _taskApplication.CreateTask(command);
taskSchedule.SetLastEndTaskDate(previousDateEdited); 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); bool isHoliday = _holidayItemRepository.GetHoliday(previousDateRaw);
while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday) while (isHoliday || previousDateEdited.DayOfWeek == DayOfWeek.Friday)
{ {
@@ -141,13 +203,72 @@ public class TaskScheduleApplication : ITaskScheduleApplication
isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited); isHoliday = _holidayItemRepository.GetHoliday(previousDateEdited);
} }
previousDateRaw = previousDateRaw.AddMonths(unitNumber);
previousDateEdited = previousDateRaw; previousDateEdited = previousDateRaw;
} }
}
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;
}
else
{
month = unitNumber + month;
}
if (day == 30)
{
if (month == 12)
{
var lastYearDay = Convert.ToInt32($"{year:0000}/{month:00}/1".FindeEndOfMonth()
.Substring(8, 2));
endDay = lastYearDay == 30 ? lastYearDay : 29;
}
}
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; break;
case "week": case TaskScheduleUnitType.Week:
for (int i = 1; i <= count; i++) for (int i = 1; i <= count; i++)
{ {
if (string.IsNullOrWhiteSpace(kindOfWeekUnit)) if (string.IsNullOrWhiteSpace(kindOfWeekUnit))
@@ -177,7 +298,7 @@ public class TaskScheduleApplication : ITaskScheduleApplication
} }
break; break;
case "day": case TaskScheduleUnitType.Day:
for (int i = 1; i <= count; i++) for (int i = 1; i <= count; i++)
{ {
@@ -199,6 +320,7 @@ public class TaskScheduleApplication : ITaskScheduleApplication
} }
_taskScheduleRepository.SaveChanges(); _taskScheduleRepository.SaveChanges();
//transaction.Complete();
operation = operation.Succcedded(); operation = operation.Succcedded();
return operation; return operation;
} }
@@ -208,16 +330,27 @@ public class TaskScheduleApplication : ITaskScheduleApplication
} }
} }
public OperationResult CreateUnlimitedTasks(CreateTask command) 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); var operation = _taskApplication.CreateTask(command);
if (!operation.IsSuccedded) if (!operation.IsSuccedded)
return operation; 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(); _taskScheduleRepository.SaveChanges();
transaction.Complete();
return operation.Succcedded(); return operation.Succcedded();
} }

View File

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

View File

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

View File

@@ -27,12 +27,21 @@ namespace AccountManagement.Domain.AccountAgg
List<AccountViewModel> GetAccountEqualToLowerPositionValue(); List<AccountViewModel> GetAccountEqualToLowerPositionValue();
AccountViewModel GetAccountViewModel(long id); AccountViewModel GetAccountViewModel(long id);
List<AccountViewModel> GetAccountsDeactivePositionValue(long Positionid); List<AccountViewModel> GetAccountsDeactivePositionValue(long Positionid);
Task<List<AccountSelectListViewModel>> GetAdminSelectList();
#endregion #endregion
List<AccountViewModel> GetAdminAccountsNew(); List<AccountViewModel> GetAdminAccountsNew();
List<AccountViewModel> GetAccountsToEditWorkshop(long workshopId); List<AccountViewModel> GetAccountsToEditWorkshop(long workshopId);
/// <summary>
/// چک میکند که اکانتی با این ام کاربری وجود دارد یا نه
/// </summary>
/// <param name="userName"></param>
/// <returns></returns>
public bool CheckExistClientAccount(string userName);
} }
} }

View File

@@ -2,6 +2,7 @@
using AccountManagement.Domain.TaskAgg; using AccountManagement.Domain.TaskAgg;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq;
using AccountManagement.Domain.TaskMessageAgg; using AccountManagement.Domain.TaskMessageAgg;
namespace AccountManagement.Domain.AssignAgg; namespace AccountManagement.Domain.AssignAgg;
@@ -52,7 +53,9 @@ public class Assign : EntityBase
public string? DoneDescription { get; private set; } public string? DoneDescription { get; private set; }
public bool IsCanceledRequest { get; private set; } public bool IsCanceledRequest { get; private set; }
public bool FirstTimeCreation { get; private set; } public bool FirstTimeCreation { get; private set; }
public Tasks Task { get; set; } public Tasks Task { get; set; }
public List<TaskMessage> TaskMessageList { get; set; } public List<TaskMessage> TaskMessageList { get; set; }
@@ -69,13 +72,15 @@ public class Assign : EntityBase
public void AcceptTimeRequest() public void AcceptTimeRequest()
{ {
ClearRequests();
TimeRequest = false; TimeRequest = false;
AcceptedTimeRequest++; AcceptedTimeRequest++;
EndTaskDate = RequestDate.Value; EndTaskDate = RequestDate < DateTime.Today ? DateTime.Today : RequestDate.Value;
} }
public void RejectTimeRequest() public void RejectTimeRequest()
{ {
ClearRequests();
TimeRequest = false; TimeRequest = false;
TimeRequestDescription = null; TimeRequestDescription = null;
RequestDate = null; RequestDate = null;
@@ -90,6 +95,7 @@ public class Assign : EntityBase
} }
public void AcceptCancelRequest() public void AcceptCancelRequest()
{ {
ClearRequests();
IsCanceledRequest = false; IsCanceledRequest = false;
IsCancel = true; IsCancel = true;
@@ -97,23 +103,27 @@ public class Assign : EntityBase
} }
public void RejectCancel() public void RejectCancel()
{ {
ClearRequests();
CancelDescription = null; CancelDescription = null;
IsCanceledRequest = false; IsCanceledRequest = false;
} }
public void CompleteRequest(string? doneDescription) public void CompleteRequest(string? doneDescription)
{ {
ClearRequests();
DoneDescription = doneDescription; DoneDescription = doneDescription;
IsDoneRequest = true; IsDoneRequest = true;
} }
public void RejectCompleteRequest() public void RejectCompleteRequest()
{ {
ClearRequests();
IsDoneRequest = false; IsDoneRequest = false;
DoneDescription = null; DoneDescription = null;
} }
public void Completed() public void Completed()
{ {
ClearRequests();
IsDoneRequest = false; IsDoneRequest = false;
IsDone = true; IsDone = true;
} }
@@ -126,6 +136,13 @@ public class Assign : EntityBase
TimeRequest = false; TimeRequest = false;
} }
public void ClearRequests()
{
IsDoneRequest = false;
IsCanceledRequest = false;
TimeRequest = false;
}
public void InsertNewData(DateTime endTaskDate,bool timeRequest,int acceptedTimeRequest,DateTime? requestDate, string timeRequestDescription, bool isCanceledRequest, public void InsertNewData(DateTime endTaskDate,bool timeRequest,int acceptedTimeRequest,DateTime? requestDate, string timeRequestDescription, bool isCanceledRequest,
bool isCancel,string cancelDescription,bool isDone,bool isDoneRequest,string? doneDescription) bool isCancel,string cancelDescription,bool isDone,bool isDoneRequest,string? doneDescription)
{ {
@@ -142,4 +159,24 @@ public class Assign : EntityBase
IsDoneRequest=isDoneRequest; IsDoneRequest=isDoneRequest;
DoneDescription=doneDescription; DoneDescription=doneDescription;
} }
public void ChangeAssignedId(long assignedId)
{
AssignedId = assignedId;
}
public void SetAssignerId(long assignerId)
{
AssignerId = assignerId;
}
public void ChangeSender(long senderId)
{
Task.SetSender(senderId);
var taskMessageItemsEnumerable =TaskMessageList.SelectMany(m => m.TaskMessageItemsList);
foreach (var taskMessageItems in taskMessageItemsEnumerable)
{
taskMessageItems.SetSenderId(senderId);
}
}
} }

View File

@@ -1,12 +1,15 @@
using System.Collections.Generic; using System.Collections.Generic;
using _0_Framework.Application;
using _0_Framework.Domain; using _0_Framework.Domain;
using AccountManagement.Application.Contracts.Media; using AccountManagement.Application.Contracts.Media;
using Microsoft.AspNetCore.Http;
namespace AccountManagement.Domain.MediaAgg; namespace AccountManagement.Domain.MediaAgg;
public interface IMediaRepository : IRepository<long, Media> public interface IMediaRepository : IRepository<long, Media>
{ {
public string BasePath { get; protected set; }
void CreateMediaWithTaskMedia(long taskId, long mediaId); void CreateMediaWithTaskMedia(long taskId, long mediaId);
List<MediaViewModel> GetMediaByTaskId(long taskId); List<MediaViewModel> GetMediaByTaskId(long taskId);
void Remove(long id); void Remove(long id);
@@ -23,4 +26,6 @@ public interface IMediaRepository:IRepository<long,Media>
#endregion #endregion
OperationResult UploadFile(IFormFile file, string fileLabel, string relativePath, int maximumFileLength,
List<string> allowedExtensions, string category);
} }

View File

@@ -2,6 +2,7 @@
using _0_Framework.Domain; using _0_Framework.Domain;
using AccountManagement.Application.Contracts.SubAccount; using AccountManagement.Application.Contracts.SubAccount;
using System.Collections.Generic; using System.Collections.Generic;
using System.Collections.Specialized;
namespace AccountManagement.Domain.SubAccountAgg namespace AccountManagement.Domain.SubAccountAgg
{ {
@@ -13,5 +14,6 @@ namespace AccountManagement.Domain.SubAccountAgg
SubAccount GetDetails(long subAccountId); SubAccount GetDetails(long subAccountId);
SubAccount GetBy(string commandUsername); SubAccount GetBy(string commandUsername);
SubAccountViewModel GetByVerifyCodeAndPhoneNumber(string code, string phone); SubAccountViewModel GetByVerifyCodeAndPhoneNumber(string code, string phone);
List<SubAccount> GetBySubAccountRole(long subAccountRoleId);
} }
} }

View File

@@ -13,17 +13,21 @@ namespace AccountManagement.Domain.SubAccountRoleAgg
public List<SubAccountRolePermission> RolePermissions { get; private set; } public List<SubAccountRolePermission> RolePermissions { get; private set; }
public List<SubAccount> SubAccounts { get; private set; } public List<SubAccount> SubAccounts { get; private set; }
public List<SubAccountRoleWorkshop> RoleWorkshops { get; set; }
private SubAccountRole() private SubAccountRole()
{ {
} }
public SubAccountRole(string title, List<int> permissions, long accountId) public SubAccountRole(string title, List<int> permissions, long accountId, List<long> workshopIds)
{ {
Title = title; Title = title;
RolePermissions = permissions.Select(x => new SubAccountRolePermission(x, id)).ToList(); RolePermissions = permissions.Select(x => new SubAccountRolePermission(x, id)).ToList();
AccountId = accountId; AccountId = accountId;
RoleWorkshops = workshopIds.Select(x => new SubAccountRoleWorkshop(x, id)).ToList();
} }
public void ChangeTitle(string title) public void ChangeTitle(string title)
{ {
Title = title; Title = title;
@@ -32,10 +36,12 @@ namespace AccountManagement.Domain.SubAccountRoleAgg
{ {
RolePermissions.AddRange(permissionIds.Select(x => new SubAccountRolePermission(x, id))); RolePermissions.AddRange(permissionIds.Select(x => new SubAccountRolePermission(x, id)));
} }
public void Edit(string title, List<int> permissions) public void Edit(string title, List<int> permissions,List<long> workshopIds)
{ {
Title = title; Title = title;
RolePermissions = permissions.Select(x => new SubAccountRolePermission(x, id)).ToList(); RolePermissions = permissions.Select(x => new SubAccountRolePermission(x, id)).ToList();
RoleWorkshops = workshopIds.Select(x => new SubAccountRoleWorkshop(x, id)).ToList();
} }
} }
} }

View File

@@ -0,0 +1,16 @@
using _0_Framework.Domain;
namespace AccountManagement.Domain.SubAccountRoleAgg;
public class SubAccountRoleWorkshop:EntityBase
{
public SubAccountRoleWorkshop(long workshopId, long subAccountId)
{
WorkshopId = workshopId;
SubAccountId = subAccountId;
}
public long WorkshopId { get; set; }
public long SubAccountId { get; set; }
public SubAccountRole SubAccountRole { get; set; }
}

View File

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

View File

@@ -1,10 +1,12 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq;
using System.Security.AccessControl; using System.Security.AccessControl;
using _0_Framework.Domain; using _0_Framework.Domain;
using AccountManagement.Domain.AssignAgg; using AccountManagement.Domain.AssignAgg;
using AccountManagement.Domain.TaskMediaAgg; using AccountManagement.Domain.TaskMediaAgg;
using AccountManagement.Domain.TaskScheduleAgg; using AccountManagement.Domain.TaskScheduleAgg;
using OfficeOpenXml.Style;
namespace AccountManagement.Domain.TaskAgg; namespace AccountManagement.Domain.TaskAgg;
@@ -80,4 +82,40 @@ public class Tasks : EntityBase
TaskScheduleId = taskScheduleId; TaskScheduleId = taskScheduleId;
} }
public void ChangeSender(long senderId)
{
var prevSender = SenderId;
var assigners = Assigns.Where(x => x.AssignerId == prevSender).ToList();
foreach (var assigner in assigners)
{
assigner.SetAssignerId(senderId);
}
var senderMessageItem = Assigns
.SelectMany(x=>x.TaskMessageList
.SelectMany(m=>m.TaskMessageItemsList)).Where(x=>x.SenderAccountId == prevSender).ToList();
var receiverMessageItem = Assigns.SelectMany(x=>x.TaskMessageList
.SelectMany(m=>m.TaskMessageItemsList)).Where(x=>x.ReceiverAccountId == prevSender).ToList();
SenderId = senderId;
foreach (var taskMessageItems in senderMessageItem)
{
taskMessageItems.SetSenderId(senderId);
}
foreach (var taskMessageItems in receiverMessageItem)
{
taskMessageItems.SetReceiver(senderId);
}
}
public void SetSender(long senderId)
{
SenderId = senderId;
}
} }

View File

@@ -19,4 +19,13 @@ public class TaskMessageItems:EntityBase
public TaskMessage TaskMessage { get; set; } public TaskMessage TaskMessage { get; set; }
public void SetSenderId(long senderId)
{
SenderAccountId = senderId;
}
public void SetReceiver(long receiverId)
{
ReceiverAccountId = receiverId;
}
} }

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; 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;
using System.Collections.Generic; using System.Collections.Generic;
using _0_Framework.Application;
using _0_Framework.Domain; using _0_Framework.Domain;
using AccountManagement.Application.Contracts.Task;
using AccountManagement.Domain.TaskAgg; using AccountManagement.Domain.TaskAgg;
namespace AccountManagement.Domain.TaskScheduleAgg; namespace AccountManagement.Domain.TaskScheduleAgg;
public class TaskSchedule:EntityBase 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; Count = count;
Type = type; Type = type;
UnitType = unitType; UnitType = unitType;
UnitNumber = unitNumber; UnitNumber = unitNumber;
LastEndTaskDate = lastEndTaskDate; LastEndTaskDate = lastEndTaskDate;
IsActive = IsActive.True;
} }
public string Count { get; private set; } public string Count { get; private set; }
public string Type { get; private set; } public TaskScheduleType Type { get; private set; }
public string UnitType { get; private set; } public TaskScheduleUnitType UnitType { get; private set; }
public string UnitNumber { get; private set; } public string UnitNumber { get; private set; }
public DateTime LastEndTaskDate { get; private set; } public DateTime LastEndTaskDate { get; private set; }
public IsActive IsActive { get; private set; }
public List<Tasks> TasksList { get; set; } public List<Tasks> TasksList { get; set; }
public void SetLastEndTaskDate(DateTime lastEndTaskDate) public void SetLastEndTaskDate(DateTime lastEndTaskDate)
{ {
LastEndTaskDate = 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.SubAccountPermissionSubtitle4Agg;
using AccountManagement.Domain.SubAccountRoleAgg; using AccountManagement.Domain.SubAccountRoleAgg;
using AccountMangement.Infrastructure.EFCore.Seed; using AccountMangement.Infrastructure.EFCore.Seed;
using AccountManagement.Domain.TaskScheduleAgg;
namespace AccountMangement.Infrastructure.EFCore namespace AccountMangement.Infrastructure.EFCore
{ {
@@ -57,6 +58,9 @@ namespace AccountMangement.Infrastructure.EFCore
public DbSet<TicketAccessAccount> TicketAccessAccounts { get; set; } public DbSet<TicketAccessAccount> TicketAccessAccounts { get; set; }
public DbSet<TaskSchedule> TaskSchedules { get; set; }
#endregion #endregion
#region Pooya #region Pooya

View File

@@ -21,6 +21,10 @@ namespace AccountMangement.Infrastructure.EFCore.Mappings
opt.WithOwner(x => x.SubAccountRole); opt.WithOwner(x => x.SubAccountRole);
}); });
builder.OwnsMany(x => x.RoleWorkshops, roleWorkshop =>
{
roleWorkshop.WithOwner(x => x.SubAccountRole).HasForeignKey(x => x.SubAccountId);
});
} }
} }
} }

View File

@@ -12,9 +12,10 @@ public class TaskScheduleMapping : IEntityTypeConfiguration<TaskSchedule>
builder.HasKey(x => x.id); builder.HasKey(x => x.id);
builder.Property(x => x.Count).HasMaxLength(10); 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.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) builder.HasMany(x => x.TasksList).WithOne(x => x.TaskSchedule)
.HasForeignKey(x => x.TaskScheduleId); .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

@@ -0,0 +1,43 @@
using System;
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace AccountMangement.Infrastructure.EFCore.Migrations
{
/// <inheritdoc />
public partial class addworkshoptosubAccountRole : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.CreateTable(
name: "SubAccountRoleWorkshop",
columns: table => new
{
id = table.Column<long>(type: "bigint", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
SubAccountId = table.Column<long>(type: "bigint", nullable: false),
WorkshopId = table.Column<long>(type: "bigint", nullable: false),
CreationDate = table.Column<DateTime>(type: "datetime2", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_SubAccountRoleWorkshop", x => new { x.SubAccountId, x.id });
table.ForeignKey(
name: "FK_SubAccountRoleWorkshop_SubAccountRoles_SubAccountId",
column: x => x.SubAccountId,
principalTable: "SubAccountRoles",
principalColumn: "id",
onDelete: ReferentialAction.Cascade);
});
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropTable(
name: "SubAccountRoleWorkshop");
}
}
}

View File

@@ -759,10 +759,16 @@ namespace AccountMangement.Infrastructure.EFCore.Migrations
b.Property<DateTime>("CreationDate") b.Property<DateTime>("CreationDate")
.HasColumnType("datetime2"); .HasColumnType("datetime2");
b.Property<string>("IsActive")
.IsRequired()
.HasMaxLength(5)
.HasColumnType("nvarchar(5)");
b.Property<DateTime>("LastEndTaskDate") b.Property<DateTime>("LastEndTaskDate")
.HasColumnType("datetime2"); .HasColumnType("datetime2");
b.Property<string>("Type") b.Property<string>("Type")
.IsRequired()
.HasMaxLength(12) .HasMaxLength(12)
.HasColumnType("nvarchar(12)"); .HasColumnType("nvarchar(12)");
@@ -771,6 +777,7 @@ namespace AccountMangement.Infrastructure.EFCore.Migrations
.HasColumnType("nvarchar(10)"); .HasColumnType("nvarchar(10)");
b.Property<string>("UnitType") b.Property<string>("UnitType")
.IsRequired()
.HasMaxLength(10) .HasMaxLength(10)
.HasColumnType("nvarchar(10)"); .HasColumnType("nvarchar(10)");
@@ -1071,6 +1078,33 @@ namespace AccountMangement.Infrastructure.EFCore.Migrations
modelBuilder.Entity("AccountManagement.Domain.SubAccountRoleAgg.SubAccountRole", b => modelBuilder.Entity("AccountManagement.Domain.SubAccountRoleAgg.SubAccountRole", b =>
{ {
b.OwnsMany("AccountManagement.Domain.SubAccountRoleAgg.SubAccountRoleWorkshop", "RoleWorkshops", b1 =>
{
b1.Property<long>("SubAccountId")
.HasColumnType("bigint");
b1.Property<long>("id")
.ValueGeneratedOnAdd()
.HasColumnType("bigint");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b1.Property<long>("id"));
b1.Property<DateTime>("CreationDate")
.HasColumnType("datetime2");
b1.Property<long>("WorkshopId")
.HasColumnType("bigint");
b1.HasKey("SubAccountId", "id");
b1.ToTable("SubAccountRoleWorkshop");
b1.WithOwner("SubAccountRole")
.HasForeignKey("SubAccountId");
b1.Navigation("SubAccountRole");
});
b.OwnsMany("AccountManagement.Domain.SubAccountRoleAgg.SubAccountRolePermission", "RolePermissions", b1 => b.OwnsMany("AccountManagement.Domain.SubAccountRoleAgg.SubAccountRolePermission", "RolePermissions", b1 =>
{ {
b1.Property<long>("id") b1.Property<long>("id")
@@ -1098,6 +1132,8 @@ namespace AccountMangement.Infrastructure.EFCore.Migrations
}); });
b.Navigation("RolePermissions"); b.Navigation("RolePermissions");
b.Navigation("RoleWorkshops");
}); });
modelBuilder.Entity("AccountManagement.Domain.TaskAgg.Tasks", b => modelBuilder.Entity("AccountManagement.Domain.TaskAgg.Tasks", b =>

View File

@@ -312,6 +312,17 @@ public class AccountRepository : RepositoryBase<long, Account>, IAccountReposito
IsActiveString = x.IsActive ? "true" : "false", IsActiveString = x.IsActive ? "true" : "false",
}).ToList(); }).ToList();
} }
public async Task<List<AccountSelectListViewModel>> GetAdminSelectList()
{
return await _context.Accounts.Where(x => x.AdminAreaPermission == "true").Select(x => new AccountSelectListViewModel()
{
Id = x.id,
Name = x.Fullname,
RoleId = x.RoleId
}).ToListAsync();
}
//public List<AccountViewModel> GetAdminAccounts() //public List<AccountViewModel> GetAdminAccounts()
//{ //{
// return _context.Accounts.Where(x=>x.AdminAreaPermission == "true" && x.IsActiveString == "true").Select(x => new AccountViewModel() // return _context.Accounts.Where(x=>x.AdminAreaPermission == "true" && x.IsActiveString == "true").Select(x => new AccountViewModel()
@@ -332,4 +343,9 @@ public class AccountRepository : RepositoryBase<long, Account>, IAccountReposito
#endregion #endregion
public bool CheckExistClientAccount(string userName)
{
return _context.Accounts.Any(x => x.Username == userName);
}
} }

View File

@@ -1,5 +1,8 @@
using System.Collections.Generic; using System;
using System.Collections.Generic;
using System.IO;
using System.Linq; using System.Linq;
using _0_Framework.Application;
using _0_Framework.InfraStructure; using _0_Framework.InfraStructure;
using AccountManagement.Application.Contracts.Media; using AccountManagement.Application.Contracts.Media;
using AccountManagement.Domain.AdminResponseMediaAgg; using AccountManagement.Domain.AdminResponseMediaAgg;
@@ -7,19 +10,27 @@ using AccountManagement.Domain.ClientResponseMediaAgg;
using AccountManagement.Domain.MediaAgg; using AccountManagement.Domain.MediaAgg;
using AccountManagement.Domain.TaskMediaAgg; using AccountManagement.Domain.TaskMediaAgg;
using AccountManagement.Domain.TicketMediasAgg; using AccountManagement.Domain.TicketMediasAgg;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
namespace AccountMangement.Infrastructure.EFCore.Repository; namespace AccountMangement.Infrastructure.EFCore.Repository;
public class MediaRepository : RepositoryBase<long, Media>, IMediaRepository public class MediaRepository : RepositoryBase<long, Media>, IMediaRepository
{ {
private const string _basePath = "Storage/Medias";
public string BasePath { get; set; }
private readonly AccountContext _accountContext; private readonly AccountContext _accountContext;
public MediaRepository( AccountContext taskManagerContext) : base(taskManagerContext) public MediaRepository(AccountContext taskManagerContext, IWebHostEnvironment webHostEnvironment) : base(taskManagerContext)
{ {
_accountContext = taskManagerContext; _accountContext = taskManagerContext;
BasePath = webHostEnvironment.ContentRootPath + "/Storage";
} }
//ساخت جدول واسط بین مدیا و نسک //ساخت جدول واسط بین مدیا و نسک
//نکته: این متد ذخیره انجام نمیدهد //نکته: این متد ذخیره انجام نمیدهد
public void CreateMediaWithTaskMedia(long taskId, long mediaId) public void CreateMediaWithTaskMedia(long taskId, long mediaId)
{ {
var Taskmedias = new TaskMedia(taskId, mediaId); var Taskmedias = new TaskMedia(taskId, mediaId);
@@ -77,6 +88,48 @@ public class MediaRepository:RepositoryBase<long,Media>,IMediaRepository
{ {
return _accountContext.Medias.Where(x => mediaIds.Contains(x.id)).ToList(); return _accountContext.Medias.Where(x => mediaIds.Contains(x.id)).ToList();
} }
public OperationResult UploadFile(IFormFile file, string fileLabel, string relativePath, int maximumFileLength,
List<string> allowedExtensions, string category)
{
OperationResult op = new();
var path = Path.Combine(_basePath, relativePath);
var fileExtension = Path.GetExtension(file.FileName);
if (file == null || file.Length == 0)
return op.Failed("خطای سیستمی");
if (file.Length > (maximumFileLength * 1024 * 1024))
return op.Failed($"حجم فایل نمی تواند بیشتر از " +
$"{maximumFileLength}" +
$"مگابایت باشد");
if (!allowedExtensions.Contains(fileExtension.ToLower()))
{
var operationMessage = ":فرمت فایل باید یکی از موارد زیر باشد";
operationMessage += "\n";
operationMessage += string.Join(" ", allowedExtensions);
return op.Failed(operationMessage);
}
Directory.CreateDirectory(path);
var extension = Path.GetExtension(file.FileName);
var uniqueFileName = $"{fileLabel}-{DateTime.Now.Ticks}{extension}";
var filePath = Path.Combine(path, uniqueFileName);
using (var fileStream = new FileStream(filePath, FileMode.CreateNew))
{
file.CopyTo(fileStream);
}
var mediaEntity = new Media(filePath, extension, "فایل", category);
Create(mediaEntity);
SaveChanges();
return op.Succcedded(mediaEntity.id);
}
} }
#endregion #endregion

View File

@@ -77,5 +77,10 @@ namespace AccountMangement.Infrastructure.EFCore.Repository
Username = entity.Username Username = entity.Username
}; };
} }
public List<SubAccount> GetBySubAccountRole(long subAccountRoleId)
{
return _context.SubAccounts.Where(x => x.SubAccountRoleId == subAccountRoleId).ToList();
}
} }
} }

View File

@@ -4,6 +4,7 @@ using _0_Framework.InfraStructure;
using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Http;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using System.Linq; using System.Linq;
using System.Threading.Tasks;
using _0_Framework.Application; using _0_Framework.Application;
using AccountManagement.Application.Contracts.Account; using AccountManagement.Application.Contracts.Account;
using AccountManagement.Application.Contracts.Assign; using AccountManagement.Application.Contracts.Assign;
@@ -46,7 +47,6 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
public EditTask GetDetails(long TaskId) public EditTask GetDetails(long TaskId)
{ {
var task = Get(TaskId);
var userId = _authHelper.CurrentAccountId(); var userId = _authHelper.CurrentAccountId();
@@ -94,7 +94,8 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
Fullname = a.Fullname, Fullname = a.Fullname,
Id = a.id, Id = a.id,
}).FirstOrDefault() }).FirstOrDefault(),
TaskScheduleId = x.TaskScheduleId ?? 0
}).FirstOrDefault(); }).FirstOrDefault();
@@ -105,13 +106,26 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
{ {
res.EndTaskDate = _accountContext.Assigns.First(a => a.TaskId == res.Id && a.AssignedId == userId) res.EndTaskDate = _accountContext.Assigns.First(a => a.TaskId == res.Id && a.AssignedId == userId)
.EndTaskDate.ToFarsi(); .EndTaskDate.ToFarsi();
var userAssign = res.AssignViewModels.First(x => x.AssignedId == userId);
res.AssignViewModels = res.AssignViewModels.Where(x => x.AssignedId == userId).ToList(); res.AssignViewModels = res.AssignViewModels.Where(x => x.AssignedId == userId).ToList();
res.IsDone = res.AssignViewModels.First(x => x.AssignedId == userId).IsDone; res.IsDone = userAssign.IsDone;
res.IsCancel = res.AssignViewModels.First(x => x.AssignedId == userId).IsCancel; res.IsCancel = userAssign.IsCancel;
res.HasRequest = userAssign.IsCanceledRequest || userAssign.TimeRequest ||
userAssign.IsDoneRequest;
} }
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() //_accountContext.Tasks.Where(x => x.id == TaskId).Select(x => new EditTask()
//{ //{
// EndTaskDate = x.EndTaskDate.ToFarsi(), // EndTaskDate = x.EndTaskDate.ToFarsi(),
@@ -148,8 +162,6 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
Remove(task); Remove(task);
} }
public List<TaskViewModel> GetRequestedTasks(TaskSearchModel searchModel) public List<TaskViewModel> GetRequestedTasks(TaskSearchModel searchModel)
{ {
var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value); var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value);
@@ -888,7 +900,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
AcceptedTimeRequest = x.AcceptedTimeRequest, AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest, IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName, ContractingPartyName = x.ContractingPartyName,
Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel), Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel,false),
MediaCount = x.MediaCount, MediaCount = x.MediaCount,
HasAttachment = x.MediaCount > 0, HasAttachment = x.MediaCount > 0,
SelfName = x.SelfName, SelfName = x.SelfName,
@@ -968,7 +980,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
.ThenInclude(x => x.Media) .ThenInclude(x => x.Media)
.Where(x => .Where(x =>
x.Task.IsActiveString == "true" && (x.AssignerId == accountId && x.AssignedId != accountId) && (!x.IsCanceledRequest && !x.TimeRequest && !x.IsDoneRequest) && x.Task.TicketId == null && 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 => .Select(x =>
new TaskViewModel() new TaskViewModel()
{ {
@@ -1217,7 +1229,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
AcceptedTimeRequest = x.AcceptedTimeRequest, AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest, IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName, ContractingPartyName = x.ContractingPartyName,
Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel), Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel, false),
MediaCount = x.MediaCount, MediaCount = x.MediaCount,
HasAttachment = x.MediaCount > 0, HasAttachment = x.MediaCount > 0,
SelfName = x.SelfName, SelfName = x.SelfName,
@@ -1776,7 +1788,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
AcceptedTimeRequest = x.AcceptedTimeRequest, AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest, IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName, ContractingPartyName = x.ContractingPartyName,
Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel), Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel, false),
MediaCount = x.MediaCount, MediaCount = x.MediaCount,
HasAttachment = x.MediaCount > 0, HasAttachment = x.MediaCount > 0,
SelfName = x.SelfName, SelfName = x.SelfName,
@@ -1839,10 +1851,313 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
return final; return final;
} }
public List<TaskViewModel> GetTaskScheduleList(TaskSearchModel searchModel)
public string SetTasksColors(DateTime date, bool isCancel)
{ {
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) && x.Task.TaskSchedule.IsActive== IsActive.True);
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, false),
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,bool hasRequest)
{
if (hasRequest)
return "red";
if (isCancel) if (isCancel)
{ {
//return "brown"; //return "brown";
@@ -1888,23 +2203,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 positionValue = int.Parse(_contextAccessor.HttpContext.User.FindFirst("PositionValue").Value);
var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value); var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value);
if (positionValue == 1) 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.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) (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 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.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) (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 +2316,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); var account = _accountRepository.GetIncludePositions(userId);
if (account.Position == null) if (account.Position == null)
@@ -2009,7 +2324,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
DateTime now = DateTime.Now; DateTime now = DateTime.Now;
var overdueTasksCount = OverdueTasksCount(userId); var overdueTasksCount = await OverdueTasksCount(userId);
//overdueTasksCount = _accountContext.Tasks.Include(x => //overdueTasksCount = _accountContext.Tasks.Include(x =>
@@ -2018,10 +2333,10 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
// !x.Assigns.Any(a => a.TimeRequest) // !x.Assigns.Any(a => a.TimeRequest)
// && x.Assigns.Any(a => a.AssignedId == userId) && // && x.Assigns.Any(a => a.AssignedId == userId) &&
// (x.Assigns.First(a => a.AssignedId == userId).EndTaskDate.Date <= DateTime.Now.Date)); // (x.Assigns.First(a => a.AssignedId == userId).EndTaskDate.Date <= DateTime.Now.Date));
var overdueRequestsCount = GetRequestedTasksCount(); var overdueRequestsCount = await GetRequestedTasksCount();
var ticketRequested = TasksHaveTicketRequestsCount(userId); var ticketRequested = await TasksHaveTicketRequestsCount(userId);
var overdueTicket = TasksHaveTicketCounts(userId); var overdueTicket = await TasksHaveTicketCounts(userId);
return overdueTasksCount + overdueRequestsCount + ticketRequested + overdueTicket; return overdueTasksCount + overdueRequestsCount + ticketRequested + overdueTicket;
} }
@@ -2036,7 +2351,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
return overdueRequestsCount; return overdueRequestsCount;
} }
public int OverdueTasksCount(long userId) public async Task<int> OverdueTasksCount(long userId)
{ {
var account = _accountRepository.GetIncludePositions(userId); var account = _accountRepository.GetIncludePositions(userId);
@@ -2048,12 +2363,12 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
int overdueTasksCount; int overdueTasksCount;
if (positionValue == 1) 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.AssignerId == userId && x.Task.Assigns.Count == 1 &&
!x.IsCancel && !x.IsCanceledRequest && !x.IsCancel && !x.IsCanceledRequest &&
!x.IsDone && !x.TimeRequest && !x.IsDoneRequest && x.EndTaskDate.Date <= DateTime.Now.Date && !x.IsDone && !x.TimeRequest && !x.IsDoneRequest && x.EndTaskDate.Date <= DateTime.Now.Date &&
x.Task.IsActiveString == "true" && x.Task.TicketId == null) 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 => //overdueTasksCount = _accountContext.Tasks.Include(x =>
// x.Assigns).Count(x => !x.Assigns.Any(a => a.IsCancel) && !x.Assigns.Any(a => a.IsCanceledRequest) && // x.Assigns).Count(x => !x.Assigns.Any(a => a.IsCancel) && !x.Assigns.Any(a => a.IsCanceledRequest) &&
@@ -2065,43 +2380,49 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
} }
else 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.IsCancel && !x.IsCanceledRequest &&
!x.IsDone && !x.TimeRequest && !x.IsDoneRequest && x.EndTaskDate.Date <= DateTime.Now.Date && !x.IsDone && !x.TimeRequest && !x.IsDoneRequest && x.EndTaskDate.Date <= DateTime.Now.Date &&
x.Task.IsActiveString == "true" && x.Task.TicketId == null) 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; 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.IsDone && x.Task.IsActiveString == "true" && !x.IsCancel &&
!x.IsCanceledRequest && !x.IsDoneRequest && !x.IsCanceledRequest && !x.IsDoneRequest &&
!x.TimeRequest && (x.AssignerId == userId || x.AssignedId == userId) && !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 positionValue = int.Parse(_contextAccessor.HttpContext.User.FindFirst("PositionValue").Value);
var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value); var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value);
if (positionValue == 1) 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.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) (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 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.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) (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();
} }
} }
@@ -2340,7 +2661,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
AcceptedTimeRequest = x.AcceptedTimeRequest, AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest, IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName, ContractingPartyName = x.ContractingPartyName,
Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel), Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel, false),
MediaCount = x.MediaCount, MediaCount = x.MediaCount,
HasAttachment = x.MediaCount > 0, HasAttachment = x.MediaCount > 0,
SelfName = x.SelfName, SelfName = x.SelfName,
@@ -2404,6 +2725,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
{ {
var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value); var accountId = long.Parse(_contextAccessor.HttpContext.User.FindFirst("AccountId").Value);
var positionValue = int.Parse(_contextAccessor.HttpContext.User.FindFirst("PositionValue").Value); var positionValue = int.Parse(_contextAccessor.HttpContext.User.FindFirst("PositionValue").Value);
var today = DateTime.Today;
var emptyAcc = new AccountViewModel() var emptyAcc = new AccountViewModel()
{ {
Fullname = "-", Fullname = "-",
@@ -2413,7 +2735,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
var raw = _accountContext.Assigns.Include(x => x.Task).ThenInclude(x => x.TaskMedias) var raw = _accountContext.Assigns.Include(x => x.Task).ThenInclude(x => x.TaskMedias)
.ThenInclude(x => x.Media) .ThenInclude(x => x.Media)
.Where(x => .Where(x =>
x.Task.IsActiveString == "true" && x.AssignedId == accountId && (!x.IsCanceledRequest && !x.TimeRequest && !x.IsDoneRequest) && x.Task.TicketId == null); x.Task.IsActiveString == "true" && x.AssignedId == accountId && x.Task.TicketId == null &&!x.IsDoneRequest && !x.IsCanceledRequest);
if (!string.IsNullOrWhiteSpace(searchModel.GeneralSearch)) if (!string.IsNullOrWhiteSpace(searchModel.GeneralSearch))
{ {
raw = raw.Where(x => raw = raw.Where(x =>
@@ -2446,6 +2768,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
MediaCount = _accountContext.TaskMedias.Count(m => m.TaskId == x.Task.id), MediaCount = _accountContext.TaskMedias.Count(m => m.TaskId == x.Task.id),
Description = x.Task.Description, Description = x.Task.Description,
IsDoneRequest = x.IsDoneRequest, IsDoneRequest = x.IsDoneRequest,
}); });
if (!string.IsNullOrWhiteSpace(searchModel.GeneralSearch)) if (!string.IsNullOrWhiteSpace(searchModel.GeneralSearch))
{ {
@@ -2484,7 +2807,8 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
ContractingPartyName = x.ContractingPartyName, ContractingPartyName = x.ContractingPartyName,
MediaCount = x.MediaCount, MediaCount = x.MediaCount,
Description = x.Description, Description = x.Description,
IsDoneRequest = x.IsDoneRequest IsDoneRequest = x.IsDoneRequest,
HasRequest = x.IsCancelRequest || x.RequestTime || x.IsDoneRequest
}); });
if (!string.IsNullOrWhiteSpace(searchModel.StartDate) && !string.IsNullOrWhiteSpace(searchModel.EndDate)) if (!string.IsNullOrWhiteSpace(searchModel.StartDate) && !string.IsNullOrWhiteSpace(searchModel.EndDate))
{ {
@@ -2553,8 +2877,10 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
} }
var orderResult = result.OrderByDescending(x => x.IsCancel ? 0 : 1).ThenBy(x => x.IsDone ? 1 : 0) var orderResult = result.OrderBy(x => x.IsDone || x.IsCancel)
.ThenBy(x => x.EndTaskDateGE); .ThenByDescending(x => x.EndTaskDateGE <= today.AddDays(1) && !x.RequestTime)
.ThenByDescending(x => x.RequestTime)
.ThenBy(x => x.EndTaskDateGE); // مرتب‌سازی داخلی بر اساس تاریخ
var final = orderResult.Skip(searchModel.PageIndex).Take(30).ToList(); var final = orderResult.Skip(searchModel.PageIndex).Take(30).ToList();
@@ -2588,7 +2914,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
MediaCount = x.MediaCount, MediaCount = x.MediaCount,
SelfName = x.SelfName, SelfName = x.SelfName,
Description = x.Description, Description = x.Description,
IsDoneRequest = x.IsDoneRequest IsDoneRequest = x.IsDoneRequest,
}).ToList(); }).ToList();
@@ -2616,7 +2942,7 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
AcceptedTimeRequest = x.AcceptedTimeRequest, AcceptedTimeRequest = x.AcceptedTimeRequest,
IsCancelRequest = x.IsCancelRequest, IsCancelRequest = x.IsCancelRequest,
ContractingPartyName = x.ContractingPartyName, ContractingPartyName = x.ContractingPartyName,
Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel), Color = x.IsDone ? "green" : SetTasksColors(x.EndTaskDateGE, x.IsCancel,x.RequestTime),
MediaCount = x.MediaCount, MediaCount = x.MediaCount,
HasAttachment = x.MediaCount > 0, HasAttachment = x.MediaCount > 0,
SelfName = x.SelfName, SelfName = x.SelfName,
@@ -2675,6 +3001,8 @@ public class TaskRepository : RepositoryBase<long, Tasks>, ITaskRepository
AssignedName = "-", AssignedName = "-",
AssignedPositionValue = 0 AssignedPositionValue = 0
}, },
HasRequest = x.IsCancelRequest || x.RequestTime || x.IsDoneRequest
}).ToList(); }).ToList();
return final; return final;
} }

View File

@@ -0,0 +1,69 @@
using System.Linq;
using System.Threading.Tasks;
using _0_Framework.Application;
using _0_Framework.InfraStructure;
using AccountManagement.Application.Contracts.Media;
using AccountManagement.Application.Contracts.Task;
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,
Count = taskSchedule.Type == TaskScheduleType.Limited ? taskSchedule.Count : "نامحدود",
FirstEndTaskDate = firstTaskDetails.Assigns.FirstOrDefault()?.EndTaskDate.ToFarsi() ?? "",
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

@@ -0,0 +1,55 @@
using System;
using System.IO;
using System.Linq;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.AdminMonthlyOverview;
using Microsoft.AspNetCore.JsonPatch.Operations;
namespace Company.Domain.AdminMonthlyOverviewAgg;
public class AdminMonthlyOverview:EntityBase
{
public AdminMonthlyOverview(long workshopId, int month, int year, AdminMonthlyOverviewStatus status)
{
WorkshopId = workshopId;
Month = month;
Year = year;
Status = status;
}
public long WorkshopId { get; set; }
public int Month { get; set; }
public int Year { get; set; }
public AdminMonthlyOverviewStatus Status { get; set; }
public void Next()
{
var maxValue = Enum.GetValues(typeof(AdminMonthlyOverviewStatus))
.Cast<AdminMonthlyOverviewStatus>()
.Max();
if (Status >= maxValue)
{
throw new InvalidDataException("تغییر وضعیت وارد شده نامعتبر است");
}
Status += 1;
}
public void Back()
{
var minValue = Enum.GetValues(typeof(AdminMonthlyOverviewStatus))
.Cast<AdminMonthlyOverviewStatus>()
.Min();
if (Status <= minValue)
{
throw new InvalidDataException("تغییر وضعیت وارد شده نامعتبر است");
}
Status -= 1;
}
public void SetStatus(AdminMonthlyOverviewStatus status)
{
Status = status;
}
}

View File

@@ -0,0 +1,12 @@
using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.AdminMonthlyOverview;
namespace Company.Domain.AdminMonthlyOverviewAgg;
public interface IAdminMonthlyOverviewRepository:IRepository<long, AdminMonthlyOverview>
{
Task<List<AdminMonthlyOverviewListViewModel>> GetWorkshopStatus(AdminMonthlyOverviewSearchModel searchModel);
Task<AdminMonthlyOverViewCounterVm> GetCounter(int year, int month, long accountId);
}

View File

@@ -1,6 +1,11 @@
using System; using System;
using System.Collections;
using System.Collections.Generic;
using _0_Framework.Application; using _0_Framework.Application;
using _0_Framework.Domain; using _0_Framework.Domain;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
using Company.Domain.CheckoutAgg.ValueObjects;
using Company.Domain.CustomizeCheckoutAgg.ValueObjects;
using Company.Domain.WorkshopAgg; using Company.Domain.WorkshopAgg;
namespace Company.Domain.CheckoutAgg; namespace Company.Domain.CheckoutAgg;
@@ -21,7 +26,11 @@ public class Checkout : EntityBase
double salaryAidDeduction, double absenceDeduction, string sumOfWorkingDays double salaryAidDeduction, double absenceDeduction, string sumOfWorkingDays
, string archiveCode, string personnelCode, , string archiveCode, string personnelCode,
string totalClaims, string totalDeductions, double totalPayment, string signature, double marriedAllowance, bool leaveCheckout, string totalClaims, string totalDeductions, double totalPayment, string signature, double marriedAllowance, bool leaveCheckout,
double creditLeaves, double absencePeriod, double averageHoursPerDay, bool hasRollCall, string overTimeWorkvalue, string overNightWorkValue, string fridayWorkValue, string rotatingShifValue, string absenceValue, string totalDayOfLeaveCompute, string totalDayOfYearsCompute, string totalDayOfBunosesCompute) double creditLeaves, double absencePeriod, double averageHoursPerDay, bool hasRollCall, string overTimeWorkvalue,
string overNightWorkValue, string fridayWorkValue, string rotatingShifValue, string absenceValue,
string totalDayOfLeaveCompute, string totalDayOfYearsCompute, string totalDayOfBunosesCompute,
ICollection<CheckoutLoanInstallment> loanInstallments,
ICollection<CheckoutSalaryAid> salaryAids,CheckoutRollCall checkoutRollCall)
{ {
EmployeeFullName = employeeFullName; EmployeeFullName = employeeFullName;
FathersName = fathersName; FathersName = fathersName;
@@ -78,6 +87,9 @@ public class Checkout : EntityBase
TotalDayOfLeaveCompute = totalDayOfLeaveCompute; TotalDayOfLeaveCompute = totalDayOfLeaveCompute;
TotalDayOfYearsCompute = totalDayOfYearsCompute; TotalDayOfYearsCompute = totalDayOfYearsCompute;
TotalDayOfBunosesCompute = totalDayOfBunosesCompute; TotalDayOfBunosesCompute = totalDayOfBunosesCompute;
LoanInstallments = loanInstallments;
SalaryAids = salaryAids;
CheckoutRollCall = checkoutRollCall;
} }
public string EmployeeFullName { get; private set; } public string EmployeeFullName { get; private set; }
@@ -181,6 +193,15 @@ public class Checkout : EntityBase
/// </summary> /// </summary>
public string TotalDayOfBunosesCompute { get; private set; } public string TotalDayOfBunosesCompute { get; private set; }
#region valueObjects
public ICollection<CheckoutLoanInstallment> LoanInstallments { get; set; } = [];
public ICollection<CheckoutSalaryAid> SalaryAids { get; set; } = [];
public CheckoutRollCall CheckoutRollCall { get; private set; }
#endregion
public Workshop Workshop { get; set; } public Workshop Workshop { get; set; }
//public WorkingHours WorkingHours { get; set; } //public WorkingHours WorkingHours { get; set; }
@@ -278,4 +299,161 @@ public class Checkout : EntityBase
this.TotalDeductions = totalDeductions; this.TotalDeductions = totalDeductions;
this.TotalPayment = totalPayment; this.TotalPayment = totalPayment;
} }
public void SetSalaryAid(ICollection<CheckoutSalaryAid> salaryAids,double salaryAidAmount)
{
SalaryAids = salaryAids;
SalaryAidDeduction = salaryAidAmount;
}
public void SetLoanInstallment(ICollection<CheckoutLoanInstallment> lonaInstallments, double installmentsAmount)
{
LoanInstallments = lonaInstallments;
InstallmentDeduction = installmentsAmount;
}
public void SetCheckoutRollCall(CheckoutRollCall checkoutRollCall)
{
CheckoutRollCall = checkoutRollCall;
}
}
public class CheckoutRollCall
{
private CheckoutRollCall(){}
public CheckoutRollCall(TimeSpan totalMandatoryTimeSpan, TimeSpan totalPresentTimeSpan, TimeSpan totalBreakTimeSpan,
TimeSpan totalWorkingTimeSpan, TimeSpan totalPaidLeaveTmeSpan, TimeSpan totalSickLeaveTimeSpan,
ICollection<CheckoutRollCallDay> rollCallDaysCollection)
{
TotalMandatoryTimeSpan = totalMandatoryTimeSpan;
TotalPresentTimeSpan = totalPresentTimeSpan;
TotalBreakTimeSpan = totalBreakTimeSpan;
TotalWorkingTimeSpan = totalWorkingTimeSpan;
TotalPaidLeaveTmeSpan = totalPaidLeaveTmeSpan;
TotalSickLeaveTimeSpan = totalSickLeaveTimeSpan;
RollCallDaysCollection = rollCallDaysCollection;
}
/// <summary>
/// مجموع ساعت موظفی
/// </summary>
public TimeSpan TotalMandatoryTimeSpan { get; private set; }
/// <summary>
/// مجموع ساعت حضور
/// </summary>
public TimeSpan TotalPresentTimeSpan { get; private set; }
/// <summary>
/// مجموع ساعت استراحت
/// </summary>
public TimeSpan TotalBreakTimeSpan { get; private set; }
/// <summary>
/// مجموع ساعت کارکرد
/// </summary>
public TimeSpan TotalWorkingTimeSpan { get; private set; }
/// <summary>
/// مجموع ساعت مرخصی استحقاقی
/// </summary>
public TimeSpan TotalPaidLeaveTmeSpan { get; private set; }
/// <summary>
/// مجموع ساعت مرخصی استعلاجی
/// </summary>
public TimeSpan TotalSickLeaveTimeSpan { get; private set; }
/// <summary>
/// روز های حضور غیاب
/// </summary>
public ICollection<CheckoutRollCallDay> RollCallDaysCollection { get; private set; }
}
public class CheckoutRollCallDay
{
private CheckoutRollCallDay(){}
public CheckoutRollCallDay(DateTime date, string firstStartDate, string firstEndDate,
string secondStartDate, string secondEndDate, TimeSpan breakTimeSpan,
bool isSliced, TimeSpan workingTimeSpan, bool isAbsent, bool isFriday,
bool isHoliday, string leaveType)
{
Date = date;
FirstStartDate = firstStartDate;
FirstEndDate = firstEndDate;
SecondStartDate = secondStartDate;
SecondEndDate = secondEndDate;
BreakTimeSpan = breakTimeSpan;
IsSliced = isSliced;
WorkingTimeSpan = workingTimeSpan;
IsAbsent = isAbsent;
IsFriday = isFriday;
IsHoliday = isHoliday;
LeaveType = leaveType;
}
public long Id { get; set; }
/// <summary>
/// تاریخ
/// </summary>
public DateTime Date { get; private set; }
/// <summary>
/// ورود اول
/// </summary>
public string FirstStartDate { get; private set; }
/// <summary>
/// خروج اول
/// </summary>
public string FirstEndDate { get; private set; }
/// <summary>
/// ورود دوم
/// </summary>
public string SecondStartDate { get; private set; }
/// <summary>
/// خروج دوم
/// </summary>
public string SecondEndDate { get; private set; }
/// <summary>
/// ساعت استراحت
/// </summary>
public TimeSpan BreakTimeSpan { get; private set; }
/// <summary>
/// مقدار زمان کارکرد
/// </summary>
public TimeSpan WorkingTimeSpan { get; private set; }
/// <summary>
/// آیا منقطع است؟
/// </summary>
public bool IsSliced { get; private set; }
/// <summary>
/// آیا غیبت است
/// </summary>
public bool IsAbsent { get; private set; }
/// <summary>
/// آیا جمعه است
/// </summary>
public bool IsFriday { get; private set; }
/// <summary>
/// آیا تعطیل رسمی است
/// </summary>
public bool IsHoliday { get; private set; }
/// <summary>
/// نوع مرخصی - درصورت نداشتن مرخصی مقدارش null میباشد
/// </summary>
public string LeaveType { get; private set; }
public long CheckoutId { get; set; }
} }

View File

@@ -10,9 +10,36 @@ namespace Company.Domain.CheckoutAgg;
public interface ICheckoutRepository : IRepository<long, Checkout> public interface ICheckoutRepository : IRepository<long, Checkout>
{ {
/// <summary>
/// چک میکند که آیا پرسنل در سال و ماه درخواستی در این کارگاه فیش حقوقی دارد یا خیر
/// </summary>
/// <param name="workshopId"></param>
/// <param name="employeId"></param>
/// <param name="سال به صورت رشته عددی"></param>
/// <param name="ماه بصورت رشته عددی"></param>
/// <returns></returns>
(bool hasChekout, double FamilyAlloance, double OverTimePay) HasCheckout(long workshopId, long employeId,
string year, string month);
EditCheckout GetDetails(long id); EditCheckout GetDetails(long id);
void CreateCkeckout(Checkout command); Task CreateCkeckout(Checkout command);
/// <summary>
/// لود لیست اولیه جهت ایجاد فیش حقوقی
/// </summary>
/// <param name="workshopId"></param>
/// <param name="employeeId"></param>
/// <param name="year"></param>
/// <param name="month"></param>
/// <param name="contractStart"></param>
/// <param name="contractEnd"></param>
/// <returns></returns>
/// <exception cref="NotImplementedException"></exception>
Task<CreateCheckoutListViewModel> GetContractResultToCreateCheckout(long workshopId, long employeeId, string year,
string month,
string contractStart, string contractEnd);
//void CreateCkeckout(Checkout command);
Task<List<CheckoutViewModel>> Search(CheckoutSearchModel searchModel); Task<List<CheckoutViewModel>> Search(CheckoutSearchModel searchModel);

View File

@@ -0,0 +1,25 @@
using _0_Framework.Application;
namespace Company.Domain.CheckoutAgg.ValueObjects;
public class CheckoutLoanInstallment
{
public CheckoutLoanInstallment(string amountForMonth, string month, string year, IsActive isActive, string loanRemaining, string loanAmount, long entityId)
{
AmountForMonth = amountForMonth;
Month = month;
Year = year;
IsActive = isActive;
LoanRemaining = loanRemaining;
LoanAmount = loanAmount;
EntityId = entityId;
}
public string AmountForMonth { get; private set; }
public string Month { get; private set; }
public string Year { get; private set; }
public string LoanRemaining { get; set; }
public IsActive IsActive { get; private set; }
public string LoanAmount { get; set; }
public long EntityId { get; set; }
}

View File

@@ -0,0 +1,24 @@
using System;
using AccountManagement.Domain.AccountAgg;
namespace Company.Domain.CheckoutAgg.ValueObjects;
public class CheckoutSalaryAid
{
public CheckoutSalaryAid(string amount, DateTime salaryAidDateTime, string salaryAidDateTimeFa, DateTime calculationDateTime, string calculationDateTimeFa, long entityId)
{
Amount = amount;
SalaryAidDateTime = salaryAidDateTime;
SalaryAidDateTimeFa = salaryAidDateTimeFa;
CalculationDateTime = calculationDateTime;
CalculationDateTimeFa = calculationDateTimeFa;
EntityId = entityId;
}
public string Amount { get; private set; }
public DateTime SalaryAidDateTime { get; private set; }
public string SalaryAidDateTimeFa { get; private set; }
public DateTime CalculationDateTime { get; private set; }
public string CalculationDateTimeFa { get; private set; }
public long EntityId { get; set; }
}

View File

@@ -1,4 +1,4 @@
<Project Sdk="Microsoft.NET.Sdk"> <Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup> <PropertyGroup>
<TargetFramework>net8.0</TargetFramework> <TargetFramework>net8.0</TargetFramework>
@@ -14,4 +14,8 @@
<ProjectReference Include="..\CompanyManagment.App.Contracts\CompanyManagment.App.Contracts.csproj" /> <ProjectReference Include="..\CompanyManagment.App.Contracts\CompanyManagment.App.Contracts.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup>
<Folder Include="CheckoutAgg\ValueObjects\" />
</ItemGroup>
</Project> </Project>

View File

@@ -1,12 +1,13 @@
using _0_Framework.Application; using System;
using System.Collections.Generic;
using System.Linq;
using _0_Framework.Application;
using _0_Framework.Domain; using _0_Framework.Domain;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
using _0_Framework.Domain.CustomizeCheckoutShared.ValueObjects;
using Company.Domain.CustomizeCheckoutAgg.ValueObjects; using Company.Domain.CustomizeCheckoutAgg.ValueObjects;
using Company.Domain.EmployeeAgg; using Company.Domain.EmployeeAgg;
using Company.Domain.WorkshopAgg; using Company.Domain.WorkshopAgg;
using System;
using System.Collections.Generic;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
using Microsoft.AspNetCore.Authentication.Cookies;
namespace Company.Domain.CustomizeCheckoutAgg; namespace Company.Domain.CustomizeCheckoutAgg;
@@ -16,8 +17,7 @@ namespace Company.Domain.CustomizeCheckoutAgg;
public class CustomizeCheckout : EntityBase public class CustomizeCheckout : EntityBase
{ {
private CustomizeCheckout() private CustomizeCheckout()
{ { }
}
public CustomizeCheckout(DateTime contractStart, DateTime contractEnd, long employeeId, string employeeFName, public CustomizeCheckout(DateTime contractStart, DateTime contractEnd, long employeeId, string employeeFName,
string employeeLName, DateTime employeeDateOfBirth, string employeeLName, DateTime employeeDateOfBirth,
string employeeNationalCode, string workshopFullName, long workshopId, long? contractId, string employeeNationalCode, string workshopFullName, long workshopId, long? contractId,
@@ -32,7 +32,8 @@ public class CustomizeCheckout : EntityBase
ICollection<CustomizeCheckoutLoanInstallments> customizeCheckoutLoanInstallments, ICollection<CustomizeCheckoutLoanInstallments> customizeCheckoutLoanInstallments,
ICollection<CustomizeCheckoutSalaryAid> customizeCheckoutSalaryAids, ICollection<CustomizeCheckoutSalaryAid> customizeCheckoutSalaryAids,
ICollection<CustomizeCheckoutReward> customizeCheckoutRewards, TimeSpan lateToWorkValue, double settingSalary, ICollection<CustomizeCheckoutReward> customizeCheckoutRewards, TimeSpan lateToWorkValue, double settingSalary,
double dailyWage, WorkshopShiftStatus shiftStatus) double dailyWage, WorkshopShiftStatus shiftStatus, IrregularShift irregularShift,
ICollection<CustomizeRotatingShift> customizeRotatingShifts, ICollection<CustomizeCheckoutRegularShift> employeeSettingsShifts)
{ {
YearInt = Convert.ToInt32(contractStart.ToFarsi().Substring(0, 4)); YearInt = Convert.ToInt32(contractStart.ToFarsi().Substring(0, 4));
MonthInt = Convert.ToInt32(contractStart.ToFarsi().Substring(5, 2)); MonthInt = Convert.ToInt32(contractStart.ToFarsi().Substring(5, 2));
@@ -79,6 +80,9 @@ public class CustomizeCheckout : EntityBase
SettingSalary = settingSalary; SettingSalary = settingSalary;
DailyWage = dailyWage; DailyWage = dailyWage;
ShiftStatus = shiftStatus; ShiftStatus = shiftStatus;
IrregularShift = irregularShift;
CustomizeRotatingShifts = customizeRotatingShifts;
RegularShifts = employeeSettingsShifts;
} }
@@ -283,6 +287,12 @@ public class CustomizeCheckout : EntityBase
public ICollection<CustomizeCheckoutSalaryAid> CustomizeCheckoutSalaryAids { get; set; } public ICollection<CustomizeCheckoutSalaryAid> CustomizeCheckoutSalaryAids { get; set; }
public ICollection<CustomizeCheckoutReward> CustomizeCheckoutRewards { 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 #endregion
#region Relations #region Relations
@@ -292,4 +302,78 @@ public class CustomizeCheckout : EntityBase
#endregion #endregion
public void SetValueObjects(ICollection<CustomizeCheckoutFine> checkoutFines,
ICollection<CustomizeCheckoutLoanInstallments> customizeCheckoutLoanInstallments,
ICollection<CustomizeCheckoutSalaryAid> customizeCheckoutSalaryAids,
ICollection<CustomizeCheckoutReward> customizeCheckoutRewards)
{
CheckoutFines = checkoutFines;
CustomizeCheckoutLoanInstallments = customizeCheckoutLoanInstallments;
CustomizeCheckoutSalaryAids = customizeCheckoutSalaryAids;
CustomizeCheckoutRewards = customizeCheckoutRewards;
}
public void SetRewards(ICollection<CustomizeCheckoutReward> rewards)
{
var previousTotalAmount = CustomizeCheckoutRewards.Sum(x => x.Amount.MoneyToDouble());
var newTotalAmount = rewards.Sum(x => x.Amount.MoneyToDouble());
RewardPay = newTotalAmount;
IncreaseTotalPayment(previousTotalAmount, newTotalAmount);
RecalculateTotalClaims(previousTotalAmount, newTotalAmount);
CustomizeCheckoutRewards = rewards;
}
public void SetSalaryAids(ICollection<CustomizeCheckoutSalaryAid> salaryAids)
{
var previousTotalAmount = CustomizeCheckoutSalaryAids.Sum(x => x.Amount.MoneyToDouble());
var newTotalAmount = salaryAids.Sum(x => x.Amount.MoneyToDouble());
SalaryAidDeduction = newTotalAmount;
ReduceTotalPayment(previousTotalAmount, newTotalAmount);
RecalculateTotalDeduction(previousTotalAmount, newTotalAmount);
CustomizeCheckoutSalaryAids = salaryAids;
}
public void SetFines(ICollection<CustomizeCheckoutFine> fines)
{
var previousTotalAmount = CheckoutFines.Sum(x => x.Amount.MoneyToDouble());
var newTotalAmount = fines.Sum(x => x.Amount.MoneyToDouble());
FineDeduction = newTotalAmount;
ReduceTotalPayment(previousTotalAmount, newTotalAmount);
RecalculateTotalDeduction(previousTotalAmount, newTotalAmount);
CheckoutFines = fines;
}
public void SetLoanInstallment(ICollection<CustomizeCheckoutLoanInstallments> installments)
{
var previousTotalAmount = CustomizeCheckoutLoanInstallments.Sum(x => x.AmountForMonth.MoneyToDouble());
var newTotalAmount = installments.Sum(x => x.AmountForMonth.MoneyToDouble());
InstallmentDeduction = newTotalAmount;
ReduceTotalPayment(previousTotalAmount, newTotalAmount);
RecalculateTotalDeduction(previousTotalAmount, newTotalAmount);
CustomizeCheckoutLoanInstallments = installments;
}
private void RecalculateTotalClaims(double previousTotalAmount, double newTotalAmount)
{
TotalClaims = (TotalClaims.MoneyToDouble() - previousTotalAmount + newTotalAmount).ToMoney();
}
private void RecalculateTotalDeduction(double previousTotalAmount, double newTotalAmount)
{
TotalDeductions = (TotalDeductions.MoneyToDouble() - previousTotalAmount + newTotalAmount).ToMoney();
}
private void ReduceTotalPayment(double previousAmount, double newAmount)
{
TotalPayment = TotalPayment + previousAmount - newAmount;
}
private void IncreaseTotalPayment(double previousAmount, double newAmount)
{
TotalPayment = TotalPayment - previousAmount + newAmount;
}
} }

View File

@@ -3,6 +3,7 @@ using _0_Framework.Domain;
using CompanyManagment.App.Contracts.CustomizeCheckout; using CompanyManagment.App.Contracts.CustomizeCheckout;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Threading.Tasks;
namespace Company.Domain.CustomizeCheckoutAgg namespace Company.Domain.CustomizeCheckoutAgg
{ {
@@ -14,5 +15,12 @@ namespace Company.Domain.CustomizeCheckoutAgg
void RemoveEmployeeCustomizeCheckoutInDates(long workshopId, long employeeId, DateTime startOfMonth, DateTime endOfMonth); void RemoveEmployeeCustomizeCheckoutInDates(long workshopId, long employeeId, DateTime startOfMonth, DateTime endOfMonth);
IEnumerable<CustomizeCheckout> GetRange(long workshopId, List<long> ids); IEnumerable<CustomizeCheckout> GetRange(long workshopId, List<long> ids);
void RemoveRange(IEnumerable<CustomizeCheckout> entities); void RemoveRange(IEnumerable<CustomizeCheckout> entities);
List<CustomizeCheckout> GetByWorkshopIdEmployeeIdInDates(long workshopId, long employeeId, DateTime startDate, DateTime endDate);
Task<CustomizeCheckout> GetByWorkshopIdEmployeeIdMonthYear(long workshopId, long employeeId, int year,
int month);
(bool Checkout, bool CustomizeCheckout, bool CustomizeCheckoutTemp) ValidateExistsCheckouts(
DateTime startDate, DateTime endDate, long workshopId, List<long> employeeId);
} }
} }

View File

@@ -5,7 +5,7 @@ namespace Company.Domain.CustomizeCheckoutAgg.ValueObjects;
public record CustomizeCheckoutFine public record CustomizeCheckoutFine
{ {
public CustomizeCheckoutFine(string title, string amount, string fineDateFa, DateTime fineDateGr, IsActive isActive, DateTime creationDate) public CustomizeCheckoutFine(string title, string amount, string fineDateFa, DateTime fineDateGr, IsActive isActive, DateTime creationDate, long entityId)
{ {
Title = title; Title = title;
Amount = amount; Amount = amount;
@@ -13,6 +13,7 @@ public record CustomizeCheckoutFine
FineDateGr = fineDateGr; FineDateGr = fineDateGr;
IsActive = isActive; IsActive = isActive;
CreationDate = creationDate; CreationDate = creationDate;
EntityId = entityId;
} }
public string Title { get; private set; } public string Title { get; private set; }
@@ -21,4 +22,5 @@ public record CustomizeCheckoutFine
public DateTime FineDateGr { get; private set; } public DateTime FineDateGr { get; private set; }
public IsActive IsActive { get; private set; } public IsActive IsActive { get; private set; }
public DateTime CreationDate { get; private set; } public DateTime CreationDate { get; private set; }
public long EntityId { get; set; }
} }

View File

@@ -5,7 +5,7 @@ namespace Company.Domain.CustomizeCheckoutAgg.ValueObjects;
public class CustomizeCheckoutLoanInstallments public class CustomizeCheckoutLoanInstallments
{ {
public CustomizeCheckoutLoanInstallments(string amountForMonth, string month, string year, IsActive isActive, string loanRemaining, string loanAmount) public CustomizeCheckoutLoanInstallments(string amountForMonth, string month, string year, IsActive isActive, string loanRemaining, string loanAmount, long entityId)
{ {
AmountForMonth = amountForMonth; AmountForMonth = amountForMonth;
Month = month; Month = month;
@@ -13,12 +13,16 @@ public class CustomizeCheckoutLoanInstallments
IsActive = isActive; IsActive = isActive;
LoanRemaining = loanRemaining; LoanRemaining = loanRemaining;
LoanAmount = loanAmount; LoanAmount = loanAmount;
EntityId = entityId;
} }
public string AmountForMonth { get; private set; } public string AmountForMonth { get; private set; }
public string Month { get; private set; } public string Month { get; private set; }
public string Year { get; private set; } public string Year { get; private set; }
public string LoanRemaining { get; set; } public string LoanRemaining { get; set; }
public string LoanAmount { get; set; }
public IsActive IsActive { get; private set; } public IsActive IsActive { get; private set; }
public string LoanAmount { get; set; }
public long EntityId { 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

@@ -5,7 +5,7 @@ namespace Company.Domain.CustomizeCheckoutAgg.ValueObjects;
public class CustomizeCheckoutReward public class CustomizeCheckoutReward
{ {
public CustomizeCheckoutReward(string amount, string description, DateTime grantDate, string grantDateFa, IsActive isActive, string title) public CustomizeCheckoutReward(string amount, string description, DateTime grantDate, string grantDateFa, IsActive isActive, string title, long entityId)
{ {
Amount = amount; Amount = amount;
Description = description; Description = description;
@@ -13,6 +13,7 @@ public class CustomizeCheckoutReward
GrantDateFa = grantDateFa; GrantDateFa = grantDateFa;
IsActive = isActive; IsActive = isActive;
Title = title; Title = title;
EntityId = entityId;
} }
/// <summary> /// <summary>
@@ -39,5 +40,7 @@ public class CustomizeCheckoutReward
public IsActive IsActive { get; private set; } public IsActive IsActive { get; private set; }
public long EntityId { get; set; }
} }

View File

@@ -4,14 +4,23 @@ namespace Company.Domain.CustomizeCheckoutAgg.ValueObjects;
public class CustomizeCheckoutSalaryAid public class CustomizeCheckoutSalaryAid
{ {
public CustomizeCheckoutSalaryAid(string amount, DateTime salaryAidDateTime, string salaryAidDateTimeFa) public CustomizeCheckoutSalaryAid(string amount, DateTime salaryAidDateTime, string salaryAidDateTimeFa,DateTime calculationDateTime,string calculationDateTimeFa, long entityId)
{ {
Amount = amount; Amount = amount;
SalaryAidDateTime = salaryAidDateTime; SalaryAidDateTime = salaryAidDateTime;
SalaryAidDateTimeFa = salaryAidDateTimeFa; SalaryAidDateTimeFa = salaryAidDateTimeFa;
CalculationDateTime = calculationDateTime;
CalculationDateTimeFa = calculationDateTimeFa;
EntityId = entityId;
} }
public string Amount { get; private set; } public string Amount { get; private set; }
public DateTime SalaryAidDateTime { get; private set; } public DateTime SalaryAidDateTime { get; private set; }
public string SalaryAidDateTimeFa { get; private set; } public string SalaryAidDateTimeFa { get; private set; }
public DateTime CalculationDateTime { get; private set; }
public string CalculationDateTimeFa { get; private set; }
public long EntityId { get; set; }
} }

View File

@@ -7,6 +7,8 @@ using System;
using System.Collections.Generic; using System.Collections.Generic;
using Company.Domain.CustomizeCheckoutTempAgg.ValueObjects; using Company.Domain.CustomizeCheckoutTempAgg.ValueObjects;
using _0_Framework.Domain.CustomizeCheckoutShared.Enums; using _0_Framework.Domain.CustomizeCheckoutShared.Enums;
using _0_Framework.Domain.CustomizeCheckoutShared.ValueObjects;
using System.Linq;
namespace Company.Domain.CustomizeCheckoutTempAgg; namespace Company.Domain.CustomizeCheckoutTempAgg;
@@ -34,7 +36,8 @@ public class CustomizeCheckoutTemp : EntityBase
ICollection<CustomizeCheckoutTempLoanInstallments> customizeCheckoutLoanInstallments, ICollection<CustomizeCheckoutTempLoanInstallments> customizeCheckoutLoanInstallments,
ICollection<CustomizeCheckoutTempSalaryAid> customizeCheckoutSalaryAids, ICollection<CustomizeCheckoutTempSalaryAid> customizeCheckoutSalaryAids,
ICollection<CustomizeCheckoutTempReward> customizeCheckoutRewards, ICollection<CustomizeCheckoutTempReward> customizeCheckoutRewards,
TimeSpan lateToWorkValue, double settingSalary, double dailyWage, WorkshopShiftStatus shiftStatus) TimeSpan lateToWorkValue, double settingSalary, double dailyWage, WorkshopShiftStatus shiftStatus, IrregularShift irregularShift,
ICollection<CustomizeRotatingShift> customizeRotatingShifts, ICollection<CustomizeCheckoutRegularShift> employeeSettingsShifts)
{ {
YearInt = Convert.ToInt32(contractStart.ToFarsi().Substring(0, 4)); YearInt = Convert.ToInt32(contractStart.ToFarsi().Substring(0, 4));
MonthInt = Convert.ToInt32(contractStart.ToFarsi().Substring(5, 2)); MonthInt = Convert.ToInt32(contractStart.ToFarsi().Substring(5, 2));
@@ -81,6 +84,9 @@ public class CustomizeCheckoutTemp : EntityBase
SettingSalary = settingSalary; SettingSalary = settingSalary;
DailyWage = dailyWage; DailyWage = dailyWage;
ShiftStatus = shiftStatus; ShiftStatus = shiftStatus;
IrregularShift = irregularShift;
CustomizeRotatingShifts = customizeRotatingShifts;
RegularShifts = employeeSettingsShifts;
} }
#region Getters #region Getters
@@ -114,6 +120,10 @@ public class CustomizeCheckoutTemp : EntityBase
public ICollection<CustomizeCheckoutTempSalaryAid> CustomizeCheckoutSalaryAids { get; set; } public ICollection<CustomizeCheckoutTempSalaryAid> CustomizeCheckoutSalaryAids { get; set; }
public ICollection<CustomizeCheckoutTempReward> CustomizeCheckoutRewards { 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 #endregion
@@ -296,4 +306,75 @@ public class CustomizeCheckoutTemp : EntityBase
#endregion #endregion
public void SetValueObjects(ICollection<CustomizeCheckoutTempFine> checkoutFines,
ICollection<CustomizeCheckoutTempLoanInstallments> customizeCheckoutLoanInstallments,
ICollection<CustomizeCheckoutTempSalaryAid> customizeCheckoutSalaryAids,
ICollection<CustomizeCheckoutTempReward> customizeCheckoutRewards)
{
CheckoutFines = checkoutFines;
CustomizeCheckoutLoanInstallments = customizeCheckoutLoanInstallments;
CustomizeCheckoutSalaryAids = customizeCheckoutSalaryAids;
CustomizeCheckoutRewards = customizeCheckoutRewards;
}
public void SetRewards(ICollection<CustomizeCheckoutTempReward> rewards)
{
var previousTotalAmount = CustomizeCheckoutRewards.Sum(x => x.Amount.MoneyToDouble());
var newTotalAmount = rewards.Sum(x => x.Amount.MoneyToDouble());
RewardPay = newTotalAmount;
IncreaseTotalPayment(previousTotalAmount,newTotalAmount);
RecalculateTotalClaims(previousTotalAmount, newTotalAmount);
CustomizeCheckoutRewards = rewards;
}
public void SetSalaryAids(ICollection<CustomizeCheckoutTempSalaryAid> salaryAids)
{
var previousTotalAmount = CustomizeCheckoutSalaryAids.Sum(x => x.Amount.MoneyToDouble());
var newTotalAmount = salaryAids.Sum(x => x.Amount.MoneyToDouble());
SalaryAidDeduction = newTotalAmount;
ReduceTotalPayment(previousTotalAmount,newTotalAmount);
RecalculateTotalDeduction(previousTotalAmount, newTotalAmount);
CustomizeCheckoutSalaryAids = salaryAids;
}
public void SetFines(ICollection<CustomizeCheckoutTempFine> fines)
{
var previousTotalAmount = CheckoutFines.Sum(x => x.Amount.MoneyToDouble());
var newTotalAmount = fines.Sum(x => x.Amount.MoneyToDouble());
FineDeduction = newTotalAmount;
ReduceTotalPayment(previousTotalAmount,newTotalAmount);
RecalculateTotalDeduction(previousTotalAmount, newTotalAmount);
CheckoutFines = fines;
}
public void SetLoanInstallment(ICollection<CustomizeCheckoutTempLoanInstallments> installments)
{
var previousTotalAmount = CustomizeCheckoutLoanInstallments.Sum(x => x.AmountForMonth.MoneyToDouble());
var newTotalAmount = installments.Sum(x => x.AmountForMonth.MoneyToDouble());
InstallmentDeduction = newTotalAmount;
ReduceTotalPayment(previousTotalAmount,newTotalAmount);
RecalculateTotalDeduction(previousTotalAmount, newTotalAmount);
CustomizeCheckoutLoanInstallments = installments;
}
private void RecalculateTotalClaims(double previousTotalAmount, double newTotalAmount)
{
TotalClaims = (TotalClaims.MoneyToDouble() - previousTotalAmount + newTotalAmount).ToMoney();
}
private void RecalculateTotalDeduction(double previousTotalAmount, double newTotalAmount)
{
TotalDeductions = (TotalDeductions.MoneyToDouble() - previousTotalAmount + newTotalAmount).ToMoney();
}
private void ReduceTotalPayment(double previousAmount, double newAmount)
{
TotalPayment = TotalPayment + previousAmount - newAmount;
}
private void IncreaseTotalPayment(double previousAmount, double newAmount)
{
TotalPayment = TotalPayment - previousAmount + newAmount;
}
} }

View File

@@ -4,6 +4,7 @@ using Company.Domain.CustomizeCheckoutAgg;
using CompanyManagment.App.Contracts.CustomizeCheckout; using CompanyManagment.App.Contracts.CustomizeCheckout;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Threading.Tasks;
namespace Company.Domain.CustomizeCheckoutTempAgg namespace Company.Domain.CustomizeCheckoutTempAgg
{ {
@@ -19,5 +20,7 @@ namespace Company.Domain.CustomizeCheckoutTempAgg
IEnumerable<CustomizeCheckoutTemp> GetRange(long workshopId, List<long> ids); IEnumerable<CustomizeCheckoutTemp> GetRange(long workshopId, List<long> ids);
void RemoveRange(IEnumerable<CustomizeCheckoutTemp> entities); void RemoveRange(IEnumerable<CustomizeCheckoutTemp> entities);
List<CustomizeCheckoutTemp> GetByWorkshopIdEmployeeIdInDates(long workshopId, long employeeId, DateTime startDate, DateTime endDate);
Task<CustomizeCheckoutTemp> GetByWorkshopIdEmployeeIdInDate(long workshopId, long employeeId, DateTime inDate);
} }
} }

View File

@@ -4,14 +4,23 @@ namespace Company.Domain.CustomizeCheckoutTempAgg.ValueObjects;
public class CustomizeCheckoutTempSalaryAid public class CustomizeCheckoutTempSalaryAid
{ {
public CustomizeCheckoutTempSalaryAid(string amount, DateTime salaryAidDateTime, string salaryAidDateTimeFa) public CustomizeCheckoutTempSalaryAid(string amount, DateTime salaryAidDateTime, string salaryAidDateTimeFa,
DateTime calculationDateTime, string calculationDateTimeFa, long entityId)
{ {
Amount = amount; Amount = amount;
SalaryAidDateTime = salaryAidDateTime; SalaryAidDateTime = salaryAidDateTime;
SalaryAidDateTimeFa = salaryAidDateTimeFa; SalaryAidDateTimeFa = salaryAidDateTimeFa;
CalculationDateTime = calculationDateTime;
CalculationDateTimeFa = calculationDateTimeFa;
EntityId = entityId;
} }
public string Amount { get; private set; } public string Amount { get; private set; }
public DateTime SalaryAidDateTime { get; private set; } public DateTime SalaryAidDateTime { get; private set; }
public string SalaryAidDateTimeFa { get; private set; } public string SalaryAidDateTimeFa { get; private set; }
public DateTime CalculationDateTime { get; private set; }
public string CalculationDateTimeFa { get; private set; }
public long EntityId { get; set; }
} }

View File

@@ -6,7 +6,7 @@ namespace Company.Domain.CustomizeCheckoutTempAgg.ValueObjects;
public record CustomizeCheckoutTempFine public record CustomizeCheckoutTempFine
{ {
public CustomizeCheckoutTempFine(string title, string amount, string fineDateFa, DateTime fineDateGr, IsActive isActive, DateTime creationDate) public CustomizeCheckoutTempFine(string title, string amount, string fineDateFa, DateTime fineDateGr, IsActive isActive, DateTime creationDate, long entityId)
{ {
Title = title; Title = title;
Amount = amount; Amount = amount;
@@ -14,7 +14,7 @@ public record CustomizeCheckoutTempFine
FineDateGr = fineDateGr; FineDateGr = fineDateGr;
IsActive = isActive; IsActive = isActive;
CreationDate = creationDate; CreationDate = creationDate;
EntityId = entityId;
} }
public string Title { get; private set; } public string Title { get; private set; }
public string Amount { get; private set; } public string Amount { get; private set; }
@@ -22,4 +22,6 @@ public record CustomizeCheckoutTempFine
public DateTime FineDateGr { get; private set; } public DateTime FineDateGr { get; private set; }
public IsActive IsActive { get; private set; } public IsActive IsActive { get; private set; }
public DateTime CreationDate { get; private set; } public DateTime CreationDate { get; private set; }
public long EntityId { get; set; }
} }

View File

@@ -4,7 +4,7 @@ namespace Company.Domain.CustomizeCheckoutTempAgg.ValueObjects;
public class CustomizeCheckoutTempLoanInstallments public class CustomizeCheckoutTempLoanInstallments
{ {
public CustomizeCheckoutTempLoanInstallments(string amountForMonth, string month, string year, IsActive isActive, string loanRemaining, string loanAmount) public CustomizeCheckoutTempLoanInstallments(string amountForMonth, string month, string year, IsActive isActive, string loanRemaining, string loanAmount, long entityId)
{ {
AmountForMonth = amountForMonth; AmountForMonth = amountForMonth;
Month = month; Month = month;
@@ -12,6 +12,7 @@ public class CustomizeCheckoutTempLoanInstallments
IsActive = isActive; IsActive = isActive;
LoanRemaining = loanRemaining; LoanRemaining = loanRemaining;
LoanAmount = loanAmount; LoanAmount = loanAmount;
EntityId = entityId;
} }
public string AmountForMonth { get; private set; } public string AmountForMonth { get; private set; }
@@ -20,5 +21,7 @@ public class CustomizeCheckoutTempLoanInstallments
public IsActive IsActive { get; private set; } public IsActive IsActive { get; private set; }
public string LoanRemaining { get; set; } public string LoanRemaining { get; set; }
public string LoanAmount { get; set; } public string LoanAmount { get; set; }
public long EntityId { get; set; }
} }

View File

@@ -5,7 +5,7 @@ namespace Company.Domain.CustomizeCheckoutTempAgg.ValueObjects;
public class CustomizeCheckoutTempReward public class CustomizeCheckoutTempReward
{ {
public CustomizeCheckoutTempReward(string amount, string description, DateTime grantDate, string grantDateFa, IsActive isActive, string title) public CustomizeCheckoutTempReward(string amount, string description, DateTime grantDate, string grantDateFa, IsActive isActive, string title, long entityId)
{ {
Amount = amount; Amount = amount;
Description = description; Description = description;
@@ -13,6 +13,7 @@ public class CustomizeCheckoutTempReward
GrantDateFa = grantDateFa; GrantDateFa = grantDateFa;
IsActive = isActive; IsActive = isActive;
Title = title; Title = title;
EntityId = entityId;
} }
/// <summary> /// <summary>
@@ -37,4 +38,6 @@ public class CustomizeCheckoutTempReward
public IsActive IsActive { get; private set; } public IsActive IsActive { get; private set; }
public string Title { get; set; } public string Title { get; set; }
public long EntityId { get; set; }
} }

View File

@@ -213,6 +213,60 @@ public class CustomizeWorkshopEmployeeSettings : BaseCustomizeEntity
earlyExit.EarlyExitTimeFines.Select(x => new EarlyExitTimeFine(x.Minute, x.FineMoney)) earlyExit.EarlyExitTimeFines.Select(x => new EarlyExitTimeFine(x.Minute, x.FineMoney))
.ToList(), earlyExit.Value); .ToList(), earlyExit.Value);
} }
public void UpdateIsShiftChange()
{
var groupSetting = CustomizeWorkshopGroupSettings;
if (groupSetting == null)
return;
bool isShiftChange;
if (WorkshopShiftStatus == WorkshopShiftStatus.Regular)
{
if (CustomizeWorkshopEmployeeSettingsShifts.All(x => groupSetting.CustomizeWorkshopGroupSettingsShifts.Any(y => x.Equals(y)))
&& WorkshopShiftStatus == groupSetting.WorkshopShiftStatus && FridayWork == groupSetting.FridayWork &&
HolidayWork == groupSetting.HolidayWork && BreakTime == groupSetting.BreakTime)
{
isShiftChange = false;
}
else
{
isShiftChange = true;
}
}
else if (WorkshopShiftStatus == WorkshopShiftStatus.Irregular)
{
if (WorkshopShiftStatus == groupSetting.WorkshopShiftStatus && BreakTime == groupSetting.BreakTime &&
IrregularShift == groupSetting.IrregularShift && FridayWork == groupSetting.FridayWork &&
HolidayWork == groupSetting.HolidayWork)
{
isShiftChange = false;
}
else
{
isShiftChange = true;
}
}
else
{
if (CustomizeRotatingShifts.All(x => groupSetting.CustomizeRotatingShifts.Any(y => x.Equals(y)))
&& WorkshopShiftStatus == groupSetting.WorkshopShiftStatus && FridayWork == groupSetting.FridayWork &&
HolidayWork == groupSetting.HolidayWork && BreakTime == groupSetting.BreakTime)
{
isShiftChange = false;
}
else
{
isShiftChange = true;
}
}
IsShiftChanged = isShiftChange;
}
} }

View File

@@ -15,4 +15,5 @@ public interface ICustomizeWorkshopEmployeeSettingsRepository : IRepository<long
List<CustomizeWorkshopEmployeeSettingsViewModel> GetEmployeeSettingNotInMainGroup(long entityWorkshopId); List<CustomizeWorkshopEmployeeSettingsViewModel> GetEmployeeSettingNotInMainGroup(long entityWorkshopId);
void RemoveByWorkshopIdAndEmployeeId(long workshopId, long employeeId); void RemoveByWorkshopIdAndEmployeeId(long workshopId, long employeeId);
bool CheckEmployeeShiftHasChanged(EditCustomizeEmployeeSettings command);
} }

View File

@@ -219,7 +219,7 @@ public class CustomizeWorkshopGroupSettings : BaseCustomizeEntity
} }
var permittedToOverWrite = CustomizeWorkshopEmployeeSettingsCollection.Where(x => employeeIds.Contains(x.id)); var permittedToOverWrite = CustomizeWorkshopEmployeeSettingsCollection.Where(x => employeeIds.Contains(x.EmployeeId));
foreach (var item in permittedToOverWrite) foreach (var item in permittedToOverWrite)
{ {

View File

@@ -20,7 +20,7 @@ public class Employee : EntityBase
{ {
public Employee(string fName, string lName, string fatherName, public Employee(string fName, string lName, string fatherName,
DateTime dateOfBirth, DateTime dateOfIssue, string placeOfIssue, DateTime dateOfBirth, DateTime dateOfIssue, string placeOfIssue,
string nationalCode, string idNumber, string gender, string nationality, string nationalCode, string idNumber, string gender, string nationality, string idNumberSerial , string idNumberSeri ,
string phone = null, string address = null, string state = null, string city = null, 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 maritalStatus = null, string militaryService = null, string levelOfEducation = null, string fieldOfStudy = null,
string bankCardNumber = null, string bankBranch = null, string insuranceCode = null, string insuranceHistoryByYear = null, string bankCardNumber = null, string bankBranch = null, string insuranceCode = null, string insuranceHistoryByYear = null,
@@ -146,6 +146,15 @@ public class Employee : EntityBase
/// آیا پرسنل احراز هویت شده است /// آیا پرسنل احراز هویت شده است
/// </summary> /// </summary>
public bool IsAuthorized { get; set; } public bool IsAuthorized { get; set; }
/// <summary>
/// سریال شناسنامه
/// </summary>
public string IdNumberSerial { get; set; }
/// <summary>
/// سری شناسنامه
/// </summary>
public string IdNumberSeri { get; set; }
#endregion #endregion
@@ -234,5 +243,39 @@ public class Employee : EntityBase
IsAuthorized = true; IsAuthorized = true;
} }
public void EditAuthorizeEmployee(DateTime dateOfIssue, string placeOfIssue,
string phone, string address, string state, string citi,
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)
{
DateOfIssue = dateOfIssue;
PlaceOfIssue = placeOfIssue;
Phone = phone;
Address = address;
State = state;
City = citi;
MaritalStatus = maritalStatus;
MilitaryService = militaryService;
LevelOfEducation = levelOfEducation;
FieldOfStudy = fieldOfStudy;
BankCardNumber = bankCardNumber;
BankBranch = bankBranch;
InsuranceCode = insuranceCode;
InsuranceHistoryByYear = insuranceHistoryByYear;
InsuranceHistoryByMonth = insuranceHistoryByMonth;
NumberOfChildren = numberOfChildren;
OfficePhone = OfficePhone;
MclsUserName = mclsUserName;
MclsPassword = mclsPassword;
EserviceUserName = eserviceUserName;
EservicePassword = eservicePassword;
TaxOfficeUserName = taxOfficeUserName;
TaxOfficepassword = taxOfficepassword;
SanaUserName = sanaUserName;
SanaPassword = sanaPassword;
}
#endregion #endregion
} }

View File

@@ -54,6 +54,7 @@ public interface IEmployeeRepository : IRepository<long, Employee>
Employee GetIgnoreQueryFilter(long id); Employee GetIgnoreQueryFilter(long id);
Task<List<EmployeeSelectListViewModel>> WorkedEmployeesInWorkshopSelectList(long workshopId);
#endregion #endregion

View File

@@ -0,0 +1,44 @@
using System;
using _0_Framework.Application;
using _0_Framework.Domain;
namespace Company.Domain.EmployeeAuthorizeTempAgg;
public class EmployeeAuthorizeTemp:EntityBase
{
public EmployeeAuthorizeTemp(Gender gender, string fName, string lName, string fatherName, DateTime birthDate, string nationalCode, string idNumber, string idNumberSerial, string idNumberSeri)
{
Gender = gender;
FName = fName;
LName = lName;
FatherName = fatherName;
BirthDate = birthDate;
NationalCode = nationalCode;
IdNumber = idNumber;
IdNumberSerial = idNumberSerial;
IdNumberSeri = idNumberSeri;
}
public Gender Gender { get; private set; }
public string FName { get; private set; }
public string LName { get; private set; }
public string FatherName { get; private set; }
public DateTime BirthDate { get; private set; }
/// <summary>
/// کدملی
/// </summary>
public string NationalCode { get; set; }
/// <summary>
/// شماره شناسنامه
/// </summary>
public string IdNumber { get; set; }
/// <summary>
/// سریال شناسنامه
/// </summary>
public string IdNumberSerial { get; set; }
/// <summary>
/// سری شناسنامه
/// </summary>
public string IdNumberSeri { get; set; }
}

View File

@@ -0,0 +1,10 @@
using System;
using System.Threading.Tasks;
using _0_Framework.Domain;
namespace Company.Domain.EmployeeAuthorizeTempAgg;
public interface IEmployeeAuthorizeTempRepository:IRepository<long,EmployeeAuthorizeTemp>
{
Task<EmployeeAuthorizeTemp> GetByNationalCode(string nationalCode);
}

View File

@@ -1,4 +1,6 @@
using _0_Framework.Domain; using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework.Domain;
using CompanyManagment.App.Contracts.EmployeeClientTemp; using CompanyManagment.App.Contracts.EmployeeClientTemp;
namespace Company.Domain.EmployeeClientTempAgg; namespace Company.Domain.EmployeeClientTempAgg;
@@ -8,4 +10,5 @@ public interface IEmployeeClientTempRepository : IRepository<long, EmployeeClien
EmployeeClientTemp GetByEmployeeIdAndWorkshopId(long employeeId, long commandWorkshopId); EmployeeClientTemp GetByEmployeeIdAndWorkshopId(long employeeId, long commandWorkshopId);
EmployeeClientTempGetDetailsViewModel GetDetails(long employeeId, long workshopId); EmployeeClientTempGetDetailsViewModel GetDetails(long employeeId, long workshopId);
void Remove(EmployeeClientTemp entity); void Remove(EmployeeClientTemp entity);
Task<List<EmployeeClientTempViewModel>> GetByEmployeeId(long employeeId);
} }

View File

@@ -9,15 +9,20 @@ namespace Company.Domain.EmployeeComputeOptionsAgg
{ {
public class EmployeeComputeOptions : EntityBase public class EmployeeComputeOptions : EntityBase
{ {
public EmployeeComputeOptions(long workshopId, long employeeId, string computeOptions, string bonusesOptions, string yearsOptions) public EmployeeComputeOptions(long workshopId, long employeeId, string computeOptions, string bonusesOptions, string yearsOptions,
bool createContract, bool signContract, bool createCheckout, bool signCheckout)
{ {
WorkshopId = workshopId; WorkshopId = workshopId;
EmployeeId = employeeId; EmployeeId = employeeId;
ComputeOptions = computeOptions; ComputeOptions = computeOptions;
BonusesOptions = bonusesOptions; BonusesOptions = bonusesOptions;
YearsOptions = yearsOptions; YearsOptions = yearsOptions;
SetContractAndCheckoutOptions(createContract, signContract, createCheckout, signCheckout);
} }
public long WorkshopId { get; private set; } public long WorkshopId { get; private set; }
public long EmployeeId { get; private set; } public long EmployeeId { get; private set; }
@@ -28,11 +33,59 @@ namespace Company.Domain.EmployeeComputeOptionsAgg
//نحوه محاسبه سنوات //نحوه محاسبه سنوات
public string YearsOptions { get; private set; } public string YearsOptions { get; private set; }
public void Edit(string computeOptions, string bonusesOptions, string yearsOptions) /// <summary>
/// ایجاد قرارداد
/// </summary>
public bool CreateContract { get; private set; }
/// <summary>
/// امضای قرارداد
/// </summary>
public bool SignContract { get; private set; }
/// <summary>
/// ایجاد تصفیه
/// </summary>
public bool CreateCheckout { get; private set; }
/// <summary>
/// امضای تصفیه
/// </summary>
public bool SignCheckout { get; private set; }
public void Edit(string computeOptions, string bonusesOptions, string yearsOptions, bool createContract, bool signContract, bool createCheckout,
bool signCheckout)
{ {
ComputeOptions = computeOptions; ComputeOptions = computeOptions;
BonusesOptions = bonusesOptions; BonusesOptions = bonusesOptions;
YearsOptions = yearsOptions; YearsOptions = yearsOptions;
SetContractAndCheckoutOptions(createContract, signContract, createCheckout, signCheckout);
}
private void SetContractAndCheckoutOptions(bool createContract, bool signContract, bool createCheckout,
bool signCheckout)
{
CreateContract = createContract;
if (createContract)
{
SignContract = signContract;
CreateCheckout = createCheckout;
if (createCheckout)
{
SignCheckout = signCheckout;
}
else
{
SignCheckout = false;
}
}
else
{
SignContract = false;
CreateCheckout = false;
SignCheckout = false;
} }
} }
} }
}

View File

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

View File

@@ -7,16 +7,17 @@ using System.Collections.Generic;
using _0_Framework.Application; using _0_Framework.Application;
using Microsoft.AspNetCore.JsonPatch.Operations; using Microsoft.AspNetCore.JsonPatch.Operations;
namespace Company.Domain.EmployeeDocumentItemAgg namespace Company.Domain.EmployeeDocumentItemAgg;
{
public class EmployeeDocumentItem : EntityBase public class EmployeeDocumentItem : EntityBase
{ {
private EmployeeDocumentItem() { }
public long WorkshopId { get; private set; } public long WorkshopId { get; private set; }
public long EmployeeId { get; private set; } public long EmployeeId { get; private set; }
public long UploaderId { get; private set; } public long UploaderId { get; private set; }
public UserType UploaderType { get; private set; } public UserType UploaderType { get; private set; }
public long UploaderRoleId { get; set; }
public long ReviewedById { get; private set; } public long ReviewedById { get; private set; }
@@ -37,11 +38,12 @@ namespace Company.Domain.EmployeeDocumentItemAgg
public EmployeeDocumentItem(long workshopId, long employeeId, long mediaId, long employeeDocumentId, DocumentItemLabel documentLabel, long uploaderId, public EmployeeDocumentItem(long workshopId, long employeeId, long mediaId, long employeeDocumentId, DocumentItemLabel documentLabel, long uploaderId,
UserType uploaderType, DocumentStatus documentStatus = DocumentStatus.Unsubmitted) UserType uploaderType, long roleId, DocumentStatus documentStatus = DocumentStatus.Unsubmitted)
{ {
MediaId = mediaId; MediaId = mediaId;
UploaderId = uploaderId; UploaderId = uploaderId;
UploaderType = uploaderType; UploaderType = uploaderType;
UploaderRoleId = uploaderType == UserType.Admin ? roleId : -1;
EmployeeId = employeeId; EmployeeId = employeeId;
WorkshopId = workshopId; WorkshopId = workshopId;
DocumentStatus = documentStatus; DocumentStatus = documentStatus;
@@ -101,6 +103,9 @@ namespace Company.Domain.EmployeeDocumentItemAgg
ItemLogs.Add(new EmployeeDocumentItemLog(EmployeeDocumentItemOperation.SubmittedItems, operatorId, operatorType)); ItemLogs.Add(new EmployeeDocumentItemLog(EmployeeDocumentItemOperation.SubmittedItems, operatorId, operatorType));
EmployeeDocuments.UpdateHasRejectedItems(); EmployeeDocuments.UpdateHasRejectedItems();
} }
}
public void SetRoleId(long roleId)
{
UploaderRoleId = roleId;
}
} }

View File

@@ -9,12 +9,12 @@ namespace Company.Domain.EmployeeDocumentsAgg
{ {
List<DocumentItemLabel> requiredDocuments = List<DocumentItemLabel> requiredDocuments =
[ [
DocumentItemLabel.IdCardPage1, DocumentItemLabel.IdCardPage2, DocumentItemLabel.IdCardPage3, DocumentItemLabel.NationalCardRear, DocumentItemLabel.IdCardPage1,/* DocumentItemLabel.IdCardPage2, DocumentItemLabel.IdCardPage3, DocumentItemLabel.NationalCardRear,*/
DocumentItemLabel.NationalCardFront,DocumentItemLabel.EmployeePicture DocumentItemLabel.NationalCardFront,/*DocumentItemLabel.EmployeePicture*/
]; ];
if (gender == "مرد") //if (gender == "مرد")
requiredDocuments.Add(DocumentItemLabel.MilitaryServiceCard); // requiredDocuments.Add(DocumentItemLabel.MilitaryServiceCard);
return requiredDocuments; return requiredDocuments;
} }

View File

@@ -30,5 +30,76 @@ namespace Company.Domain.EmployeeDocumentsAgg
Task<int> GetAdminWorkFlowCountForNewEmployees(List<long> workshopIds); Task<int> GetAdminWorkFlowCountForNewEmployees(List<long> workshopIds);
Task<int> GetAdminWorkFlowCountForSubmittedAndRejectedDocuments(List<long> workshopIds); Task<int> GetAdminWorkFlowCountForSubmittedAndRejectedDocuments(List<long> workshopIds);
List<EmployeeDocumentsViewModel> GetDocumentsAwaitingReviewByWorkshopIdForCheckerWorkFlow(long workshopId); List<EmployeeDocumentsViewModel> GetDocumentsAwaitingReviewByWorkshopIdForCheckerWorkFlow(long workshopId);
#region Mahan
/// <summary>
/// کارگاهی که افزودن پرسنل کرده اند. بر اساس نقش فیلتر میشوند
/// </summary>
/// <param name="workshops"></param>
/// <param name="roleId"></param>
/// <returns></returns>
Task<ICollection<WorkshopWithEmployeeDocumentsViewModel>> GetWorkshopDocumentCreatedEmployeeForAdmin(
List<long> workshops, long roleId);
/// <summary>
///کارگاه های مدارک های برگشت خورده براساس دسترسی افراد و نقششان. یک مدرک برگشت خورده به تمامی کسانی که به آن کارگاه دسترسی دارند و تمامی کسانی که هم نقش آپلود کننده بوده اند نمایش داده میشود
/// </summary>
/// <param name="workshops"></param>
/// <param name="roleId"></param>
/// <returns></returns>
Task<ICollection<WorkshopWithEmployeeDocumentsViewModel>> GetWorkshopDocumentRejectedForAdmin(
List<long> workshops, long roleId);
/// <summary>
/// مدارک های برگشت خورده براساس دسترسی افراد و نقششان. یک مدرک برگشت خورده به تمامی کسانی که به آن کارگاه دسترسی دارند و تمامی کسانی که هم نقش آپلود کننده بوده اند نمایش داده میشود
/// </summary>
/// <param name="workshopId"></param>
/// <param name="roleId"></param>
/// <returns></returns>
Task<List<EmployeeDocumentsViewModel>> GetRejectedItemsByWorkshopIdAndRoleForAdminWorkFlow(long workshopId,
long roleId);
/// <summary>
/// کارگاه هایی که افزودن پرسنل کرده اند و مدارک آنها ناقص است
/// </summary>
/// <param name="workshops"></param>
/// <param name="roleId"></param>
/// <returns></returns>
Task<List<WorkshopWithEmployeeDocumentsViewModel>> GetCreatedEmployeesWorkshopDocumentForAdmin(
List<long> workshops,long roleId);
/// <summary>
/// پرسنلی که افزوده شده اند در کارگاه و آپلود مدارک آنها ناقص است
/// </summary>
/// <param name="workshopId"></param>
/// <returns></returns>
Task<List<EmployeeDocumentsViewModel>> GetCreatedEmployeesDocumentByWorkshopIdForAdmin(long workshopId);
/// <summary>
/// لیست کارگاه هایی که مدارک آپلود شده توسط کلاینت برگشت خورده است در کارپوشه ادمین
/// </summary>
/// <param name="workshops"></param>
/// <param name="roleId"></param>
/// <returns></returns>
Task<List<WorkshopWithEmployeeDocumentsViewModel>> GetClientRejectedDocumentWorkshopsForAdmin(
List<long> workshops, long roleId);
/// <summary>
/// مدارک های آپلود شده توسط کلاینت در کارگاه که برگشت خورده اند در کارپوشه ادمین
/// </summary>
/// <param name="workshopId"></param>
/// <returns></returns>
Task<List<EmployeeDocumentsViewModel>> GetClientRejectedDocumentByWorkshopIdForAdmin(long workshopId);
/// <summary>
/// مدارک های برگشت خورده برای کلاینت
/// </summary>
/// <param name="workshopId"></param>
/// <param name="accountId"></param>
/// <returns></returns>
Task<List<EmployeeDocumentsViewModel>> GetClientRejectedDocumentForClient(long workshopId, long accountId);
#endregion
} }
} }

View File

@@ -12,7 +12,7 @@ public class EmployeeInsurancListData : EntityBase
{ {
public EmployeeInsurancListData(long insuranceListId, long employeeId, int workingDays, double dailyWage, double monthlySalary, public EmployeeInsurancListData(long insuranceListId, long employeeId, int workingDays, double dailyWage, double monthlySalary,
double monthlyBenefits, double monthlyBenefitsIncluded, double benefitsIncludedContinuous, double benefitsIncludedNonContinuous, double monthlyBenefits, double monthlyBenefitsIncluded, double benefitsIncludedContinuous, double benefitsIncludedNonContinuous,
double insuranceShare, DateTime startWorkDate, DateTime? leftWorkDate, long jobId,bool includeStatus, double baseYears, double marriedAllowance) double insuranceShare, DateTime startWorkDate, DateTime? leftWorkDate, long jobId,bool includeStatus, double baseYears, double marriedAllowance, double overTimePay, double familyAllowance)
{ {
InsuranceListId = insuranceListId; InsuranceListId = insuranceListId;
EmployeeId = employeeId; EmployeeId = employeeId;
@@ -30,6 +30,8 @@ public class EmployeeInsurancListData : EntityBase
IncludeStatus = includeStatus; IncludeStatus = includeStatus;
BaseYears = baseYears; BaseYears = baseYears;
MarriedAllowance = marriedAllowance; MarriedAllowance = marriedAllowance;
OverTimePay = overTimePay;
FamilyAllowance = familyAllowance;
DailyWagePlusBaseYears = dailyWage + baseYears; DailyWagePlusBaseYears = dailyWage + baseYears;
} }
@@ -110,10 +112,20 @@ public class EmployeeInsurancListData : EntityBase
/// </summary> /// </summary>
public double MarriedAllowance { get; private set; } public double MarriedAllowance { get; private set; }
/// <summary>
/// اضافه کار فیش حقوقی
/// </summary>
public double OverTimePay { get; private set; }
/// <summary>
/// حق اولاد فیش حقوقی
/// </summary>
public double FamilyAllowance { get; private set; }
public void Edit(int workingDays, double dailyWage, double monthlySalary, double monthlyBenefits, double monthlyBenefitsIncluded, public void Edit(int workingDays, double dailyWage, double monthlySalary, double monthlyBenefits, double monthlyBenefitsIncluded,
double benefitsIncludedContinuous, double benefitsIncludedNonContinuous, double insuranceShare, DateTime startWorkDate, double benefitsIncludedContinuous, double benefitsIncludedNonContinuous, double insuranceShare, DateTime startWorkDate,
DateTime? leftWorkDate, long jobId, bool includeStatus, double baseYears, double marriedAllowance) DateTime? leftWorkDate, long jobId, bool includeStatus, double baseYears, double marriedAllowance, double overTimePay, double familyAllowance)
{ {
WorkingDays = workingDays; WorkingDays = workingDays;
@@ -130,6 +142,8 @@ public class EmployeeInsurancListData : EntityBase
IncludeStatus= includeStatus; IncludeStatus= includeStatus;
BaseYears = baseYears; BaseYears = baseYears;
MarriedAllowance = marriedAllowance; MarriedAllowance = marriedAllowance;
OverTimePay = overTimePay;
FamilyAllowance = familyAllowance;
DailyWagePlusBaseYears = dailyWage + baseYears; DailyWagePlusBaseYears = dailyWage + baseYears;
} }

View File

@@ -1,4 +1,5 @@
using System.Collections.Generic; using System.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework_b.Domain; using _0_Framework_b.Domain;
using CompanyManagment.App.Contracts.Employee; using CompanyManagment.App.Contracts.Employee;
using CompanyManagment.App.Contracts.Employer; using CompanyManagment.App.Contracts.Employer;
@@ -16,4 +17,17 @@ public interface IFileRepository : IRepository<long, File1>
string GetEmployerFullNameById(long id); string GetEmployerFullNameById(long id);
List<EmployeeViewModel> GetAllEmploees(); List<EmployeeViewModel> GetAllEmploees();
List<EmployerViewModel> GetAllEmployers(); 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.Collections.Generic;
using System.Threading.Tasks;
using _0_Framework_b.Domain; using _0_Framework_b.Domain;
using CompanyManagment.App.Contracts.FileAlert; using CompanyManagment.App.Contracts.FileAlert;
@@ -10,4 +11,5 @@ public interface IFileAlertRepository : IRepository<long, FileAlert>
FileAlertViewModel GetDetails(long id); FileAlertViewModel GetDetails(long id);
void Remove(long id); void Remove(long id);
List<EditFileAlert> Search(FileAlertSearchModel searchModel); 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 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; EmployeeId = employeeId;
WorkshopId = workshopId; WorkshopId = workshopId;
@@ -15,6 +19,9 @@ public class Fine:EntityBase
IsActive = IsActive.True; IsActive = IsActive.True;
FineDate = fineDate; FineDate = fineDate;
CreatedByUserType = createdByUserType;
CreatedByAccountId = createdByAccountId;
} }
public long EmployeeId { get; private set; } public long EmployeeId { get; private set; }
@@ -24,6 +31,22 @@ public class Fine:EntityBase
public IsActive IsActive { get; private set; } public IsActive IsActive { get; private set; }
public DateTime FineDate { get; private set; } public DateTime FineDate { get; private set; }
/// <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() public void DeActive()
{ {
IsActive = IsActive.False; IsActive = IsActive.False;
@@ -34,14 +57,15 @@ public class Fine:EntityBase
IsActive = IsActive.True; 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; EmployeeId = employeeId;
WorkshopId = workshopId; WorkshopId = workshopId;
Title = title; Title = title;
Amount = amount; Amount = amount;
FineDate = fineDate; FineDate = fineDate;
LastModifiedByAccountId = modifiedByAccountId;
LastModifiedByUserType = modifiedByUserType;
} }
} }

View File

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

View File

@@ -25,7 +25,7 @@ public interface IInstitutionContractRepository : IRepository<long, InstitutionC
double GetcontractAmount(int countPerson); double GetcontractAmount(int countPerson);
string ExpColor(DateTime contractEndGr, double contractAmount, (string result, string isExpier) ExpColor(DateTime contractEndGr, double contractAmount,
string isActiveString); string isActiveString);
TotalbalancViewModel TotalBalance(long contractingPartyId); TotalbalancViewModel TotalBalance(long contractingPartyId);

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;
}
}

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