Compare commits

...

1054 Commits

Author SHA1 Message Date
Hussain Nagaria a35638d289 feat: add reply_to in email students 2023-10-17 22:01:04 +05:30
Jannat Patel a02365c223 Merge pull request #642 from pateljannat/course-permissions
fix: permissions
2023-10-13 19:43:50 +05:30
Jannat Patel 2d589aefa2 Merge pull request #643 from pateljannat/timetable-customisations
feat: timetable customisations
2023-10-13 19:39:15 +05:30
Jannat Patel bc2dc679a8 fix: revert ci changes 2023-10-13 18:15:49 +05:30
Jannat Patel f2432d78ee ci: added collation server for mariadb 2023-10-13 16:29:47 +05:30
Jannat Patel f27eecce1f ci: added collation server for mariadb 2023-10-13 16:17:58 +05:30
Jannat Patel caf967f2e2 ci: added collation server for mariadb 2023-10-13 16:13:45 +05:30
Jannat Patel eecc9b53df ci: added collation server for mariadb 2023-10-13 16:07:01 +05:30
Jannat Patel 8e12cae91f ci: added collation server for mariadb 2023-10-13 15:58:07 +05:30
Jannat Patel 12c5ad54e7 ci: added collation server for mariadb 2023-10-13 15:24:12 +05:30
Jannat Patel c20fa7e093 ci: added collation server for mariadb 2023-10-13 14:50:50 +05:30
Jannat Patel 4c83264c4a ci: added collation server for mariadb 2023-10-13 13:14:35 +05:30
Jannat Patel f592cf08d8 ci: added collation server for mariadb 2023-10-13 12:47:36 +05:30
Jannat Patel bf0cb25a88 ci: added collation server for mariadb 2023-10-13 12:33:16 +05:30
Jannat Patel 2ff3d83d8f ci: added collation server for mariadb 2023-10-13 11:52:38 +05:30
Jannat Patel 3f5c3e89c8 ci: added collation server for mariadb 2023-10-13 11:45:42 +05:30
Jannat Patel a1bb7962bc ci: added collation server for mariadb 2023-10-13 11:40:17 +05:30
Jannat Patel bf5cc5e1d1 ci: fixed mariadb options 2023-10-13 11:24:58 +05:30
Jannat Patel d840d2fc18 ci: fixed step in server tests script 2023-10-13 11:19:27 +05:30
Jannat Patel 1e458921e8 ci: fix server tests script 2023-10-13 11:17:41 +05:30
Jannat Patel 55feb41998 feat: timetable customisations 2023-10-13 10:59:44 +05:30
Jannat Patel a7dbdd844b feat: batch customisations 2023-10-12 21:20:36 +05:30
Jannat Patel f3d6ad6c84 fix: course permissions 2023-10-11 13:40:07 +05:30
Jannat Patel a0255e1743 feat: send email to batch students 2023-10-11 12:58:07 +05:30
Jannat Patel affd2b47bd Merge pull request #640 from pateljannat/registration-email
feat: batch registration confirmation email
2023-10-10 10:16:12 +05:30
Jannat Patel 814870fd69 feat: batch regisration confirmation email 2023-10-09 18:53:50 +05:30
Jannat Patel 50c1a566a8 Merge pull request #639 from pateljannat/summary
feat: assignment as text
2023-10-07 11:08:10 +05:30
Jannat Patel 47783997c6 feat: assignment as text 2023-10-06 15:32:53 +05:30
Jannat Patel 70d8505596 Merge pull request #637 from pateljannat/batch-emails
feat: send email to batch students
2023-10-05 21:59:46 +05:30
Jannat Patel 6e8cf9ca25 fix: category on batch edit 2023-10-05 17:24:04 +05:30
Jannat Patel c9cda6c6f5 fix: show email button only to moderators 2023-10-05 16:24:11 +05:30
Jannat Patel 6c4d3ea37e feat: send email to batch students 2023-10-05 16:12:02 +05:30
Jannat Patel 8ad0e99b3c Merge pull request #634 from pateljannat/template-days
feat: Days and Duration in timetable template
2023-10-04 13:06:36 +05:30
Jannat Patel 60277ed6e9 fix: onboarding style 2023-10-04 12:12:00 +05:30
Jannat Patel 7b570420ca fix: content collapse 2023-10-04 11:07:01 +05:30
Jannat Patel 9205b59e29 feat: days in timetable template 2023-10-04 10:44:16 +05:30
Jannat Patel 685c5babe5 Merge pull request #633 from pateljannat/pdf-upload-issue
fix: pdf rendering in lessons
2023-10-03 16:24:18 +05:30
Jannat Patel 681dc8fbc1 fix: pdf rendering in lessons 2023-10-03 16:09:11 +05:30
Jannat Patel 7c623b1a8d Merge pull request #632 from pateljannat/audio-in-lesson
feat: audio in lessons
2023-10-03 13:53:30 +05:30
Jannat Patel 277c089adc feat: audio in lessons 2023-10-03 13:33:59 +05:30
Jannat Patel cfc3c231ff fix: permissions for lms enrollment 2023-10-02 12:55:35 +05:30
Jannat Patel 1000a22490 fix: permissions for lms enrollment 2023-10-02 12:52:36 +05:30
Jannat Patel 65c0ebac50 Merge pull request #629 from pateljannat/student-role
feat: LMS Student Role
2023-09-29 19:22:23 +05:30
Jannat Patel 80843ec44b feat: assign LMS Student role to all signups 2023-09-29 18:59:08 +05:30
Jannat Patel be23220e01 feat: lms student role 2023-09-29 17:14:00 +05:30
Jannat Patel c82c10d17e Merge pull request #628 from pateljannat/batch-customisations
feat: batch customisations
2023-09-29 10:59:41 +05:30
Jannat Patel 5918b8be60 feat: batch customisations 2023-09-28 19:11:46 +05:30
Jannat Patel 647a0a8ff1 Merge pull request #626 from pateljannat/ins-notes-changes
feat: editor js for instructor notes
2023-09-28 11:32:00 +05:30
Jannat Patel bf3c6bc6be test: change lesson sequence 2023-09-28 10:39:30 +05:30
Jannat Patel cc7832614b fix: hide course header for students if no courses in batch 2023-09-28 10:14:10 +05:30
Jannat Patel d5387a0d1a test: fix course creation test 2023-09-27 19:57:37 +05:30
Jannat Patel 5d7ad973a2 Merge pull request #627 from pateljannat/batch-meta
feat: batch meta and raw details
2023-09-27 19:46:28 +05:30
Jannat Patel 0fcea692c7 feat: batch meta and raw details 2023-09-27 19:21:57 +05:30
Jannat Patel db71f1271b feat: editor js for instructor notes 2023-09-27 17:59:36 +05:30
Jannat Patel 3fde923190 Merge pull request #624 from pateljannat/billing-flow-issues
fix: billing flow issues
2023-09-27 09:17:53 +05:30
Jannat Patel 4f97760e8a fix: billing flow issues 2023-09-26 22:40:00 +05:30
Jannat Patel 5614a6203f Merge pull request #622 from pateljannat/issues
fix: sanitized inputs for people and course creation page
2023-09-25 22:49:25 +05:30
Jannat Patel 5727b7cd73 fix: sanitized inputs for people and course creation page 2023-09-25 22:08:37 +05:30
Jannat Patel 1c0644aa7a Merge pull request #619 from pateljannat/state-validation
fix: billing flow
2023-09-25 17:57:50 +05:30
Jannat Patel 23e6ebe8ee fix: multicurrency on course pages 2023-09-25 17:50:36 +05:30
Jannat Patel 5602c0b6c3 Merge branch 'main' of https://github.com/frappe/lms into state-validation 2023-09-25 09:48:09 +05:30
Jannat Patel 8e59c10b90 Merge pull request #610 from pateljannat/ins-notes
fix: instructor notes
2023-09-25 09:39:45 +05:30
Jannat Patel 90587b0508 fix: price update on country 2023-09-22 21:46:08 +05:30
Jannat Patel 153a8428f7 fix: billing flow 2023-09-21 12:52:31 +05:30
Jannat Patel 3d00d96716 Merge pull request #614 from pateljannat/timetable
feat: Batch Timetable
2023-09-20 13:07:09 +05:30
Jannat Patel fb9824301f fix: removed live class from template row 2023-09-20 13:00:51 +05:30
Jannat Patel 33f4e82399 fix: batch copy 2023-09-20 12:40:04 +05:30
Jannat Patel 0d99269109 feat: live class checkbox 2023-09-20 12:09:02 +05:30
Jannat Patel 8098532215 feat: timetable legends and template 2023-09-18 19:16:57 +05:30
Jannat Patel 24e9f46e2f feat: batch timetable 2023-09-15 21:55:06 +05:30
Jannat Patel 7c3b40f9d5 Merge pull request #613 from pateljannat/change-batch-course-naming
fix: batch course sequence id issue
2023-09-14 12:47:44 +05:30
Jannat Patel 29860583f4 fix: batch course sequence id issue 2023-09-14 12:34:34 +05:30
Jannat Patel 9c00a5561a Merge pull request #600 from pateljannat/paid-class
feat: Batches Revamp
2023-09-13 15:18:55 +05:30
Jannat Patel 82b8853f39 fix: patches 2023-09-13 15:10:52 +05:30
Jannat Patel c4ab91a565 feat: certified participants page 2023-09-13 13:07:20 +05:30
Jannat Patel 87e5096f5d fix: course card edit and delete button position 2023-09-13 10:39:32 +05:30
Jannat Patel 1a07021bbf fix: quiz list in lesson page 2023-09-12 18:03:56 +05:30
Jannat Patel 6ab4f15d0c feat: publish batches 2023-09-12 15:09:13 +05:30
Jannat Patel f137f8e048 feat: multicurrency 2023-09-12 12:13:41 +05:30
Jannat Patel 04501143ec feat: apply_gst in batches 2023-09-11 22:44:28 +05:30
Jannat Patel 07276f5c17 fix: renamed class to batch for live classes 2023-09-04 23:18:45 +05:30
Jannat Patel a9bd01b34e fix: instructor notes 2023-09-01 23:14:58 +05:30
Jannat Patel 93db82305f Merge pull request #607 from pateljannat/lesson-embed
feat: embeds in lesson
2023-08-31 23:38:23 +05:30
Jannat Patel ce09f27373 fix: assignment renderer 2023-08-31 23:32:46 +05:30
Jannat Patel ffd9d56896 feat: embed pdf 2023-08-31 23:29:56 +05:30
Jannat Patel 833e714a1f feat: embeds in lesson 2023-08-31 21:33:09 +05:30
Jannat Patel e402f322f6 Merge pull request #606 from pateljannat/instructor-notes
feat: instructor notes
2023-08-31 12:18:56 +05:30
Jannat Patel 2a0636b32b fix: field descriptions 2023-08-31 11:58:08 +05:30
Jannat Patel 677dc59399 feat: instructor notes 2023-08-31 11:49:51 +05:30
Jannat Patel db408b21d2 chore: resolve conflicts 2023-08-30 14:38:18 +05:30
Jannat Patel fe08f4cf09 Merge pull request #605 from pateljannat/assignment-url
feat: Assignment as URL
2023-08-30 13:26:35 +05:30
Jannat Patel ccb7c1485b fix: validation for URL 2023-08-30 13:10:22 +05:30
Jannat Patel 4a76f42e35 feat: assignment url 2023-08-30 13:01:45 +05:30
Jannat Patel 6f31d50a27 fix: payment fetch failure after payment completion 2023-08-30 11:50:12 +05:30
Jannat Patel 018c26b885 fix: course enrollment 2023-08-29 22:25:40 +05:30
Jannat Patel f9f70f208f feat: certificate generation dialog 2023-08-29 16:50:14 +05:30
Jannat Patel b940ddca25 fix: batch ui and ux 2023-08-29 09:55:40 +05:30
Jannat Patel cd82527ef3 Merge branch 'main' of https://github.com/frappe/lms into paid-class 2023-08-28 11:15:27 +05:30
Jannat Patel f600f016ae fix: permissions for lms course doctype 2023-08-28 11:14:08 +05:30
Jannat Patel 27101ffd31 fix: renamed class to batch 2023-08-28 10:59:52 +05:30
Jannat Patel 9376b0b010 chore: resolved conflicts 2023-08-26 16:00:44 +05:30
Jannat Patel e2c1f6aa2d Merge pull request #602 from pateljannat/rename-batch-doctype
refactor: renamed batch and membership doctypes
2023-08-26 15:53:56 +05:30
Jannat Patel e2287cc73c Merge pull request #586 from niraj2477/fix-quiz-submission
fix: Add question in quiz submission
2023-08-26 15:53:22 +05:30
Jannat Patel c350ce1b60 fix: replaced batch references 2023-08-26 15:44:19 +05:30
Jannat Patel 09dbe0fed7 fix: replaced instances of batch to batch_old 2023-08-26 15:28:03 +05:30
Jannat Patel 12b3d16662 Merge branch 'main' of https://github.com/frappe/lms into rename-batch-doctype 2023-08-25 18:04:28 +05:30
Jannat Patel 1676329eb2 Merge pull request #572 from tahir-zaqout/fix-instructors
fix: course when instructor is not set
2023-08-25 18:02:59 +05:30
Jannat Patel 86434ea320 fix: removed fields array as there is pluck 2023-08-25 17:45:46 +05:30
Jannat Patel de6b4f7fb2 test: fix batch fieldname 2023-08-25 17:05:55 +05:30
Jannat Patel 6e488cba3e test: fix enrollment tests 2023-08-25 16:44:04 +05:30
Jannat Patel 03a6cc85fe test: enrollment and exercise test fixed 2023-08-25 15:19:29 +05:30
Jannat Patel b8b32681bf refactor: renamed batch and membership doctypes 2023-08-25 14:46:11 +05:30
Jannat Patel 7f67c6c6d9 Merge pull request #601 from pateljannat/link-class-to-eval-flow
feat: link class in evaluation flow
2023-08-25 10:08:38 +05:30
Jannat Patel 0487b2c987 chore: resolved conflicts 2023-08-24 22:17:45 +05:30
Jannat Patel d5f10db250 feat: capture gst information 2023-08-24 22:15:55 +05:30
Jannat Patel 74df0f19cf fix: class filter on certification doctypes 2023-08-23 14:52:56 +05:30
Jannat Patel 47c19b4e3d feat: gst fields in class student 2023-08-23 13:00:54 +05:30
Jannat Patel b197e36ba7 Merge pull request #599 from pateljannat/filter-mobile
fix: styling of course list menu
2023-08-23 10:43:37 +05:30
Jannat Patel 4b049dcf71 fix: styling of course list menu 2023-08-22 19:16:22 +05:30
Jannat Patel 04ed7f412f feat: class billing 2023-08-22 18:34:42 +05:30
Jannat Patel ac64e59c43 chore: resolved conflicts 2023-08-19 12:26:21 +05:30
Jannat Patel d5524a8d67 feat: registration information in class student 2023-08-19 12:24:13 +05:30
Jannat Patel bc350a2661 Merge pull request #595 from pateljannat/revert-registration
revert: class registration
2023-08-18 19:09:19 +05:30
Jannat Patel 575fb623ba revert: class registration 2023-08-18 18:59:02 +05:30
Jannat Patel b7783659c9 Merge branch 'main' of https://github.com/frappe/lms 2023-08-18 17:39:02 +05:30
Jannat Patel bddd4743a7 fix: reload course doctype 2023-08-18 17:38:20 +05:30
Jannat Patel ce8ac15faa Merge pull request #594 from pateljannat/user-validate-image
fix: dont validate user uploaded files
2023-08-18 15:19:57 +05:30
Jannat Patel 46e7c83fae fix: dont validate user uploaded files 2023-08-18 15:13:34 +05:30
Jannat Patel 3dcb55f603 Merge pull request #592 from pateljannat/course-filter
feat: course filters
2023-08-18 13:05:24 +05:30
Jannat Patel fb3e0832d6 chore: removed unnecessary print statements 2023-08-18 12:49:43 +05:30
Jannat Patel 982d6c9045 fix: popularity filter for enrolled and authored courses 2023-08-18 12:39:19 +05:30
Jannat Patel a061a89ee7 fix: paid course details on course card template 2023-08-17 22:06:25 +05:30
Jannat Patel 00bb71f714 chore: resolved conflicts 2023-08-17 21:25:52 +05:30
Jannat Patel e23cfac5a7 Merge pull request #589 from pateljannat/paid-courses
feat: Paid courses
2023-08-17 14:44:29 +05:30
Jannat Patel ed651959c1 fix: amount information in membership 2023-08-17 14:20:30 +05:30
Jannat Patel 01a1632a5a feat: course filters 2023-08-16 22:01:59 +05:30
Jannat Patel c2a6697f72 fix: show price on all course cards 2023-08-16 11:51:05 +05:30
Jannat Patel 211775dba5 fix: formatting 2023-08-16 11:00:06 +05:30
Jannat Patel 2ba85ba6a7 feat: paid course from course creation form 2023-08-14 19:30:33 +05:30
Jannat Patel 3b3f1d692f Merge branch 'main' of https://github.com/frappe/lms into paid-courses 2023-08-14 09:59:46 +05:30
Ankush Menat d90bb1e5ea fix: escape arguments 2023-08-13 23:37:16 +05:30
Jannat Patel 0c14a1ab4c feat: payment verification and membership 2023-08-11 19:45:12 +05:30
Jannat Patel ea27acc683 Merge branch 'main' of https://github.com/frappe/lms into paid-courses 2023-08-10 13:33:44 +05:30
14987 b2122e7707 fix: add question in quiz submission 2023-08-10 13:19:33 +05:30
Jannat Patel 9cdc8a50f6 Merge pull request #580 from pateljannat/class-flow
feat: Class flow
2023-08-10 13:14:27 +05:30
Jannat Patel 03620be7bb fix: class schedule date and time validation 2023-08-10 13:00:26 +05:30
Jannat Patel 55296cd9cc fix: show progress on class schedule 2023-08-10 11:51:16 +05:30
Jannat Patel 5fefea1434 Merge branch 'main' of https://github.com/frappe/lms into class-flow 2023-08-09 17:22:44 +05:30
Jannat Patel 66dbe68a15 Merge pull request #583 from pateljannat/certificate-share
fix: Certificate share
2023-08-09 17:10:14 +05:30
Jannat Patel 066e2ddc69 fix: print format value 2023-08-09 17:03:10 +05:30
Jannat Patel 59f08ad4da fix: raise error if certificate is not found in any condition 2023-08-09 16:57:25 +05:30
Jannat Patel 551936e7c4 fix: show logo on certificate only if its present 2023-08-09 16:29:36 +05:30
Jannat Patel 4660240395 fix: certificate share 2023-08-09 14:29:51 +05:30
Jannat Patel 5d0a50242e fix: progress marking for normal content 2023-08-09 12:37:56 +05:30
Jannat Patel 141a778c9a chore: resolved conflicts 2023-08-09 11:49:00 +05:30
Jannat Patel d83d6cf2d8 Merge pull request #559 from pateljannat/class-revamp
feat: discussions and class dashboard
2023-08-09 11:18:44 +05:30
Jannat Patel 71dc32098e fix: removed unnecessary code 2023-08-09 11:09:17 +05:30
Jannat Patel 6e47b4a941 test: fix discussions test 2023-08-09 10:53:52 +05:30
Jannat Patel 8479e90aeb fix: allow evaluators to access the discussions section 2023-08-09 10:16:48 +05:30
Jannat Patel 24276b779d fix: progress access by students 2023-08-09 10:13:02 +05:30
Jannat Patel 47e254ed9b fix: flow UI and quiz progress 2023-08-07 21:17:23 +05:30
Jannat Patel 9c021ef3b1 feat: razorpay order creation and checkout redirection 2023-08-04 19:37:08 +05:30
Jannat Patel c284e95dc8 feat: validate razorpay data 2023-08-03 11:46:59 +05:30
Jannat Patel 39663a872c Merge branch 'main' of https://github.com/frappe/lms into paid-courses 2023-08-02 18:50:57 +05:30
Jannat Patel 14cefca735 Merge pull request #579 from pateljannat/fix-gha-dependencies
ci: remove mysql
2023-08-02 18:27:49 +05:30
Jannat Patel 55c56207c2 ci: remove mysql 2023-08-02 18:19:45 +05:30
Jannat Patel 79d9f31db7 feat: paid courses 2023-08-02 18:08:42 +05:30
Jannat Patel 845b906851 feat: redirection from class flow 2023-08-01 18:02:02 +05:30
Jannat Patel 5d2b19cc43 feat: learning flow in class 2023-08-01 10:10:06 +05:30
Jannat Patel a5bc30f776 Merge pull request #576 from pateljannat/evaluation-duplication
fix: eval request duplicate conditions
2023-07-31 14:49:44 +05:30
Jannat Patel cce77a475a chore: removed print statement 2023-07-31 14:42:35 +05:30
Jannat Patel 13a26321f5 fix: eval request duplicate conditions 2023-07-31 13:25:12 +05:30
Jannat Patel e7a2eb7373 feat: student dashboard 2023-07-31 12:36:13 +05:30
tahirAnvil 1cc168404a fix: get_instructors function 2023-07-27 12:07:11 +03:00
Jannat Patel cef3d21ab3 Merge branch 'main' of https://github.com/frappe/lms into class-revamp 2023-07-26 12:27:16 +05:30
Jannat Patel d0ac0e4523 Merge pull request #571 from pateljannat/fix-escription
fix: course card descriptions
2023-07-26 12:24:34 +05:30
Jannat Patel abaa7754a6 fix: adding dependency mariadb-client-core-10.6 for UI Test 2023-07-26 12:17:32 +05:30
Jannat Patel 02e875cbdc Merge branch 'main' of https://github.com/frappe/lms into fix-escription 2023-07-26 11:44:24 +05:30
Jannat Patel a218257952 fix: course card descriptions 2023-07-26 11:09:35 +05:30
Jannat Patel 7dfcabde5e chore: resolved conflicts 2023-07-26 11:00:27 +05:30
Jannat Patel 6573602dfc Merge pull request #570 from pateljannat/remove-dependencies
chore: remove dev dependencies
2023-07-25 19:27:19 +05:30
Jannat Patel 3c374f48b3 ci: manually installing cypress 2023-07-25 19:20:55 +05:30
Jannat Patel 2412ef0260 fix: dependencies 2023-07-25 18:48:31 +05:30
Jannat Patel d4dcfcdbc6 chore: remove dev dependencies 2023-07-25 18:06:25 +05:30
Jannat Patel 60aec7c801 Merge pull request #569 from pateljannat/fix-telemetry
fix: telemetry
2023-07-25 17:29:36 +05:30
Jannat Patel 1862d726ad fix: telemetry 2023-07-25 17:15:56 +05:30
Jannat Patel 3d27d5f755 fix: upcoming evals query 2023-07-25 10:50:56 +05:30
Jannat Patel 0b3f76590f Merge branch 'main' of https://github.com/frappe/lms into class-revamp 2023-07-24 18:25:58 +05:30
Jannat Patel 294832834c fix: ignore permissions while eval creations 2023-07-24 18:25:36 +05:30
Jannat Patel e3338e0236 Merge pull request #562 from pateljannat/class-evaluator
Class evaluator
2023-07-24 18:23:19 +05:30
Jannat Patel 5c7ae55775 Merge branch 'main' of https://github.com/frappe/lms into class-evaluator 2023-07-24 17:14:46 +05:30
Jannat Patel bc8827547e fix: scheduled the eval event creation 2023-07-24 17:10:03 +05:30
Jannat Patel 7990675c5c fix: evaluator in evals and link field descriptions 2023-07-21 12:46:33 +05:30
Jannat Patel 0182db8030 fix: show upcoming evals in progress page 2023-07-20 20:16:13 +05:30
Jannat Patel 295feccb49 fix: check booked slots against both day and time 2023-07-17 14:28:25 +05:30
Jannat Patel b5005f41fe feat: schedule evaluations 2023-07-14 20:56:21 +05:30
Jannat Patel 37f06a8ba4 Merge branch 'main' of https://github.com/frappe/lms into class-evaluator 2023-07-14 10:34:22 +05:30
Jannat Patel 71d421898d Merge pull request #561 from pateljannat/fix-docker
fix: use node 18 for docker
2023-07-13 17:16:05 +05:30
Jannat Patel bf5a69cee4 use node 18 for docker 2023-07-13 17:08:05 +05:30
Jannat Patel 11e6b8a372 feat: class evaluators 2023-07-13 15:10:53 +05:30
Jannat Patel d763dba204 discussions in class 2023-07-11 19:29:30 +05:30
Jannat Patel 9e5cd84214 Merge pull request #558 from pateljannat/quiz-with-no-answer-check
feat: show and hide quiz answers
2023-07-10 15:03:56 +05:30
Jannat Patel 14cf0c9ae1 test: fix flaky course creation test 2023-07-10 14:56:36 +05:30
Jannat Patel 7d410e9ec8 fix: removed print statement 2023-07-10 14:30:05 +05:30
Jannat Patel 07c3d423aa Merge branch 'main' of https://github.com/frappe/lms into quiz-with-no-answer-check 2023-07-10 12:33:25 +05:30
Jannat Patel 5d8003549f Merge pull request #556 from pateljannat/minor-ux
fix: UX Improvements
2023-07-10 12:01:13 +05:30
Jannat Patel b286daad16 feat: show and hide quiz answers 2023-07-04 19:42:12 +05:30
Jannat Patel caa9144a12 fix: progress page width 2023-07-03 14:58:12 +05:30
Jannat Patel 3606902753 fix: ux improvements 2023-06-28 16:55:43 +05:30
Jannat Patel 1abb75a58e fix: certificate duplication validation 2023-06-27 14:37:53 +05:30
Jannat Patel d35c15c384 Merge pull request #554 from pateljannat/class-ui
fix: class improvements
2023-06-27 14:35:56 +05:30
Jannat Patel 1888209027 test: upgrade node version 2023-06-27 12:51:31 +05:30
Jannat Patel f3830bfdd5 fix: assessment validation 2023-06-27 12:17:00 +05:30
Jannat Patel 0e1b91f1ec fix: validate duplication 2023-06-26 21:16:27 +05:30
Jannat Patel 8353aa24f3 feat: description in class card 2023-06-26 13:00:45 +05:30
Jannat Patel 99f1a8dfc3 fix: class improvements 2023-06-23 20:16:48 +05:30
Jannat Patel 3d8237008f Merge pull request #551 from pateljannat/quiz-in-classes
feat: quiz in classes
2023-06-22 11:51:13 +05:30
Jannat Patel 22199da7d4 fix: linters 2023-06-22 11:25:32 +05:30
Jannat Patel d8e11f69cc fix: quiz creation url 2023-06-22 11:14:15 +05:30
Jannat Patel c9a5c0801e fix: redirect after quiz submission 2023-06-22 10:53:11 +05:30
Jannat Patel bb0abe27cd fix: redirect after quiz submission 2023-06-22 10:52:57 +05:30
Jannat Patel 7d18e1d928 fix: quiz max attempts 2023-06-21 20:11:30 +05:30
Jannat Patel da72513f6a feat: quiz in classes 2023-06-20 20:12:10 +05:30
Jannat Patel 6f8c161e03 Merge pull request #549 from pateljannat/profile-form
fix: profile web form
2023-06-19 11:25:36 +05:30
Jannat Patel ac1f02971f fix: profile web form 2023-06-19 10:55:10 +05:30
Jannat Patel d19538abd2 Merge pull request #545 from pateljannat/quiz-enhancements-2
fix: quiz list in dialog
2023-06-16 14:27:30 +05:30
Jannat Patel b1ab7e7783 fix: removed unnecesary comments 2023-06-16 13:44:55 +05:30
Jannat Patel 35c080fcc2 fix: quiz dialog display 2023-06-16 13:08:49 +05:30
Jannat Patel 43e89d9dc2 Merge branch 'main' of https://github.com/frappe/lms into quiz-enhancements-2 2023-06-16 10:12:02 +05:30
Jannat Patel 547b69dd31 Merge pull request #544 from pateljannat/class-medium-and-category
feat: class medium and category
2023-06-15 17:28:24 +05:30
Jannat Patel 1ff8514b22 feat: class medium and category 2023-06-15 17:07:28 +05:30
Jannat Patel 5fffe51c4e fix: quiz in lessons 2023-06-15 11:18:17 +05:30
Jannat Patel af9aa3e37b fix: verison and readme 2023-06-14 15:03:18 +05:30
Jannat Patel d644ee7ccd Merge branch 'main' of https://github.com/frappe/lms 2023-06-14 14:39:49 +05:30
Jannat Patel 08e3278ca0 feat: track visit on lesson page 2023-06-14 14:39:14 +05:30
Jannat Patel 85feaa00fc Merge pull request #540 from pateljannat/quiz-modal
fix: quiz enhancements
2023-06-14 10:38:14 +05:30
Jannat Patel 76ba5c188e fix: arguements for set_single_value 2023-06-13 20:40:48 +05:30
Jannat Patel 9941e0e936 fix: linters and tests 2023-06-13 20:21:02 +05:30
Jannat Patel 89206f94f0 fix: show only first line in questions table 2023-06-13 19:39:00 +05:30
Jannat Patel 43128d7ea3 chore: resolved conflicts 2023-06-13 18:58:44 +05:30
Jannat Patel 6f1026434d fix: quiz enhancements 2023-06-13 18:44:37 +05:30
Jannat Patel db35e3e425 Merge pull request #539 from pateljannat/quiz-enhancements
feat: quiz option as small text
2023-06-12 10:27:07 +05:30
Jannat Patel 1d8de792a5 feat: quiz option as small text 2023-06-09 18:09:54 +05:30
Jannat Patel 0db47dfee1 Merge pull request #537 from pateljannat/general
fix: misc issues
2023-06-08 11:19:58 +05:30
Jannat Patel fc086fdbc3 fix: misc issues 2023-06-08 11:02:42 +05:30
Jannat Patel 8a86d19b79 Merge pull request #535 from pateljannat/course-publish-issue
fix: show course settings only to moderators
2023-06-07 16:56:47 +05:30
Jannat Patel 9198302f7e fix: show course settings only to moderators 2023-06-07 16:53:46 +05:30
Jannat Patel d076451ea8 Merge pull request #534 from pateljannat/onboarding-redirects
fix: Onboarding redirects
2023-06-07 16:02:48 +05:30
Jannat Patel c2e9ef59d6 fix: onboarding conditions 2023-06-07 15:43:44 +05:30
Jannat Patel 100f72de9d Merge branch 'main' of https://github.com/frappe/lms into onboarding-redirects 2023-06-07 15:06:14 +05:30
Jannat Patel 5a32109d5d docs: updated FC link in readme 2023-06-06 22:20:27 +05:30
Jannat Patel f5e7934906 docs: fixed FC signup button 2023-06-06 22:09:41 +05:30
Jannat Patel 9800c24939 docs: FC signup button on readme 2023-06-06 22:08:24 +05:30
Jannat Patel dcd81e0a3f fix: onboarding links 2023-06-06 22:06:01 +05:30
Jannat Patel 6574b55440 docs: fix logo in readme 2023-06-06 12:57:06 +05:30
Jannat Patel 8474d1c8c4 docs: PH embed on readme 2023-06-06 12:55:32 +05:30
Jannat Patel 38ae9ab9f5 Merge pull request #532 from pateljannat/video-with-spaces
fix: embed video with spaces in name
2023-06-06 09:59:03 +05:30
Jannat Patel 659b35f03e fix: embed video with spaces in name 2023-06-05 16:17:43 +05:30
Jannat Patel 414f126f1e Merge pull request #529 from pateljannat/lesson-assignment-fixes
fix: assignment submission in lesson
2023-06-05 10:59:07 +05:30
Jannat Patel b336d769c8 fix: assignment submission in lesson 2023-06-05 10:15:40 +05:30
Jannat Patel c173953c6a Merge pull request #520 from pateljannat/assignments-in-classes
feat: assignments in class
2023-06-02 15:56:49 +05:30
Jannat Patel afac45e65f fix: assignment evaluator 2023-06-02 15:37:02 +05:30
Jannat Patel f0aa5b8744 fix: new assessment doc creation 2023-06-02 14:33:55 +05:30
Jannat Patel a101e7b089 fix: class pages 2023-06-02 13:53:09 +05:30
Jannat Patel 85903d5385 feat: my class tab 2023-06-01 22:44:32 +05:30
Jannat Patel fe80ef9b85 fix: progress view 2023-06-01 14:29:15 +05:30
Jannat Patel 961f8c1627 Merge branch 'main' of https://github.com/frappe/lms into assignments-in-classes 2023-06-01 12:56:54 +05:30
Jannat Patel 6c7fc9b317 Merge pull request #522 from pateljannat/quiz-answer-fix
fix: possible answer check
2023-05-31 11:30:02 +05:30
Jannat Patel 2afa14d68e fix: possible answer check 2023-05-31 11:13:39 +05:30
Jannat Patel f6cdac4826 feat: assessment in progress 2023-05-31 10:35:12 +05:30
Jannat Patel bb39999b84 feat: assessment tab in class 2023-05-30 22:11:14 +05:30
Jannat Patel 70a036e5a7 fix: remove lesson assignment references 2023-05-26 17:20:53 +05:30
Jannat Patel 0432751050 feat: lesson assignment renamed to lms assignment submission 2023-05-25 22:44:56 +05:30
Jannat Patel 36b3b1d086 Update README.md 2023-05-24 22:46:21 +05:30
Jannat Patel 6a783e540b docs: updated readme logo 2023-05-24 22:39:56 +05:30
Jannat Patel daeeb693d6 Merge pull request #519 from pateljannat/fix-username
fix: remove space from username
2023-05-22 17:54:53 +05:30
Jannat Patel a0b06be422 test: fixed username length test 2023-05-19 18:03:36 +05:30
Jannat Patel 4b2ba96435 test: removed invalid tests 2023-05-19 17:46:55 +05:30
Jannat Patel 10510e204f fix: removed unused functions 2023-05-19 17:34:47 +05:30
Jannat Patel 032749dd01 fix: remove space from username 2023-05-19 16:38:47 +05:30
Jannat Patel dc65bff772 Merge pull request #518 from pateljannat/telemetry-changes
fix: telemetry capture on client side
2023-05-18 14:52:35 +05:30
Jannat Patel 56266a3774 fix: load telemetry js irrespective of telemetry settings 2023-05-18 14:42:27 +05:30
Jannat Patel 93f0f8ab44 fix: telemetry capture on client side 2023-05-18 14:26:48 +05:30
Jannat Patel 611cc4d5a1 Merge pull request #515 from pateljannat/class-improvements
fix: Class improvements
2023-05-16 17:18:53 +05:30
Jannat Patel 552b0c9616 fix: sort classes by start date 2023-05-16 17:10:50 +05:30
Jannat Patel 1327b033e6 fix: removed student details doctype 2023-05-16 16:47:41 +05:30
Jannat Patel ae42828771 fix: course and student interactions in class 2023-05-16 16:14:13 +05:30
Jannat Patel 1df6319164 chore: fixed conflicts 2023-05-15 19:44:50 +05:30
Jannat Patel 95012072fc Merge pull request #514 from pateljannat/social-links
fix: course details link preview
2023-05-15 14:11:52 +05:30
Jannat Patel c01c248202 fix: course details link preview 2023-05-15 13:13:45 +05:30
Jannat Patel 0093025e5d Merge pull request #513 from pateljannat/style-issue
fix: change primary color back to frappe blue
2023-05-12 16:37:46 +05:30
Jannat Patel 20398cb934 fix: primary color 2023-05-12 16:29:39 +05:30
Jannat Patel 2792eb53b7 Merge pull request #511 from pateljannat/analytics
feat: analytics for course creation journey
2023-05-11 16:50:34 +05:30
Jannat Patel b2f8f796b9 Merge pull request #512 from pateljannat/illegal-course
fix: course creation url in LMS
2023-05-11 16:38:23 +05:30
Jannat Patel 39bb3149c9 fix: course creation url in LMS 2023-05-11 16:26:09 +05:30
Jannat Patel 1e610f7fbb feat: analytics for course creation journey 2023-05-11 15:29:11 +05:30
Jannat Patel c760fd5776 Merge pull request #510 from pateljannat/new-design-system
New design system
2023-05-11 12:53:45 +05:30
Jannat Patel 2162963926 fix: removed unnecessary lines of code 2023-05-11 12:40:43 +05:30
Jannat Patel c3f3a110c0 fix: validations and UI 2023-05-11 12:01:32 +05:30
Jannat Patel 0e444ab7d3 test: fixed course creation test 2023-05-10 19:35:45 +05:30
Jannat Patel 752fe5b4ba feat: reorder chapters, lessons 2023-05-08 19:07:28 +05:30
Jannat Patel dce369638a Merge pull request #509 from pateljannat/community-page-guest-access
fix: don't allow guest users to search the people page
2023-05-05 14:50:20 +05:30
Jannat Patel 911cfe9d2f Merge pull request #508 from pateljannat/share-certificate-on-creation
fix: share certificate with member on creation
2023-05-05 13:26:23 +05:30
Jannat Patel f4e882ba3e fix: don't allow guest users to search the people page 2023-05-05 13:22:07 +05:30
Jannat Patel 211c69bb41 feat: Video and Header component for a lesson 2023-05-05 11:53:04 +05:30
Jannat Patel b592172b82 Merge pull request #507 from pateljannat/class-seat-count
feat: Class seat count, start time and end time
2023-05-04 12:11:20 +05:30
Jannat Patel 40445cbb94 fix: share certificate with member on creation 2023-05-04 12:08:01 +05:30
Jannat Patel 20c93b3a6b fix: fetch start and end time in modal 2023-05-03 23:10:46 +05:30
Jannat Patel e2bf324fb4 feat: start and end time in class 2023-05-03 23:08:02 +05:30
Jannat Patel b47ff80e9d feat: seat count from class dialog 2023-05-03 22:47:39 +05:30
Jannat Patel e10feb3c36 feat: seat count in class 2023-05-03 21:02:57 +05:30
Jannat Patel b8471dd753 feat: paid classes and seat count 2023-05-03 20:55:49 +05:30
Jannat Patel 125c06952a Merge branch 'main' of https://github.com/frappe/lms into class-improvements 2023-05-03 17:41:44 +05:30
Jannat Patel 4336839932 feat: edit existing lesson 2023-05-03 17:41:18 +05:30
Jannat Patel bbdfaa32e9 Merge branch 'main' of https://github.com/frappe/lms into new-design-system 2023-05-02 14:46:24 +05:30
Jannat Patel 4f52a73029 Merge pull request #506 from pateljannat/revert-text-editor
revert: text editor for lesson and course
2023-05-02 14:46:03 +05:30
Jannat Patel 1a2f693fea revert: text editor for lesson and course 2023-05-02 14:22:43 +05:30
Jannat Patel ab8b76cada feat: lesson editor youtube and quiz components 2023-05-02 11:09:46 +05:30
Jannat Patel b5240f0eec feat: class improvements 2023-04-27 22:29:45 +05:30
Jannat Patel 7777bd02e3 feat: lesson edit page 2023-04-27 10:20:50 +05:30
Jannat Patel fcdd70dcc7 feat: course outline page 2023-04-26 11:46:08 +05:30
Jannat Patel 4eb5390ad8 feat: redesign lesson page 2023-04-25 20:54:57 +05:30
Jannat Patel 3b5c47222d feat: data in course fields 2023-04-21 18:17:37 +05:30
Jannat Patel f97ae4e4e2 feat: adding editorjs 2023-04-21 09:58:59 +05:30
Jannat Patel 33db16a1a2 Merge branch 'new-editor' of https://github.com/pateljannat/lms into new-design-system 2023-04-20 17:55:36 +05:30
Jannat Patel 6232f8703e feat: new design system for exisitng course home 2023-04-20 17:55:03 +05:30
Jannat Patel e6621ad866 Merge pull request #499 from pateljannat/certificate
feat: Certificate export as PDF
2023-04-18 18:45:34 +05:30
Jannat Patel 6a1533191a Merge branch 'main' into certificate 2023-04-18 18:14:41 +05:30
Jannat Patel a0782c7bf7 feat: editor js import 2023-04-18 11:51:57 +05:30
Jannat Patel 2b6436915d feat: design for course list count 2023-04-18 09:14:59 +05:30
Jannat Patel 4c220a67f2 Merge pull request #498 from pateljannat/new-class-modal
feat: New Class Dialog
2023-04-17 21:52:43 +05:30
Jannat Patel 110aab00d6 fix: removed unnecessary code 2023-04-17 16:53:48 +05:30
Jannat Patel 8e8111d272 fix: certificate page UI 2023-04-17 15:00:18 +05:30
Jannat Patel 53d2e288d4 feat: certificate pdf and custom certificate 2023-04-14 17:38:24 +05:30
Jannat Patel 262c1ea371 feat: certificate download as pdf 2023-04-12 23:15:52 +05:30
Jannat Patel 7be9eb09e8 fix: exponse class info only to moderators 2023-04-11 17:09:38 +05:30
Jannat Patel 5fb7e88318 feat: edit class 2023-04-11 16:45:34 +05:30
Jannat Patel d9c50714f4 fix: reload lesson assignment doctype in patch 2023-04-10 22:44:47 +05:30
Jannat Patel 0a91e5aa05 fix: reload question doctype in patch 2023-04-10 22:35:33 +05:30
Jannat Patel 9b70b4212f feat: class dialog 2023-04-10 22:34:24 +05:30
Jannat Patel 9f525d69b6 Merge pull request #497 from pateljannat/text-editor
feat: Text editor for course description and Lesson Content
2023-04-07 21:25:03 +05:30
Jannat Patel b09c4753da fix: removed print statements 2023-04-07 21:06:16 +05:30
Jannat Patel e4b4556210 feat: text editor for description 2023-04-06 18:01:12 +05:30
Jannat Patel fafd132768 feat: text editor for lesson body 2023-04-05 14:13:18 +05:30
Jannat Patel 67dc6d1f29 Merge pull request #496 from pateljannat/cypress
test: Course Creation UI
2023-04-04 16:48:52 +05:30
Jannat Patel 969cb37cfe test: changed test user 2023-04-03 22:23:04 +05:30
Jannat Patel 94c2be9919 test: removed beforeEach 2023-04-03 22:13:26 +05:30
Jannat Patel 5089285913 test: mariadb password 2023-04-03 22:01:14 +05:30
Jannat Patel e80920ad6c test: setup requirements 2023-04-03 21:46:25 +05:30
Jannat Patel d6606ab898 test: site_config in helper 2023-04-03 21:41:30 +05:30
Jannat Patel 41599348c4 test: added install_dependencies and install script 2023-04-03 15:44:21 +05:30
Jannat Patel 92a8ce6ef4 test: course creation flow 2023-04-03 15:19:54 +05:30
Jannat Patel 690a86bb69 Merge branch 'main' of https://github.com/frappe/lms into cypress 2023-03-31 16:46:29 +05:30
Jannat Patel cde4b61cea Merge pull request #494 from pateljannat/move-lessons
feat: move chapters and lessons
2023-03-31 16:45:26 +05:30
Jannat Patel f361c42a30 feat: move chapters and lessons 2023-03-31 16:30:38 +05:30
Jannat Patel 065646ed5d test: cypress setup 2023-03-29 17:13:51 +05:30
Jannat Patel de399166f1 fix: only allow class students to see progress 2023-03-28 16:30:14 +05:30
Jannat Patel a3a4d7fbd0 Merge pull request #493 from pateljannat/notification-on-assignment-submission
feat: notification on assignment submission
2023-03-28 16:03:23 +05:30
Jannat Patel a7c1595978 fix: spacing in email 2023-03-27 17:38:26 +05:30
Jannat Patel 1a8d113ad8 feat: notification on assignment submission 2023-03-27 17:32:43 +05:30
Jannat Patel 72cbbf147f Merge pull request #491 from pateljannat/quiz-input
feat: quiz with user input
2023-03-27 13:04:39 +05:30
Jannat Patel a0e6462c13 fix: new question with possible answers 2023-03-27 12:53:14 +05:30
Jannat Patel b37f259804 test: quiz with no possible answer 2023-03-27 08:47:07 +05:30
Jannat Patel 2fbe5dacb2 feat: user input quiz portal form 2023-03-24 18:06:42 +05:30
Jannat Patel 3150cf2510 feat: quiz with user input 2023-03-23 22:22:57 +05:30
Jannat Patel 3b1b375d5b Merge pull request #487 from pateljannat/live-class
feat: live class
2023-03-16 12:30:05 +05:30
Jannat Patel 3c0a29d4c7 fix: removed unnecessary changes 2023-03-16 12:24:12 +05:30
Jannat Patel 817bc4441f feat: ui for class cards 2023-03-16 11:23:24 +05:30
Jannat Patel 07e1aaaa66 fix: removed print statements 2023-03-15 12:15:44 +05:30
Jannat Patel 35b77a8908 feat: timezone and recording 2023-03-15 10:52:05 +05:30
Jannat Patel d5b4af95ff Merge branch 'main' of https://github.com/frappe/lms into live-class 2023-03-14 14:36:22 +05:30
Jannat Patel fc6a50b13f docs: docker instructions update in readme 2023-03-14 13:19:27 +05:30
Jannat Patel 8415abec6e Merge pull request #489 from pateljannat/delete-roles-after-uninstall
fix: delete roles after uninstall
2023-03-14 11:01:50 +05:30
Jannat Patel ea9ca67d1e fix: delete using before_uninstall hook 2023-03-14 10:56:08 +05:30
Jannat Patel 8201506c5f fix: delete roles after uninstall 2023-03-14 10:32:31 +05:30
Jannat Patel 5fc879b0ef fix: formatting 2023-03-13 18:14:14 +05:30
Jannat Patel bfde847045 Merge pull request #488 from pateljannat/session_redirection_issues
fix: redirection after completing setup wizard
2023-03-13 18:03:42 +05:30
Jannat Patel d96e3f4f9f fix: don't show past classes 2023-03-13 18:03:03 +05:30
Jannat Patel 0593a9fb30 fix: add student section 2023-03-13 15:47:51 +05:30
Jannat Patel c03cca21e8 fix: redirection after completing setup wizard 2023-03-10 23:08:00 +05:30
Jannat Patel 170b1b0dcc fix: live class card layout 2023-03-09 21:40:49 +05:30
Jannat Patel cb9c7966d9 fix: uncomment live class event creation 2023-03-08 10:19:44 +05:30
Jannat Patel b9c2222951 feat: create event for live class 2023-03-06 19:45:54 +05:30
Jannat Patel dfef5ca26c Merge branch 'main' of https://github.com/frappe/lms into live-class 2023-03-03 18:45:39 +05:30
Jannat Patel bce60a8657 Merge pull request #484 from pateljannat/mini-fix 2023-03-03 18:35:36 +05:30
Jannat Patel 2b244bb4f4 test: fix lms exercise doctype name 2023-03-03 18:23:49 +05:30
Jannat Patel 31b08eb545 test: fix lms exercise doctype name 2023-03-03 18:16:29 +05:30
Jannat Patel 9b7817a57f fix: exercise conflict and progress member 2023-03-03 18:03:35 +05:30
Jannat Patel bb0f3d5962 feat: live class list display 2023-03-03 15:15:49 +05:30
Jannat Patel 23c78d5801 Merge branch 'main' of https://github.com/frappe/lms 2023-03-02 22:48:29 +05:30
Jannat Patel cd3236976f fix: class list settings 2023-03-02 22:48:26 +05:30
Jannat Patel e6096bf9ed feat: live class modal 2023-03-02 19:33:12 +05:30
Jannat Patel a502603915 Merge pull request #483 from pateljannat/certificate-request 2023-03-01 17:49:37 +05:30
Jannat Patel 7566565f55 fix: certificate request notification 2023-02-28 19:55:21 +05:30
Faris Ansari f56f0b5366 Update README.md 2023-02-28 13:21:47 +05:30
Jannat Patel 34870b4625 feat: live class 2023-02-28 09:19:37 +05:30
Jannat Patel 3ee592a989 Merge pull request #482 from pateljannat/misc-fix 2023-02-27 09:13:59 +05:30
Jannat Patel d6d7e05b51 fix: quiz and assignment submission 2023-02-27 09:05:25 +05:30
Jannat Patel 07eaec2ded Merge pull request #480 from pateljannat/class-fixes 2023-02-23 14:12:44 +05:30
Jannat Patel 296a7e6023 fix: translation syntax 2023-02-23 13:04:47 +05:30
Jannat Patel 54827edd7e fix: modified timestamp 2023-02-23 13:01:45 +05:30
Jannat Patel d87fb81cf3 fix: class issues 2023-02-23 12:40:07 +05:30
Jannat Patel 99a7c47798 Merge pull request #478 from pateljannat/preview-video 2023-02-21 10:31:33 +05:30
Jannat Patel 080a02589c fix: accept only embed id for preview video 2023-02-21 09:52:20 +05:30
Jannat Patel d1e7549da9 Merge pull request #477 from pateljannat/evaluation-event 2023-02-17 11:01:54 +05:30
Jannat Patel 8e1ef1dc77 fix: layout of certification request 2023-02-17 10:52:50 +05:30
Jannat Patel 619a2f9d80 fix: only link calendars that are enabled 2023-02-16 20:20:16 +05:30
Jannat Patel 926444767b feat: event for evaluation 2023-02-16 20:11:03 +05:30
Jannat Patel 6bf4020ad1 Merge pull request #474 from fproldan/translations_es 2023-02-09 10:59:50 +05:30
Jannat Patel cb63ad8ed2 Merge pull request #475 from pateljannat/default-view 2023-02-08 13:07:16 +05:30
Jannat Patel 458ed9ad95 feat: default home setting 2023-02-07 19:58:06 +05:30
fproldan a11df1a237 feat: es translations 2023-02-01 12:48:11 -03:00
fproldan 352d4b9ab9 feat: es translations 2023-02-01 12:43:17 -03:00
Jannat Patel 275ded0658 fix: fullscreen for preview video 2023-01-18 15:07:04 +05:30
Jannat Patel c8f3350761 fix: creator patch 2023-01-17 12:27:32 +05:30
Jannat Patel e3112d8dcf fix: og tags 2023-01-16 17:53:54 +05:30
Jannat Patel 5009900c0e Merge pull request #469 from pateljannat/job-changes 2023-01-16 09:54:58 +05:30
Jannat Patel 0f60f1a58b fix: see on website link in job opportunity 2023-01-11 10:11:57 +05:30
Jannat Patel 8f88518187 Merge pull request #464 from pateljannat/people 2023-01-09 16:33:45 +05:30
Jannat Patel 05bcead7d1 fix: profile webform layout 2023-01-09 16:24:24 +05:30
Jannat Patel 6268989306 fix: user custom field positions 2023-01-09 12:51:33 +05:30
Jannat Patel 43ba835b52 fix: renamed community to people 2023-01-06 18:27:04 +05:30
Jannat Patel 9240bc9130 feat: card background 2023-01-05 13:25:59 +05:30
Jannat Patel fb70aee055 chore: fix pre-commit-config 2023-01-05 11:19:48 +05:30
Jannat Patel 7bf69eb77d chore: fix pre-commit-config 2023-01-05 11:18:32 +05:30
Jannat Patel 7ded9a23be Merge pull request #463 from pateljannat/user-singles-issue 2023-01-05 09:38:25 +05:30
Jannat Patel 281af15d65 fix: converted query to qb 2023-01-04 16:57:35 +05:30
Jannat Patel ec31c96120 fix: linters 2023-01-04 16:29:07 +05:30
Jannat Patel b970eb1541 fix: user doctype singles issue 2023-01-03 22:04:59 +05:30
Jannat Patel 7f6b90d5f4 Merge pull request #461 from NagariaHussain/fix-meta 2023-01-03 18:49:52 +05:30
Hussain Nagaria d28096ede6 Revert "feat: add meta image field in LMS course"
This reverts commit 37e8c3ab84.
2023-01-03 17:32:49 +05:30
Hussain Nagaria 12b2b0d0eb fix: linter 2023-01-03 17:01:00 +05:30
Hussain Nagaria a0e281fb30 feat(ux): add View in Website button in LMS Course 2023-01-03 16:52:50 +05:30
Hussain Nagaria 37e8c3ab84 feat: add meta image field in LMS course 2023-01-03 16:48:52 +05:30
Hussain Nagaria 16cb564a6a fix: render meta block in portal base pages 2023-01-03 16:48:16 +05:30
Jannat Patel cd88657bc9 Merge pull request #460 from pateljannat/readme 2022-12-30 18:11:42 +05:30
Jannat Patel d82a32b06a docs: grammar correction in readme 2022-12-30 18:03:01 +05:30
Jannat Patel 094bd943ee docs: updated screenshots in readme 2022-12-30 15:58:31 +05:30
Jannat Patel 1564de346d docs: improved readme 2022-12-30 12:56:41 +05:30
Jannat Patel a5268af269 Merge pull request #459 from pateljannat/onboarding-fixes 2022-12-29 16:43:14 +05:30
Jannat Patel 565d9e093c fix: onboarding header 2022-12-29 16:29:03 +05:30
Jannat Patel cb75606b05 Merge pull request #458 from pateljannat/lesson-issues 2022-12-29 14:39:23 +05:30
Jannat Patel 7c36294359 fix: removed unnecessary code 2022-12-29 11:32:31 +05:30
Jannat Patel ad084389cc fix: minor issues 2022-12-29 11:31:52 +05:30
Jannat Patel aa8c65a00a Merge pull request #454 from pateljannat/course-count 2022-12-28 15:29:06 +05:30
Jannat Patel 95ec31e238 fix: formatting 2022-12-28 15:10:01 +05:30
Jannat Patel b5f3a0fa98 feat: course count in list view 2022-12-28 13:13:03 +05:30
Jannat Patel 36bf0d7fb9 fix: rectified condition for login redirection 2022-12-28 11:07:37 +05:30
Jannat Patel 1719887ac4 Merge pull request #453 from pateljannat/setup-wizard-check-on-login 2022-12-27 17:39:06 +05:30
Jannat Patel 7f149bf3b1 fix: login redirect condition 2022-12-27 17:06:41 +05:30
Jannat Patel f592e6655f fix: docker setup 2022-12-27 16:36:40 +05:30
Jannat Patel 46399c7b13 revert: docker setup 2022-12-27 15:44:12 +05:30
Jannat Patel 0ec66f0f2d fix: docker setup 2022-12-27 15:17:33 +05:30
Jannat Patel 96c8b64e26 Merge pull request #452 from pateljannat/search 2022-12-26 16:46:46 +05:30
Jannat Patel bd0b7a8286 fix: removed unused code 2022-12-26 13:56:03 +05:30
Jannat Patel 263b3ec476 fix: formatting 2022-12-26 13:27:57 +05:30
Jannat Patel 46075130ab fix: search ux 2022-12-26 13:24:29 +05:30
Jannat Patel 0f314bc4e3 feat: new search ui 2022-12-22 15:47:03 +05:30
Jannat Patel 2b45e7d77c Merge pull request #450 from pateljannat/onboarding-signup 2022-12-21 12:04:49 +05:30
Jannat Patel 987c3e5fe2 Merge pull request #451 from mohsinalimat/main 2022-12-21 10:59:33 +05:30
Jannat Patel 1e1580d58a fix: patch format 2022-12-21 10:40:30 +05:30
Jannat Patel da9667e1f7 feat: base template and patch for onboarding 2022-12-20 13:32:30 +05:30
Jannat Patel 9e42fdd786 feat: skip onboarding 2022-12-20 11:34:56 +05:30
Jannat Patel de19abbc5e feat: onboarding ui 2022-12-19 23:25:53 +05:30
MohsinAli 5448a99177 fix: doc url 2022-12-17 17:01:00 +05:30
Jannat Patel f93d7b0193 signup-and-onboarding 2022-12-16 16:44:55 +05:30
Jannat Patel d3bda1b5d0 Merge pull request #449 from pateljannat/revert-navbar-settings 2022-12-15 10:35:16 +05:30
Jannat Patel 1c49e78b13 revert: navbar settings 2022-12-15 10:28:17 +05:30
Jannat Patel 9d373d4091 Merge pull request #446 from pateljannat/navbar-settings
Resolves https://github.com/frappe/lms/issues/442
2022-12-12 13:55:31 +05:30
Jannat Patel 26edfc7bb9 fix: remove after_install hook 2022-12-12 13:47:48 +05:30
Jannat Patel b527c9b160 fix: format 2022-12-12 13:39:01 +05:30
Jannat Patel 0356b8e2d2 feat: pages to navbar settings 2022-12-12 13:31:11 +05:30
Jannat Patel 1bf093d1b9 Merge pull request #443 from pateljannat/course-redirection-issue 2022-12-12 11:37:33 +05:30
Jannat Patel a78d127702 fix: formatting 2022-12-12 11:28:38 +05:30
Jannat Patel 028c0725c3 fix: hide start learning when no lesson in course 2022-12-12 11:17:51 +05:30
Jannat Patel 424d35bf42 fix: course outline style 2022-12-07 16:06:55 +05:30
Jannat Patel 1effdd8482 Merge pull request #441 from pateljannat/rename-instructor-to-course-creator 2022-12-02 23:46:31 +05:30
Jannat Patel a780b7520f fix: rename instructor role to course creator 2022-12-01 15:22:18 +05:30
Jannat Patel 233bf36ef6 Merge pull request #440 from pateljannat/rename-skill 2022-12-01 15:03:01 +05:30
Jannat Patel 616a45ebc5 fix: linter 2022-12-01 13:13:01 +05:30
Jannat Patel 136f16c9cc fix: renamed skill doctype to user skill 2022-12-01 12:48:33 +05:30
Jannat Patel 609628b9cf fix: progress page style 2022-11-29 16:18:15 +05:30
Jannat Patel 1e0d2e0f2a Merge pull request #436 from pateljannat/optimisation 2022-11-28 14:44:12 +05:30
Jannat Patel da7e52f85f perf: course card improvements 2022-11-28 12:40:07 +05:30
Jannat Patel 4640ce82f6 docs: updated readme 2022-11-28 10:26:37 +05:30
Jannat Patel 03ff9e0521 Merge pull request #434 from pateljannat/student-class-view 2022-11-28 10:13:41 +05:30
Jannat Patel f566211d82 feat: students view for classes 2022-11-25 17:46:46 +05:30
Jannat Patel 66ddea2031 Merge pull request #433 from pateljannat/activity-details 2022-11-25 09:29:54 +05:30
Jannat Patel 8b5a9e1639 fix: removed unnecessary lines of code 2022-11-25 09:21:59 +05:30
Jannat Patel 9a183d2ef1 fix: removed quiz result view 2022-11-25 09:02:19 +05:30
Jannat Patel 807f77755e feat: activity details in class 2022-11-24 18:57:45 +05:30
Jannat Patel c0a851e045 Merge pull request #432 from pateljannat/class-evaluations 2022-11-23 15:24:39 +05:30
Jannat Patel 96849afcba fix: formatting 2022-11-23 15:14:15 +05:30
Jannat Patel 91e71091ef fix: show evaluation in read only mode 2022-11-23 15:12:57 +05:30
Jannat Patel f691ebd146 feat: class evaluation 2022-11-23 14:39:18 +05:30
Jannat Patel f620c431a1 Merge pull request #431 from pateljannat/last-active 2022-11-23 09:52:36 +05:30
Jannat Patel 019743b245 fix: formating 2022-11-22 08:46:39 +05:30
Jannat Patel 1d8e3de136 feat: last active time of class students 2022-11-22 08:43:12 +05:30
Jannat Patel 0f46f6a1c1 Merge pull request #429 from pateljannat/classes 2022-11-21 14:08:29 +05:30
Jannat Patel b5078c1f1f fix: removed unused file 2022-11-21 13:36:37 +05:30
Jannat Patel 88f9114dd6 ci: updated flake8 url 2022-11-21 12:33:26 +05:30
Jannat Patel cfcc1b3162 fix: formatting 2022-11-21 12:27:52 +05:30
Jannat Patel ed2fababff feat: assignment comments display 2022-11-21 12:08:17 +05:30
Jannat Patel 74210245cf feat: assignment submission and ui 2022-11-18 17:05:38 +05:30
Jannat Patel a4ec058a81 feat: student progress 2022-11-16 18:43:10 +05:30
Jannat Patel ae2c15fe8c feat: progress page 2022-11-15 18:56:45 +05:30
Jannat Patel d9e44e0f91 fix: renamed instructor and moderator roles 2022-11-14 17:25:07 +05:30
Jannat Patel 3e1f29af48 feat: add and remove students and courses from class 2022-11-14 16:20:13 +05:30
Jannat Patel 7ac3f6d8ef Merge branch 'main' of https://github.com/frappe/lms into classes 2022-11-11 12:00:12 +05:30
Jannat Patel e0f2b9c1ab Merge pull request #428 from pateljannat/lesson-chart 2022-11-11 10:54:52 +05:30
Jannat Patel 3785e7066e fix: formatting 2022-11-11 10:46:35 +05:30
Jannat Patel 157f6b45e9 feat: add pages to nav after install 2022-11-11 10:40:29 +05:30
Jannat Patel c8dbc18179 feat: statistics page 2022-11-10 20:21:43 +05:30
Jannat Patel 1d5d86ef6c feat: claasses 2022-11-09 16:36:26 +05:30
Jannat Patel f1746978b2 Merge pull request #427 from pateljannat/more-stats 2022-11-09 15:33:34 +05:30
Jannat Patel e1f4dae832 fix: linting 2022-11-09 15:27:42 +05:30
Jannat Patel 94e7f6a1f4 feat: course and lesson completion count 2022-11-09 15:21:08 +05:30
Jannat Patel d3ea923da7 fix: profile button visibility 2022-11-09 11:42:16 +05:30
Jannat Patel dc27dd5d7e Merge pull request #425 from pateljannat/stats-format 2022-11-08 11:55:36 +05:30
Jannat Patel 26f76acdd2 fix: format stats 2022-11-08 11:29:46 +05:30
Jannat Patel 719a32e4a5 Merge pull request #424 from pateljannat/workspace-links 2022-11-07 18:59:59 +05:30
Jannat Patel cdf004cdec fix: workspace links 2022-11-07 18:50:43 +05:30
Jannat Patel 9d5f495842 Merge pull request #422 from pateljannat/semgrep 2022-11-04 13:54:08 +05:30
Jannat Patel 8204fa8ee7 test: slugify issue 2022-11-04 13:48:12 +05:30
Jannat Patel 9f9dd25f91 fix: translations 2022-11-04 13:39:25 +05:30
Jannat Patel bd929bfa3f fix: translations 2022-11-04 13:27:14 +05:30
Jannat Patel 5916695d30 ci: removed isort 2022-11-04 12:57:24 +05:30
Jannat Patel cca42dca49 ci: flake8 issues 2022-11-04 12:43:15 +05:30
Jannat Patel 33065c0ed3 fix: pre commit in profile 2022-11-04 11:49:25 +05:30
Jannat Patel 603eddf878 fix: pre commit issues 2022-11-04 11:47:09 +05:30
Jannat Patel cda26ab248 ci: test pre commit 2022-11-04 11:37:59 +05:30
Jannat Patel e73d59d538 ci: pre commit yaml 2022-11-04 11:25:35 +05:30
Jannat Patel 893fac348d ci: pre commit config 2022-11-04 11:22:52 +05:30
Jannat Patel 642b28bad9 Merge pull request #421 from pateljannat/tabs-url 2022-11-04 11:17:23 +05:30
Jannat Patel b9db14ad44 ci: semgrep 2022-11-04 11:14:37 +05:30
Jannat Patel 0c23ead398 fix: tab urls 2022-11-04 10:46:48 +05:30
Jannat Patel e9009dcb9c fix: quiz button mayout 2022-11-03 15:23:16 +05:30
Jannat Patel 0d0e64f930 fix: no cache for quiz 2022-11-03 15:01:06 +05:30
Jannat Patel b1bdf6516e fix: removed unused field 2022-11-03 14:21:06 +05:30
Jannat Patel eca4f89d8b Merge pull request #419 from pateljannat/course-permission-messages 2022-11-03 11:27:46 +05:30
Jannat Patel 199cbcf33f fix: messages if access lacking 2022-11-03 11:20:58 +05:30
Jannat Patel 1f4c7fcb0f fix: course permission messages 2022-11-03 10:59:39 +05:30
Jannat Patel 59b8c781e3 fix: assignment issues 2022-11-01 14:39:30 +05:30
Jannat Patel 9133a3f50b fix: batch issue 2022-11-01 12:12:08 +05:30
Jannat Patel b9f4ba6527 Merge pull request #417 from pateljannat/assignments-refactor 2022-10-31 17:22:36 +05:30
Jannat Patel 7b5fe82de9 fix: removed unused field and code 2022-10-31 17:17:46 +05:30
Jannat Patel d74db85b82 fix: validations 2022-10-31 16:54:22 +05:30
Jannat Patel 915bbdf247 fix: batch context 2022-10-31 11:50:36 +05:30
Jannat Patel b3412b42b7 refactor: assignments 2022-10-28 19:22:48 +05:30
Jannat Patel c6b917fa83 Merge branch 'main' of https://github.com/frappe/lms 2022-10-27 17:40:31 +05:30
Jannat Patel c286afa45f fix: stats graph for the current day 2022-10-27 17:40:27 +05:30
Jannat Patel c74faa3340 Merge pull request #412 from pateljannat/user-onboarding 2022-10-27 13:38:32 +05:30
Jannat Patel fa4e8a1ea6 Merge pull request #413 from pateljannat/stats-template 2022-10-27 11:33:49 +05:30
Jannat Patel 42c664a379 Merge pull request #416 from pateljannat/cohort-fixes 2022-10-27 11:31:38 +05:30
Jannat Patel b84a955ee1 fix: cohorts 2022-10-27 11:23:44 +05:30
Jannat Patel 211ca3111f fix: stats template 2022-10-21 11:00:37 +05:30
Jannat Patel 935e2a976e fix: certifications section in workspace 2022-10-20 20:09:12 +05:30
Jannat Patel 5d38b4dfa0 feat: onboarding 2022-10-20 17:41:26 +05:30
Jannat Patel cbf852828c Merge pull request #409 from pateljannat/reviews-cta 2022-10-19 17:52:49 +05:30
Jannat Patel 7d8b366a73 fix: reviews CTA 2022-10-19 17:29:05 +05:30
Jannat Patel 4ad457d568 chore: fix subscription limit for course members 2022-10-19 09:56:22 +05:30
Jannat Patel 2ab0cb2787 Merge pull request #406 from pateljannat/stats 2022-10-18 09:52:45 +05:30
Jannat Patel 4feab27c59 fix: show stats to guest users 2022-10-18 09:42:29 +05:30
Jannat Patel 3c1449c898 fix: import chart lib from website bundle 2022-10-17 19:47:11 +05:30
Jannat Patel 7d029c5305 fix: stats grid width 2022-10-17 11:26:47 +05:30
Jannat Patel 13274c01d7 fix: chart color 2022-10-17 10:56:06 +05:30
Jannat Patel f37229c202 feat: statistics section 2022-10-14 20:33:27 +05:30
Jannat Patel 61f9ff6892 Merge pull request #405 from pateljannat/cohorts 2022-10-13 20:51:46 +05:30
Jannat Patel 3df08b99b3 fix: cohort translations 2022-10-13 17:28:22 +05:30
Jannat Patel f9748cb723 fix: cohort issue 2022-10-13 17:12:13 +05:30
Jannat Patel 437f637be9 Merge pull request #404 from pateljannat/start-learning-issue 2022-10-13 13:19:39 +05:30
Jannat Patel 7d2b86c548 fix: dont show start learning from course page if disabled 2022-10-13 13:04:22 +05:30
Jannat Patel c10ff68ee7 Merge pull request #383 from joebordes/i18n_es_001 2022-10-13 12:33:09 +05:30
Jannat Patel b2a8dd13f6 Merge pull request #402 from pateljannat/dashboard-profile-merge 2022-10-12 15:55:21 +05:30
Jannat Patel fb8ab132e9 fix: heading for course list page 2022-10-12 11:14:02 +05:30
Jannat Patel 7ce2e45719 Merge branch 'main' of https://github.com/frappe/lms into dashboard-profile-merge 2022-10-12 10:53:38 +05:30
Jannat Patel c6d15d2605 Merge pull request #401 from pateljannat/ui-components 2022-10-12 10:53:12 +05:30
Jannat Patel 8d57ea4216 fix: better modal UI 2022-10-12 10:44:28 +05:30
Jannat Patel fdf1bbd1e2 refactor: merged profile and dashboard page 2022-10-11 17:23:36 +05:30
Jannat Patel 662813b378 Merge pull request #400 from pateljannat/quiz-submission 2022-10-11 10:13:18 +05:30
Jannat Patel 8709ae7113 fix: quiz submission 2022-10-11 09:53:21 +05:30
Jannat Patel ac22b71171 Merge pull request #397 from pateljannat/misc-fixes 2022-10-10 15:47:12 +05:30
Jannat Patel 328d1d6546 fix: label of login button in review section 2022-10-10 13:31:15 +05:30
Jannat Patel 11277d2ef3 fix: misc ux 2022-10-10 13:11:49 +05:30
Jannat Patel 54dc6102a6 Merge pull request #395 from pateljannat/delete-custom-fields-on-uninstall 2022-10-07 10:07:16 +05:30
Jannat Patel c0c9b50a5f fix: delete custom fields after app in uninstalled 2022-10-06 18:08:27 +05:30
Jannat Patel e780a6fc7c fix: get course directly from lesson for assignment folder 2022-10-04 19:23:51 +05:30
Jannat Patel fd89b288e5 fix: username validation 2022-10-04 18:11:55 +05:30
joebordes a05c3a5e94 i18n(ES) syntax and CSV format 2022-10-02 03:19:12 +02:00
Jannat Patel 43e91c9275 Merge pull request #382 from pateljannat/lms-statistics 2022-09-30 11:17:32 +05:30
Jannat Patel 26dd2935d7 fix: renamed dashboard stats to LMS Statistics 2022-09-30 10:51:51 +05:30
Jannat Patel f653871e3a fix: duplicate function names 2022-09-29 18:30:45 +05:30
Jannat Patel 89b91a081c fix: course restriction condition 2022-09-29 18:02:50 +05:30
Jannat Patel 246b26079b perf: course cards get all memberships at once 2022-09-29 16:59:08 +05:30
Jannat Patel 41a9e422d5 fix: course list page performance 2022-09-29 13:19:09 +05:30
Jannat Patel 0704d7f4a4 Merge pull request #381 from pateljannat/dashboard-stats 2022-09-29 09:04:15 +05:30
Jannat Patel 1e66742d02 fix: batch creation error 2022-09-28 21:55:35 +05:30
Jannat Patel d55f827d93 feat: dashboard stat 2022-09-28 18:34:14 +05:30
Jannat Patel 40c68d4d63 Merge pull request #380 from pateljannat/progress-refactor 2022-09-28 12:58:15 +05:30
Jannat Patel 5c58ddc800 fix: progress tracking 2022-09-28 12:42:15 +05:30
Jannat Patel 94171cbc0e Merge pull request #379 from pateljannat/notifications 2022-09-27 18:22:40 +05:30
Jannat Patel cf8549bb28 fix: removed unused functions 2022-09-27 18:21:57 +05:30
Jannat Patel a291d73828 feat: show notifications from logs 2022-09-27 18:13:46 +05:30
Jannat Patel a6156ec863 feat: get notifications 2022-09-26 22:09:18 +05:30
Jannat Patel be583cc86d fix: conflicts 2022-09-26 09:45:16 +05:30
Jannat Patel 00c55f5e82 Merge branch 'main' of https://github.com/frappe/lms 2022-09-23 07:12:16 +05:30
Jannat Patel c9fd1f5252 fix: discussions component visibility conditions 2022-09-23 07:12:12 +05:30
Jannat Patel 992d1065ac Merge pull request #378 from pateljannat/subscription 2022-09-22 22:18:09 +05:30
Jannat Patel 247017d19a fix: changed essential plan to pro 2022-09-21 20:38:56 +05:30
Jannat Patel b9fe05c27f feat: subscription add ons 2022-09-21 17:37:56 +05:30
Jannat Patel b01a2cfd79 Merge pull request #377 from pateljannat/private-files 2022-09-20 15:39:07 +05:30
Jannat Patel 37f2e7eeda fix: check if path is present 2022-09-19 17:56:49 +05:30
Jannat Patel 4ba6ea9190 fix: removed unnecessary import 2022-09-19 10:34:49 +05:30
Jannat Patel 7c1c061681 fix: change private files to public for company logo, user image and course image 2022-09-16 19:06:53 +05:30
Jannat Patel 47e4175c9a Merge pull request #376 from pateljannat/ux-fix 2022-09-16 16:10:49 +05:30
Jannat Patel 023fd73b86 fix: removed unused classes 2022-09-16 16:05:33 +05:30
Jannat Patel f7ba72217b fix: controls script loading 2022-09-16 11:37:11 +05:30
Jannat Patel 47b9b1dcd6 fix: show first chapter and question form by default 2022-09-15 22:52:17 +05:30
Jannat Patel f3adbfef55 Merge pull request #375 from pateljannat/fixes 2022-09-14 20:42:54 +05:30
Jannat Patel bc9225f8ed fix: course count on profile page 2022-09-14 20:07:58 +05:30
Jannat Patel 62ac0089c9 fix: misc ux 2022-09-14 17:10:38 +05:30
Jannat Patel af059141f0 fix: profile ux 2022-09-13 17:48:54 +05:30
Jannat Patel efe73a21d9 fix: profile ui 2022-09-13 17:13:25 +05:30
Jannat Patel adad299724 Merge pull request #374 from pateljannat/certificate-on-profile 2022-09-13 13:11:38 +05:30
Jannat Patel 15b832eefb fix: styles 2022-09-13 13:03:21 +05:30
Jannat Patel 434b6fdc8f Merge pull request #373 from pateljannat/description-field 2022-09-13 12:49:40 +05:30
Jannat Patel 99c886a9cb fix: conflicts 2022-09-13 12:49:06 +05:30
Jannat Patel 7d18215bc9 feat: certificates section in profile 2022-09-13 12:47:01 +05:30
Jannat Patel 7d7f674d9e fix: empty states 2022-09-12 18:17:06 +05:30
Jannat Patel 46861486c9 fix: text editor for description field 2022-09-12 13:00:51 +05:30
Jannat Patel d959cacd15 Merge pull request #372 from pateljannat/course-moderator 2022-09-12 12:35:44 +05:30
Jannat Patel d8d0ce5b45 fix: empty state for review section 2022-09-12 12:15:30 +05:30
Jannat Patel b94a4ef9d6 feat: role settings from profile 2022-09-12 12:06:36 +05:30
Jannat Patel 212ed8e428 feat: course settings from website 2022-09-09 18:16:02 +05:30
Jannat Patel 6d14bc2f54 fix: encode course image 2022-09-09 16:04:53 +05:30
Jannat Patel 9dc10c3756 feat: allow moderators to edit course 2022-09-09 15:37:35 +05:30
Jannat Patel 316e7be51e Merge branch 'main' of https://github.com/frappe/lms into course-moderator 2022-09-09 11:54:39 +05:30
Jannat Patel 14842a6d56 Merge pull request #371 from pateljannat/ui-fix 2022-09-06 13:12:33 +05:30
Jannat Patel ce7f3ffca9 fix: no preview message 2022-09-06 11:38:40 +05:30
Jannat Patel 4c969420f3 feat: course moderator 2022-09-06 11:19:11 +05:30
Jannat Patel 36aca1e664 fix: ui for review, instructors and profile 2022-09-05 18:05:16 +05:30
Jannat Patel 3a08f57fb1 fix: context for dashboard 2022-09-05 14:53:13 +05:30
Jannat Patel 8f86a8aba6 chore: removed log 2022-09-05 14:46:40 +05:30
Jannat Patel e84e02ff07 fix: profile, dashboard and tests 2022-09-05 13:32:51 +05:30
Jannat Patel 7ef625c598 chore: logging user 2022-09-05 11:35:21 +05:30
Jannat Patel 2819e55a61 fix: dashboard function parameters 2022-09-05 10:34:40 +05:30
Jannat Patel 25d9b08dd5 Merge pull request #370 from pateljannat/dashboard 2022-09-05 09:32:16 +05:30
Jannat Patel 6a760c3019 chore: removed logs 2022-09-05 09:25:00 +05:30
Jannat Patel 8088a464ad fix: dashboard creators section issue 2022-09-05 09:16:57 +05:30
Jannat Patel e41c83a68c fix: spelling in readme 2022-09-02 17:58:52 +05:30
Jannat Patel 2d5b8430bd fix: images and links in readme 2022-09-02 17:55:00 +05:30
Jannat Patel eabbe3e3ed fix: readme 2022-09-02 17:50:29 +05:30
Jannat Patel c37cdbdc5f chore: added logs 2022-09-02 17:18:57 +05:30
Jannat Patel 8a0df559c3 Merge pull request #368 from pateljannat/video-and-quiz-field 2022-09-02 14:58:17 +05:30
Jannat Patel dfc1c9c228 feat: seperate inputs for adding youtube video and quiz 2022-09-02 13:05:26 +05:30
Jannat Patel ad20c1cbf1 fix: membership doctype structure 2022-09-01 17:12:32 +05:30
Jannat Patel 6f4677b36b fix: ui issues 2022-08-31 15:34:18 +05:30
Jannat Patel b3a9274cd3 fix: minor UI 2022-08-30 12:50:26 +05:30
Jannat Patel 7a7bc3e0db fix: removed desk access from course instructor role 2022-08-29 09:21:45 +05:30
Jannat Patel 425bb54057 feat: notifications tab in dashboard 2022-08-29 09:19:06 +05:30
Jannat Patel d82df84cf6 Merge pull request #357 from pateljannat/new-course-ui 2022-08-26 17:39:34 +05:30
Jannat Patel 7d697f068f fix: ux issues 2022-08-26 16:35:02 +05:30
Jannat Patel 4499b34b51 fix: minor issues 2022-08-24 18:20:19 +05:30
Jannat Patel 9c6cc8ecd4 fix: removed web forms of old course creation flow 2022-08-23 18:27:39 +05:30
Jannat Patel 668130d443 feat: access for course creation 2022-08-22 12:58:54 +05:30
Jannat Patel 5aba690318 feat: update quiz 2022-08-19 18:22:43 +05:30
Jannat Patel 7397bf389e feat: add a new quiz 2022-08-19 11:43:49 +05:30
Jannat Patel e1b16e9ae3 feat: quiz-creation-ui 2022-08-18 19:52:27 +05:30
Jannat Patel eb50f6fd8f feat: quiz listing 2022-08-16 17:08:43 +05:30
Jannat Patel 5d6dc16a19 fix: create course button and search bar width 2022-08-12 12:34:04 +05:30
Jannat Patel 64dc76d616 fix: text editor for lesson 2022-08-12 09:09:50 +05:30
Jannat Patel 301664ce93 fix: ui for course creation 2022-08-10 19:45:58 +05:30
Jannat Patel a4534d8f3e feat: update lesson 2022-08-09 18:32:29 +05:30
Jannat Patel f161173cb6 Merge pull request #358 from pateljannat/download-certificate-pdf 2022-08-08 16:47:46 +05:30
Jannat Patel c58f5efcdd feat: export certificate 2022-08-08 16:40:40 +05:30
Jannat Patel 65edd2ce22 feat: new lesson redirect 2022-08-08 11:47:23 +05:30
Jannat Patel 0723f3091c fix: removed unnecessary code 2022-08-01 17:56:45 +05:30
Jannat Patel a95204f02e feat: add and update a chapter 2022-08-01 17:53:57 +05:30
Jannat Patel 6dd12e111d feat: new course ui 2022-07-28 18:22:57 +05:30
Jannat Patel 6e741bd800 Merge pull request #354 from pateljannat/readme-update 2022-07-19 15:40:54 +05:30
Jannat Patel d37e53bd8e chore: center align readme header 2022-07-19 15:15:04 +05:30
Jannat Patel fd3585697b chore: readme update 2022-07-19 15:10:46 +05:30
Jannat Patel e92e6ec1c6 fix: removed the blue arrow from the course cards template 2022-07-13 16:05:24 +05:30
Jannat Patel f0c89cbbba Merge pull request #352 from pateljannat/delete-old-module-documents
fix: delete doctypes from old modules
2022-07-07 17:16:01 +05:30
Jannat Patel d20f932316 fix: delete webforms of unused modules 2022-07-07 17:08:53 +05:30
Jannat Patel e011ef469f fix: delete doctypes from old modules 2022-07-05 18:50:10 +05:30
Jannat Patel 384850b452 fix: don't load api file during app init 2022-07-04 16:36:22 +05:30
Jannat Patel e467aba32f Merge pull request #350 from pateljannat/job-board-redesign 2022-07-01 18:08:43 +05:30
Jannat Patel 56c51b73b0 fix: job details redesign 2022-07-01 17:57:52 +05:30
Jannat Patel 1aa82dd03e Merge pull request #351 from frappe/ankush-patch-1 2022-07-01 16:27:43 +05:30
Ankush Menat a3b7c67ef9 ci: use python 3.10 2022-07-01 16:01:53 +05:30
Jannat Patel de0200f352 fix: job list ui 2022-06-30 17:45:48 +05:30
Jannat Patel 999c267dfe Merge pull request #348 from pateljannat/web-templates
fix: web template ui
2022-06-29 16:13:10 +05:30
Jannat Patel c9a6c2948e fix: new design for testimonial cards 2022-06-29 16:05:18 +05:30
Jannat Patel 041157a85f fix: subtitle field for testimonial and course cards 2022-06-28 18:00:53 +05:30
Jannat Patel cd009936e2 fix: save member info in quiz submission 2022-06-27 17:42:42 +05:30
Jannat Patel f43dfd47d0 revert: markdown file changes 2022-06-24 19:11:18 +05:30
Jannat Patel 7082467352 fix: made bio field small text in profile edit form 2022-06-24 19:10:42 +05:30
Jannat Patel f05d3581c1 Merge pull request #346 from pateljannat/user-name-hooks-fix
fix: renamed apps in hooks and rectified username validation conditions
2022-06-23 10:26:35 +05:30
Jannat Patel 02e560cb18 fix: renamed apps in hooks and rectified username validation conditions 2022-06-23 10:12:26 +05:30
Jannat Patel b2d38ad9d6 Merge pull request #345 from pateljannat/minor-fix 2022-06-21 16:37:44 +05:30
Jannat Patel 2743f1adc9 fix: removed unnecessary space 2022-06-21 16:19:42 +05:30
Jannat Patel 5e875b6d71 refactor: member field in lms quiz submission 2022-06-20 17:44:14 +05:30
Jannat Patel 6ccb5e8dbf Merge pull request #344 from pateljannat/testimonials-redesign 2022-06-17 19:02:25 +05:30
Jannat Patel ad42a3d41c fix: testimonials new design 2022-06-17 18:55:26 +05:30
Jannat Patel b40e0068ab fix: show only published courses in dashboard 2022-06-15 09:48:29 +05:30
Jannat Patel f8dbbc1d11 fix: quiz question style 2022-06-14 17:12:32 +05:30
Jannat Patel 951070757c fix: space between lock icon and lesson title 2022-06-13 17:57:28 +05:30
Jannat Patel c2a93c6c02 fix: course card template icon and translation 2022-06-09 16:39:29 +05:30
Jannat Patel 9dc82963c4 Merge pull request #342 from pateljannat/quiz-style-fixes
fix: quiz ui
2022-06-08 10:06:35 +05:30
Jannat Patel 148fce42ba fix: quiz ui 2022-06-08 09:56:19 +05:30
Jannat Patel 92f1263314 fix: course card meta info 2022-06-07 13:12:07 +05:30
Jannat Patel 5fad44369c Merge pull request #339 from fproldan/translations 2022-06-07 11:37:24 +05:30
Jannat Patel eb3d7c9615 Merge branch 'main' into translations 2022-06-07 11:28:42 +05:30
Jannat Patel 5437a98539 Merge pull request #341 from pateljannat/ux-fixes
fix: replaced some dialogs with alerts
2022-06-07 11:06:53 +05:30
Francisco Roldan d9b26f31f8 trans: profile 2022-06-06 14:50:08 -03:00
Jannat Patel 9916ec132b fix: revert unnecessary changes 2022-06-06 20:53:22 +05:30
Jannat Patel 1f3806a7bd fix: replaced some dialogs with alerts 2022-06-06 11:15:06 +05:30
Jannat Patel 55a770f129 fix: certificate request notification template 2022-06-03 13:36:50 +05:30
Jannat Patel d742d595b2 feat: notifications for certificate request 2022-06-03 12:01:58 +05:30
Jannat Patel 9f575902b0 fix: lms certificate existing request condition 2022-06-03 09:16:54 +05:30
Jannat Patel 6e49cf14fa fix: validation for certificate request 2022-06-02 19:28:40 +05:30
Jannat Patel 4d96abb786 Merge branch 'main' of https://github.com/frappe/lms 2022-05-27 11:44:45 +05:30
Jannat Patel b6d9470a4e fix: removed meta info from certificate page 2022-05-27 11:44:41 +05:30
Francisco Roldan 6ef86dce8c fix: es 2022-05-26 09:52:04 -03:00
Francisco Roldan 5a33f4c707 fix: translations 2022-05-26 09:49:51 -03:00
Francisco Roldan 119c1cbb35 fix: translations 2022-05-26 09:48:35 -03:00
Francisco Roldan 2be2646d95 fix: translations 2022-05-26 09:45:56 -03:00
Francisco Roldan 0609174a14 fix: translations 2022-05-26 09:43:11 -03:00
Francisco Roldan 227ca0ed41 fix: translations 2022-05-26 09:34:02 -03:00
Francisco Roldan cc90ccece2 feat: translations 2022-05-25 14:38:50 -03:00
Francisco Roldan 9ab92165c8 feat: translations 2022-05-25 14:24:54 -03:00
Jannat Patel e1fc0d08b7 Merge pull request #337 from pateljannat/ui-fixes
fix: course banner spaces
2022-05-25 14:33:56 +05:30
Jannat Patel 21dad2d72e fix: eval slot display 2022-05-25 13:20:39 +05:30
Jannat Patel 87fe3e72a2 fix: course certificate price display 2022-05-24 16:51:55 +05:30
Jannat Patel c92220f1e5 Merge branch 'main' of https://github.com/frappe/lms into ui-fixes 2022-05-24 11:05:20 +05:30
Jannat Patel eabeb612b4 fix: adding missing closing div for job details 2022-05-23 17:14:46 +05:30
Jannat Patel 900e61291a Merge pull request #336 from pateljannat/format-amount 2022-05-19 17:17:10 +05:30
Jannat Patel 51d9f1943b fix: format certificate amount on course home page 2022-05-19 17:00:19 +05:30
Jannat Patel 282b07dffc fix: format amount on course cards 2022-05-19 16:49:53 +05:30
Jannat Patel 6521415ae0 fix: course overlay site 2022-05-19 15:59:41 +05:30
Jannat Patel 2819be4508 Merge branch 'main' of https://github.com/frappe/lms into ui-fixes 2022-05-18 11:13:26 +05:30
Jannat Patel a60805a971 Merge pull request #335 from pateljannat/quiz-timer 2022-05-18 11:04:26 +05:30
Jannat Patel af21d33165 fix: page reload condition 2022-05-18 10:47:49 +05:30
Jannat Patel e465ad58ca fix: removed unnecessary tags 2022-05-17 17:47:27 +05:30
Jannat Patel cd56fc6179 fix: banner style and page exit condition 2022-05-17 17:29:11 +05:30
Jannat Patel 1ef70dd4e4 fix: submit quiz if user leaves page 2022-05-17 17:12:54 +05:30
Jannat Patel a460ea5194 fix: start banner style 2022-05-17 16:04:03 +05:30
Jannat Patel 5ebf7b7992 fix: start banner style 2022-05-17 15:31:05 +05:30
Jannat Patel c9b50e7db6 feat: timer in quiz 2022-05-17 11:52:10 +05:30
Jannat Patel b9993796a0 fix: certificate style and meta 2022-05-16 13:22:30 +05:30
Jannat Patel 4fb2241621 feat: see on website link for lms certificate 2022-05-13 19:47:36 +05:30
Jannat Patel fa49dc08a3 fix: certificate footer style 2022-05-13 18:51:07 +05:30
Jannat Patel 3d939f18df fix: removed get certificate button from course page 2022-05-11 15:08:37 +05:30
Jannat Patel 0d38b9aab1 fix: course banner spaces 2022-05-11 15:07:26 +05:30
Jannat Patel 28207f45cd Merge pull request #332 from pateljannat/certificate-design 2022-05-11 14:39:25 +05:30
Jannat Patel 72a5e9eb05 fix: return 1.1 if current lesson not found 2022-05-09 15:05:50 +05:30
Jannat Patel 91dc99d8ef fix: certificate custom and style 2022-05-09 13:17:20 +05:30
Jannat Patel 305a34b26d fix: course card info condition 2022-05-06 09:45:42 +05:30
Jannat Patel 67349bbce6 fix: job list view card style 2022-05-06 08:39:34 +05:30
Jannat Patel 242ba89b95 fix: course card cleanup 2022-05-04 19:10:40 +05:30
Jannat Patel 295280f8cf Merge pull request #331 from pateljannat/cleanup
fix: UI Cleanup
2022-05-04 17:53:31 +05:30
Jannat Patel eb0f4728c4 fix: course page style 2022-05-04 17:40:48 +05:30
Jannat Patel 8017715bc7 fix: ui cleanup 2022-05-04 16:54:16 +05:30
Jannat Patel 503c74c488 fix: show currency and certificate price in all course cards 2022-04-29 15:05:29 +05:30
Jannat Patel 32cdaa8baa Merge pull request #329 from pateljannat/max-eval-attempt 2022-04-28 16:37:21 +05:30
Jannat Patel 83176a0293 fix: renamed reapplication field to duration 2022-04-28 16:30:51 +05:30
Jannat Patel 5db3d14b17 test: evaluation eligibility 2022-04-28 14:10:10 +05:30
Jannat Patel bc6ae25aa6 Merge branch 'main' of https://github.com/frappe/lms into max-eval-attempt 2022-04-27 17:34:10 +05:30
Jannat Patel 8e3900fab7 Merge branch 'main' of https://github.com/frappe/lms 2022-04-27 17:21:39 +05:30
Jannat Patel 51b3d59094 fix: certificate price on course card web template 2022-04-27 17:21:36 +05:30
Jannat Patel 3585645580 feat: conditions for evaluation eligibility 2022-04-27 17:20:30 +05:30
Jannat Patel 1e3c20d118 Merge branch 'main' of https://github.com/frappe/lms into max-eval-attempt 2022-04-27 10:48:46 +05:30
Jannat Patel f83f13af59 Merge pull request #328 from pateljannat/course-outline-start-learning-issue
fix: no preview modal for upcoming courses.
2022-04-26 15:44:00 +05:30
Jannat Patel 54d0bc56a4 fix: indentation 2022-04-26 15:30:52 +05:30
Jannat Patel c722673dbd fix: dont show notify button from outline if already opted 2022-04-26 15:27:35 +05:30
Jannat Patel 88d34a9daf fix: no preview modal for upcoming courses. 2022-04-26 15:14:31 +05:30
Jannat Patel e91237ec05 feat: check no of attempts 2022-04-26 13:17:09 +05:30
Jannat Patel 430a2bc08d feat: max attempts fields 2022-04-25 18:48:31 +05:30
Jannat Patel 3bbe5d33d3 Merge pull request #327 from pateljannat/image-in-lesson-webform
feat: image markdown extension
2022-04-25 11:42:58 +05:30
Jannat Patel 674c6a1684 fix: web form description and redirection 2022-04-25 10:42:07 +05:30
Jannat Patel f34519e3ff fix: upload image component in lesson web form 2022-04-22 12:22:25 +05:30
Jannat Patel f047be816a fix: validate url for job opportunity 2022-04-21 11:56:24 +05:30
Jannat Patel 593c20d62b fix: login without user category 2022-04-21 08:42:18 +05:30
Jannat Patel a4bfad6138 fix: class name change for testimonial author 2022-04-20 17:54:37 +05:30
Jannat Patel 89de3c5f7a fix: class name change for testimonial author 2022-04-20 17:48:44 +05:30
Jannat Patel 81fb664ad9 feat: image markdown extension 2022-04-20 17:45:40 +05:30
Jannat Patel b65597b884 fix: replaced html5lib with lxml for lesson markdown 2022-04-20 11:26:54 +05:30
Jannat Patel d5423947f3 Merge pull request #325 from pateljannat/designation-to-category 2022-04-20 10:36:48 +05:30
Jannat Patel f80db23642 fix: changed designation to user category 2022-04-20 10:22:35 +05:30
Jannat Patel 935906e328 Merge pull request #324 from pateljannat/designation-during-signup
feat: Designation during signup
2022-04-19 16:39:34 +05:30
Jannat Patel 3ed7f68054 fix: data attribute for certificate price 2022-04-19 16:18:48 +05:30
Jannat Patel c894b75f4b feat: designation during signup 2022-04-19 15:53:25 +05:30
Jannat Patel ef43d6905f fix: take country from doctype at signup 2022-04-14 09:03:18 +05:30
Jannat Patel ab7ebedcd5 fix: check evaluator schedule for certificate request 2022-04-13 17:53:46 +05:30
Jannat Patel 8ca19afd87 Merge pull request #323 from pateljannat/start-learning-fixes 2022-04-11 16:08:32 +05:30
Jannat Patel 70e1e550e3 fix: certificate request flow and other minor changes 2022-04-11 15:35:40 +05:30
Jannat Patel cb0087c433 fix: no preview modal start learning button 2022-04-07 23:03:53 +05:30
Jannat Patel d867f86c08 fix: replaced save with insert for certificate doctype rename patch 2022-04-07 22:46:40 +05:30
Jannat Patel 1891029eed fix: ignore mandatory for certificate doctype rename patch 2022-04-07 22:38:49 +05:30
Jannat Patel 157090a122 fix: reload doc in certificate doctype rename patch 2022-04-07 22:33:06 +05:30
Jannat Patel 0ddf2aad79 fix: removed certification student to member rename patch 2022-04-07 22:27:26 +05:30
Jannat Patel 4f47a5032c fix: removed post_model_sync from patches.txt 2022-04-07 22:13:19 +05:30
Jannat Patel ae957ab642 fix: average rating precision 2022-04-07 21:58:49 +05:30
Jannat Patel b69a7022b5 Merge pull request #319 from pateljannat/certification 2022-04-07 14:58:27 +05:30
Jannat Patel c19bd88a8e fix: added post_model_sync in patches.txt 2022-04-07 14:42:05 +05:30
Jannat Patel 4967b70e7c fix: validate same slot addition twice 2022-04-07 14:32:02 +05:30
Jannat Patel cdfad8cc67 feat: cerificate price 2022-04-07 12:57:42 +05:30
Jannat Patel dcaccaca35 fix: certificate design 2022-04-05 21:13:21 +05:30
Jannat Patel d954262184 fix: redirect to list when course does not exist 2022-04-04 12:46:35 +05:30
Jannat Patel 208720545e Merge branch 'main' of https://github.com/frappe/lms into certification 2022-04-01 18:59:35 +05:30
Jannat Patel 2cbadc6946 Merge pull request #311 from pateljannat/discussion-component-redesign 2022-04-01 18:58:59 +05:30
Jannat Patel ebfa49ed8e chore: renamed lms certification to lms certificate 2022-04-01 18:56:57 +05:30
Jannat Patel e70c3ef939 feat: request for certification 2022-04-01 17:30:17 +05:30
Jannat Patel 0523f701c2 fix: profile page fixes 2022-03-31 18:03:11 +05:30
Jannat Patel c6b46295bc fix: date field 2022-03-31 17:54:31 +05:30
Jannat Patel 16ddfb2a20 feat: certification request 2022-03-30 22:52:38 +05:30
Jannat Patel ca5ea6032c feat: certificate evaluation 2022-03-29 16:49:50 +05:30
Jannat Patel b4eda0e7cd Merge pull request #318 from pateljannat/workspace-issue 2022-03-28 17:52:42 +05:30
Jannat Patel 9d2a9bbd9c fix: workspace published field filter 2022-03-28 17:40:55 +05:30
Jannat Patel ef13c8fe8d fix: update patch date 2022-03-25 18:53:35 +05:30
Jannat Patel aa6932f547 fix: reload doctype in patch 2022-03-25 18:53:07 +05:30
Jannat Patel 5d3c132e83 Merge pull request #317 from pateljannat/field-name-uniformity 2022-03-25 16:13:25 +05:30
Jannat Patel 56f4f6c977 fix: patch for published field 2022-03-25 15:56:43 +05:30
Jannat Patel 77df068fea fix: field cleanup 2022-03-24 18:59:58 +05:30
Jannat Patel b9a1bf9f24 fix: conflicts 2022-03-24 09:56:54 +05:30
Jannat Patel 2b348916f4 Merge pull request #316 from pateljannat/rename-to-lms 2022-03-23 19:20:36 +05:30
Jannat Patel 70bc5ea2ec fix: conflicts 2022-03-23 19:13:30 +05:30
Jannat Patel eff9e553a1 fix: course home card ui 2022-03-23 19:10:02 +05:30
Jannat Patel e1bfca1883 fix: breadcrumb from lesson page 2022-03-23 15:20:57 +05:30
Jannat Patel 190dbab3d0 fix: ui issues 2022-03-23 15:18:32 +05:30
Jannat Patel a1895b1f78 fix: removed unused modules from modules.txt 2022-03-21 14:14:24 +05:30
Jannat Patel 1091774003 Merge branch 'main' of https://github.com/frappe/school into rename-to-lms 2022-03-21 12:58:06 +05:30
Jannat Patel ae29eb35fd fix: removed unused modules 2022-03-21 12:57:16 +05:30
Jannat Patel 5ca0a89789 fix: reload doctypes in patch 2022-03-21 10:16:09 +05:30
Jannat Patel 6c6e836f0d fix: reload doctypes in recent patches 2022-03-21 09:47:18 +05:30
Jannat Patel c971d34d67 refactor: renamed app to lms 2022-03-19 17:30:00 +05:30
Jannat Patel 1b04615bff Merge pull request #313 from pateljannat/course-creation-through-ui 2022-03-19 14:19:25 +05:30
Jannat Patel 40eb8dec68 fix: branch shift for semantic 2022-03-19 12:57:10 +05:30
Jannat Patel 2556e98c26 fix: version change for semantic pull request 2022-03-19 12:33:56 +05:30
Jannat Patel 2204da25ed fix: semantic pull request workflow 2022-03-19 12:22:13 +05:30
Jannat Patel ab1eb6de6b Merge pull request #315 from pateljannat/semantic-pull-request 2022-03-19 11:32:51 +05:30
Jannat Patel 16278a72e9 chore: semantic pull request check 2022-03-19 11:20:37 +05:30
Jannat Patel 573a1f22dc fix: button positions on course home 2022-03-19 10:09:32 +05:30
Jannat Patel da370a7dd2 fix: better msg on web form save 2022-03-19 09:31:39 +05:30
Jannat Patel 6567660639 Merge pull request #314 from pateljannat/ui-cleanup 2022-03-17 15:23:51 +05:30
Jannat Patel 984054f00f fix: icon position on course card 2022-03-17 15:17:21 +05:30
Jannat Patel 9351edebe0 fix: jobs, quiz and community page cleanup 2022-03-17 14:23:06 +05:30
Jannat Patel 36465f0859 fix: icon background and space cleanup 2022-03-17 11:25:34 +05:30
Jannat Patel ef5cf4bd96 fix: course home, course cards and course outline cleanup 2022-03-16 18:53:09 +05:30
Jannat Patel 27e1aec001 fix: dashboard links, web form redirects and patch for status 2022-03-15 16:51:39 +05:30
Jannat Patel aa9ef65375 dashboard and patch for lesson 2022-03-14 19:07:02 +05:30
Jannat Patel c8af6d3672 feat: course creation from portal setting 2022-03-11 11:15:13 +05:30
Jannat Patel ffe5370264 Merge branch 'main' of https://github.com/frappe/school 2022-03-10 08:42:17 +05:30
Jannat Patel ef0156c068 fix: removed batch from list and filter of membership 2022-03-10 08:42:13 +05:30
Jannat Patel 00883170f3 Merge pull request #312 from pateljannat/cookie-policy 2022-03-10 08:41:35 +05:30
Jannat Patel fb72704a33 feat: cookie policy 2022-03-09 14:32:50 +05:30
Jannat Patel 8f9cd72975 feat: course creation from ui 2022-03-09 12:29:03 +05:30
Jannat Patel 913e87c4f5 Merge branch 'main' of https://github.com/frappe/school into course-creation-through-ui 2022-03-07 18:28:54 +05:30
Jannat Patel 3bdf6df70d fix: allow locked lessons o instructors through outline 2022-03-07 18:28:12 +05:30
Jannat Patel 5e973b21ae feat: course web form 2022-03-07 18:21:11 +05:30
Jannat Patel 23e2611725 feat: discussions redesign 2022-03-07 12:52:09 +05:30
Jannat Patel f8784afd72 Merge pull request #310 from pateljannat/minor-fixes 2022-02-24 14:24:41 +05:30
Jannat Patel 46a73c8ef1 fix: classname 2022-02-24 12:56:39 +05:30
Jannat Patel bcd80b616d fix: empty states redesign and misc changes 2022-02-24 12:40:13 +05:30
Jannat Patel b5d870d885 fix: indentation and headline field 2022-02-23 17:39:04 +05:30
Jannat Patel f9ac77606e Merge pull request #309 from pateljannat/privacy-policy-during-signup 2022-02-23 17:12:12 +05:30
Jannat Patel ce554ed53f feat: privacy policy and other misc changes 2022-02-23 16:52:29 +05:30
Jannat Patel 27d48f85a9 Merge pull request #308 from pateljannat/css-cleanup 2022-02-23 16:33:46 +05:30
Jannat Patel 059ff14e6d fix: added missing style 2022-02-23 14:31:14 +05:30
Jannat Patel 8cfb3569fe fix: css cleanup and testimonials redesign 2022-02-23 13:14:22 +05:30
Jannat Patel 1ac3e9b364 Merge pull request #307 from pateljannat/community-page-redesign 2022-02-23 12:16:41 +05:30
Jannat Patel 22c6a3da4f feat: community page redesign 2022-02-23 11:37:05 +05:30
Jannat Patel 737405d449 Merge pull request #306 from pateljannat/profile-redesign 2022-02-23 09:57:27 +05:30
Jannat Patel e805ae7757 feat: profile page redesign 2022-02-23 09:36:50 +05:30
Jannat Patel d5cf0fee64 Merge branch 'main' of https://github.com/frappe/school into profile-redesign 2022-02-22 11:34:22 +05:30
Jannat Patel 48e2ae6e52 Merge pull request #305 from pateljannat/lesson-page-fixes 2022-02-22 11:30:16 +05:30
Jannat Patel 351e784733 fix: conflicts 2022-02-22 11:18:57 +05:30
Jannat Patel 6c64181bf4 fix: overlay position when related courses 2022-02-22 11:15:02 +05:30
Jannat Patel d64e6a12a7 Merge pull request #304 from pateljannat/quiz-redesign 2022-02-21 18:45:19 +05:30
Jannat Patel ccddc9a404 fix: margin before explanation 2022-02-21 18:03:27 +05:30
Jannat Patel aee35aa66d fix: ui after question check 2022-02-21 16:30:10 +05:30
Jannat Patel 0cf953b3eb fix: markup lib 2022-02-21 16:01:07 +05:30
Jannat Patel eb073ebe87 fix: quiz card layout 2022-02-21 15:23:23 +05:30
Jannat Patel c3fac64280 fix: translations and sidebar 2022-02-21 14:55:20 +05:30
Jannat Patel 28ef8e7db7 feat: quiz redesign 2022-02-21 11:43:05 +05:30
Jannat Patel e3eda95b35 Merge pull request #303 from pateljannat/course-page-redesign 2022-02-18 12:52:05 +05:30
Jannat Patel 894a68823f fix: button width 2022-02-18 12:44:42 +05:30
Jannat Patel dc3843087e feat: course page redesign 2022-02-18 12:26:08 +05:30
Jannat Patel aaae9fe8bc Merge pull request #302 from pateljannat/reviews-empty-state 2022-02-17 17:24:23 +05:30
Jannat Patel 3dc9fc52a7 style: reviews empty state 2022-02-17 17:17:26 +05:30
Jannat Patel 2d373ba509 fix: avg rating condition 2022-02-17 16:53:40 +05:30
Jannat Patel f200e79dc8 style: banner 2022-02-17 16:51:21 +05:30
Jannat Patel ae9518a006 Merge pull request #301 from pateljannat/course-list-page 2022-02-17 15:04:48 +05:30
Jannat Patel 96c24e8e5f test: certificate with expiry 2022-02-17 14:56:33 +05:30
Jannat Patel cc0c1cc320 fix: removed console statements 2022-02-17 14:40:33 +05:30
Jannat Patel 9834c83126 revert: print statement 2022-02-17 13:43:11 +05:30
Jannat Patel 4b8cb5a4e4 fix: test data 2022-02-17 13:37:29 +05:30
Jannat Patel 7e2f473e22 fix: import statement 2022-02-17 13:05:47 +05:30
Jannat Patel ee9f858933 test: certificate creation 2022-02-17 12:46:35 +05:30
Jannat Patel 69f322d34c fix: certification flow 2022-02-17 11:38:27 +05:30
Jannat Patel 91099188f2 Merge pull request #300 from pateljannat/course-home-redesign 2022-02-17 10:12:56 +05:30
Jannat Patel 1e7209bafa style: banner 2022-02-16 20:41:20 +05:30
Jannat Patel a23a356bf6 style: course home 2022-02-16 19:12:25 +05:30
Jannat Patel 5218e134a9 Merge pull request #299 from pateljannat/jobs-redesign 2022-02-14 16:22:58 +05:30
Jannat Patel 55a87999e4 fix: date format 2022-02-14 16:14:53 +05:30
Jannat Patel 6cd7861b2c style: job card redesign 2022-02-14 13:46:02 +05:30
Jannat Patel 6dfaeddc0a Merge pull request #298 from pateljannat/ip-issue-fix 2022-02-11 15:06:51 +05:30
Jannat Patel 4846549a90 fix: ip issue 2022-02-11 12:56:11 +05:30
Jannat Patel 942837b4d9 fix: instructor patch 2022-02-11 10:33:06 +05:30
Jannat Patel 259b4aabcc Merge pull request #297 from pateljannat/redesign-school 2022-02-11 10:05:52 +05:30
Jannat Patel 6200b6a4b0 fix: suffix message for course card instructor 2022-02-10 12:59:31 +05:30
Jannat Patel 6ee1413996 fix: import 2022-02-10 10:32:23 +05:30
Jannat Patel 08fff1700f fix: tests and moved course functions to lms utils 2022-02-10 10:22:01 +05:30
Jannat Patel fd5b7976e7 fix: get_doc references 2022-02-10 09:53:08 +05:30
Jannat Patel e17637d27b fix: conflicts 2022-02-08 16:34:24 +05:30
Jannat Patel 57c69a7d6c fix: removing get_doc dependencies for lms course 2022-02-08 16:13:38 +05:30
Jannat Patel bf3a496ea3 feat: multiple instructors on course card and course home 2022-02-07 13:41:28 +05:30
Jannat Patel 3e46db9c11 feat: multiple instructors 2022-02-07 12:01:07 +05:30
Jannat Patel 50c624e305 Merge pull request #295 from anandology/context-in-page-extensions 2022-02-07 11:33:49 +05:30
Anand Chitipothu 6d4e64059a feat: pass context to page extensions
Pass the context to page extensions to allow them to make decisions
based on the context. For example, an extension to load the course
specific scripts. This is currently not possible because the course
details are not availale to the page extensions. Made this possible by
passing the context to page extensions.
2022-01-25 07:32:13 +05:30
Jannat Patel ec879b12b3 Merge pull request #291 from pateljannat/jobs-improvement 2022-01-11 19:55:18 +05:30
Jannat Patel 5ace8f5570 fix: email content 2022-01-11 19:41:59 +05:30
Jannat Patel 2fe5a6b248 Merge branch 'main' of https://github.com/frappe/school into jobs-improvement 2022-01-11 19:30:53 +05:30
Jannat Patel 19f5251736 fix: login button before job application 2022-01-11 19:27:12 +05:30
Jannat Patel a87e3d66a6 fix: hide apply and report button from guest users 2022-01-11 17:50:14 +05:30
Jannat Patel 62acdde68f fix: email 2022-01-11 16:33:20 +05:30
Jannat Patel e214573cd1 fix: job reporting 2022-01-11 15:10:31 +05:30
Jannat Patel 8fff1cd817 fix: jobs ui 2022-01-10 21:39:26 +05:30
Jannat Patel 20eb0c4d64 Merge pull request #290 from pateljannat/community-and-job-redesign 2022-01-10 17:00:02 +05:30
Jannat Patel ff05292bdb fix: community cards 2022-01-10 16:45:06 +05:30
Jannat Patel 326bc88f19 Merge pull request #288 from pateljannat/community-page-fix 2022-01-07 11:10:09 +05:30
Jannat Patel f0a7612369 fix: exclude disabled users 2022-01-06 21:29:04 +05:30
Jannat Patel 515be5de33 Merge pull request #287 from pateljannat/members-page 2022-01-06 17:19:25 +05:30
Jannat Patel e1e7354d85 feat: search in community page 2022-01-06 17:10:07 +05:30
Jannat Patel 2ec6a06204 Merge branch 'main' of https://github.com/frappe/school into members-page 2022-01-03 16:36:23 +05:30
Jannat Patel 9150def93e Merge pull request #285 from pateljannat/profile-fixes 2022-01-03 10:21:05 +05:30
Jannat Patel 730f1a6c47 fix: conditions to hide contacts section 2022-01-03 09:55:34 +05:30
Jannat Patel 7c12d094c5 fix: logo dimensions 2022-01-03 09:40:30 +05:30
Jannat Patel 8aceaf0595 Merge pull request #282 from pateljannat/job-posting 2021-12-30 14:54:08 +05:30
Jannat Patel 5a1bdc156d fix: email on job creation 2021-12-30 13:08:52 +05:30
Jannat Patel aa81426189 fix: show jobs with Open status 2021-12-30 11:51:27 +05:30
Jannat Patel 7a5d39cc94 fix: new module called job 2021-12-30 10:08:15 +05:30
Jannat Patel b1b8f202c9 feat: job posting 2021-12-28 22:26:52 +05:30
Jannat Patel fcfda68d88 Merge pull request #281 from pateljannat/rating-field 2021-12-27 15:19:43 +05:30
Jannat Patel e966e4c7ed fix: rating field issue 2021-12-27 13:26:50 +05:30
Jannat Patel 42455c72f9 fix: revert unnecesary change 2021-12-27 12:37:49 +05:30
Jannat Patel ef5f49016e fix: structure of course home page 2021-12-27 12:37:17 +05:30
Jannat Patel 6417dfb4a1 Merge pull request #279 from pateljannat/upload-in-lessons 2021-12-24 16:24:42 +05:30
Jannat Patel 40985da9ca fix: updating existing assignment 2021-12-23 20:30:31 +05:30
Jannat Patel e07c26c17d Merge pull request #280 from frappe/make-contact-display-configurable 2021-12-23 20:23:05 +05:30
Jannat Patel 9f2cba49ee feat: hide primary contact from profile 2021-12-23 19:58:42 +05:30
Jannat Patel 6e3de21f6e fix: file type support 2021-12-23 17:58:39 +05:30
Jannat Patel a6bdbd7cf1 feat: lesson assignment 2021-12-22 22:13:33 +05:30
Jannat Patel b822428d52 Merge pull request #277 from pateljannat/custom-signup 2021-12-21 16:13:15 +05:30
Jannat Patel 03a7df1c98 fix: mandatory terms of use 2021-12-21 16:02:30 +05:30
Jannat Patel 08b7290070 fix: display internship in profile 2021-12-21 15:54:47 +05:30
Jannat Patel 6188c698e3 fix: checkbox for terms of use 2021-12-21 15:41:32 +05:30
Jannat Patel 7d9b60c16a fix: conflicts 2021-12-21 11:34:43 +05:30
Jannat Patel df3c5060e9 Merge pull request #278 from pateljannat/profile-restrictions 2021-12-21 11:22:01 +05:30
Jannat Patel ff702c9d14 fix: restrict profile and mark as complete 2021-12-21 11:11:39 +05:30
Jannat Patel ea06fe8cf8 feat: hooks for profile mandatory fields 2021-12-20 14:18:22 +05:30
Jannat Patel f8b0d9b180 feat: hooks for profile mandatory fields 2021-12-20 14:18:10 +05:30
Jannat Patel d3a3e7066d fix: removed unnecessary imports 2021-12-20 11:28:55 +05:30
Jannat Patel 45e3964285 fix: renamed signup hook and moved default form to a template 2021-12-20 11:06:51 +05:30
Jannat Patel 4edf4936c1 fix: pass path in hooks instead of function 2021-12-20 10:04:50 +05:30
Jannat Patel 067be4973d fix: string translation 2021-12-20 09:42:31 +05:30
Jannat Patel 6a3442d058 fix: user and country data 2021-12-17 19:42:57 +05:30
Jannat Patel 0b83307f7d fix: custom signup form 2021-12-17 11:24:28 +05:30
Jannat Patel f36042f537 Merge pull request #272 from anandology/cohorts-v1 2021-12-17 10:45:56 +05:30
Jannat Patel 668a5d6334 fix: labels and order 2021-12-16 15:20:08 +05:30
Anand Chitipothu eb59713b65 fix: delete invalid links from Cohort doctype 2021-12-16 11:45:29 +05:30
Jannat Patel fbc6187062 fix: profile settings 2021-12-16 10:06:58 +05:30
Anand Chitipothu 274ecaa222 fix: typo in exercise_submission.py
Corrected the use of save instead of insert.
2021-12-15 22:27:57 +05:30
Anand Chitipothu 051196179d fix: failing test in doctype Exercise 2021-12-15 11:42:52 +05:30
Anand Chitipothu cddfc4550d Merge branch 'main' into cohorts-v1 2021-12-15 11:25:30 +05:30
Anand Chitipothu 465bc3b24a feat: allow the same custom page to be avaiable both for cohort and subgroup 2021-12-14 22:09:51 +05:30
Jannat Patel 38087f0b02 Merge pull request #275 from pateljannat/enhanced-profile 2021-12-14 18:09:15 +05:30
Jannat Patel 3237a539f7 fix: removed print statement 2021-12-14 18:04:41 +05:30
Jannat Patel 828d5764d0 fix: made user fields non mandatory 2021-12-14 17:21:08 +05:30
Jannat Patel 15fc3742d2 fix: ci install app command 2021-12-14 16:56:24 +05:30
Jannat Patel 8489b1d943 fix: text editor for bio and profile redirect changes 2021-12-14 16:46:06 +05:30
Jannat Patel 682188540c feat: new profile fields 2021-12-14 16:28:15 +05:30
Anand Chitipothu 8f740d70e0 fix: broken link to the course on join page 2021-12-13 21:30:19 +05:30
Anand Chitipothu bc80c2200d feat: add anchor to exercise to allow linking to an exercise 2021-12-13 11:16:56 +05:30
Jannat Patel fd524f627e fix: profile web form 2021-12-09 19:07:04 +05:30
Anand Chitipothu 59b3b68bde fix: fixed the issue of duplicate join requests
Someone was spamming mon.school by generating thousands of join
requests. Added to fix to avoid creating duplicate requests.
2021-12-09 18:21:29 +05:30
Anand Chitipothu 943c8eabbf feat: added custom pages at subgroup level 2021-12-09 01:17:03 +05:30
Anand Chitipothu b83918c2aa feat: added Exercise Latest Submission doctype
Issue #274
2021-12-08 23:07:53 +05:30
Jannat Patel 5b4db8fd54 feat: child tables for profile sections 2021-12-07 16:58:55 +05:30
Anand Chitipothu c8d7ac48ea fix: CohortSubgroup.has_student
Fixed the wrong query.

Issue #271
2021-12-07 15:37:46 +05:30
Anand Chitipothu 3cd4e64957 feat: allow cohort admins to add mentors
Issue #271
2021-12-05 02:10:58 +05:30
Anand Chitipothu 2f994628c3 fix: show students/mentors on subgroup page alphabetically
Issue #271
2021-12-05 01:33:33 +05:30
Anand Chitipothu f68fc02e57 style: improved the ux of approve/reject flow
Issue #271
2021-12-05 01:29:48 +05:30
Anand Chitipothu 0637b9c8f8 fix: allow admins to manage join requests
Issue #271
2021-12-05 01:29:24 +05:30
Anand Chitipothu 7001ddc96f feat: made all the cohort pages public
There is some info on the page that is only accessible to mentors and
admins and not shown to other users.
2021-12-05 01:04:46 +05:30
Anand Chitipothu fe31a64175 style: updated the styles of subgroup links on cohort page 2021-12-05 00:22:27 +05:30
Anand Chitipothu cd0cc2b501 feat: added support to get subgroups in sorted order
Issue #271
2021-12-05 00:13:05 +05:30
Anand Chitipothu ebcb3c5466 fix: fixed the issue with rendering custom cohort page
Issue #271
2021-12-05 00:01:42 +05:30
Anand Chitipothu a1d0f3948a feat: added support for custom web pages for cohorts
This allows adding custom web pages to each cohort by defining a web
template and attaching it to the cohort.

Issue #271
2021-12-04 23:47:29 +05:30
Anand Chitipothu 22f5508bea style: improved the display of users and mentors in a subgroup
Using MemberCard insted of Avatar macro.

Issue #271
2021-12-04 23:14:37 +05:30
Anand Chitipothu 63c4f708c3 feat: improved the subgroup page load time
Using `get_cached_doc` instead of `get_doc` for loading students and
mentors.

Issue #271
2021-12-04 23:03:58 +05:30
Anand Chitipothu 52fd891370 fix: show the recent join requests on the top
Issue #271
2021-12-04 22:52:56 +05:30
Anand Chitipothu fb447a30e4 feat: added undo of rejected join requests
Also improved the dispaly of timestamp, showing the diff now.

Issue #271
2021-12-04 22:47:23 +05:30
Anand Chitipothu e0c73e26ee fix: increased the page_length when querying for students of a subgroup. 2021-12-04 17:19:49 +05:30
Anand Chitipothu d5da5bd8aa feat: allow all mentors to see the cohort status
Issue #271
2021-12-04 07:25:15 +05:30
Anand Chitipothu d84302682e fix: permission issue on cohort page
Using get_all instead of get_list to disable permission check.

Issue #271
2021-12-03 16:03:14 +05:30
Anand Chitipothu c963e93b52 feat: allow students who have already joined the course to join the cohort
Issue #271
2021-12-03 00:28:13 +05:30
Anand Chitipothu c96e3ee2f9 feat: show counts on cohort listing and view pages
Issue #271
2021-12-02 10:36:17 +05:30
Jannat Patel a78019ccbc fix: mark as complete label 2021-12-01 18:59:29 +05:30
Anand Chitipothu e014c94446 fix: mentor counts on cohort page
The group by clause was missing in the query.

Issue #271
2021-12-01 12:19:03 +05:30
Anand Chitipothu 6c747ff8b4 feat: added get_url method to cohort doctypes
This is required to make it easier to include links in the email
notification to mentors.

Issue #271
2021-12-01 08:43:10 +05:30
Anand Chitipothu ffd9e9d48e feat: Added support for approve/reject join requests to a cohort subgroup
Issue #271
2021-11-30 18:06:36 +05:30
Anand Chitipothu 3328359ba4 style: "manage the course" button
Issue #271
2021-11-30 18:06:27 +05:30
Jannat Patel 66f6c1fd46 Merge pull request #273 from pateljannat/testimonial-card-fix 2021-11-30 11:15:59 +05:30
Jannat Patel aaa845a0f8 fix: testimonial cards height and shadows 2021-11-30 11:04:29 +05:30
Anand Chitipothu f1157895db feat: added portal page to join a cohort
Issue #271
2021-11-30 08:29:24 +05:30
Anand Chitipothu 1277cfed64 feat: added cohort and subgroup pages
Issue #271
2021-11-30 07:46:48 +05:30
Anand Chitipothu 102fa9c0a8 feat: added a page to list cohorts of a course
- added a page /courses/<course>/manage that lists the active cohorts
- only accessible to mentors and staff
- also added a "manage the course" button on course page for mentors/staff

Issue #271
2021-11-29 17:33:45 +05:30
Anand Chitipothu 7cd57cadb2 feat: added doctypes for cohorts
Issue #271
2021-11-29 17:26:38 +05:30
Jannat Patel 2a56b7ade2 Merge pull request #270 from pateljannat/mark-as-complete 2021-11-29 16:29:21 +05:30
Jannat Patel cf8be3ca21 style: discussons empty state and mark as complete message 2021-11-29 16:20:49 +05:30
Jannat Patel 715a1b5df5 fix: mark as complete behaviour 2021-11-29 16:02:59 +05:30
Jannat Patel 0a374a0e78 Merge pull request #269 from pateljannat/search-generic 2021-11-26 11:44:23 +05:30
Jannat Patel 36996a54a5 fix: search-settings 2021-11-26 11:34:10 +05:30
Jannat Patel 3f687e4c4a Merge pull request #265 from pateljannat/improve-notify-me-behaviour 2021-11-25 14:09:03 +05:30
Jannat Patel 315d373d2d fix: hide notify me button on callback 2021-11-25 13:06:12 +05:30
Jannat Patel 6ae346df44 fix: notify-me-ux 2021-11-23 22:28:07 +05:30
Jannat Patel 9582a27dc6 Merge pull request #264 from pateljannat/search-empty-state-improvements 2021-11-22 10:14:48 +05:30
Jannat Patel 6195d72c3c fix: indentation 2021-11-22 10:08:54 +05:30
Jannat Patel 3f0309c36a fix: search empty state improvements 2021-11-22 10:05:04 +05:30
Jannat Patel 08ea7401cc Merge pull request #263 from pateljannat/search-improvements 2021-11-19 19:44:55 +05:30
Jannat Patel f3d7f09476 feat: search empty state 2021-11-19 19:12:19 +05:30
Jannat Patel 36150d5b09 fix: allow guests to search 2021-11-18 15:44:19 +05:30
Jannat Patel e5deb2ddd7 Merge pull request #262 from pateljannat/testimonials 2021-11-18 15:25:33 +05:30
Jannat Patel d60aa54903 fix: condition if testimonials are less than multiple of three 2021-11-18 15:12:41 +05:30
Jannat Patel 2627cee938 fix: increased margin above explore more link 2021-11-18 15:07:29 +05:30
Jannat Patel e7f47a4485 fix: slider height 2021-11-18 10:09:11 +05:30
Jannat Patel 5bfe56c091 fix: slider 2021-11-17 20:34:10 +05:30
Jannat Patel f08586ee12 feat: testimonials template 2021-11-16 19:32:05 +05:30
Jannat Patel af17270c52 fix: back tracing result on search 2021-11-15 19:30:01 +05:30
Jannat Patel 06b4062003 Merge pull request #261 from pateljannat/search 2021-11-15 19:08:24 +05:30
Jannat Patel 6cba6972bc feat: search for courses 2021-11-15 19:00:23 +05:30
Jannat Patel f7a23e629c fix: conflicts 2021-11-15 13:29:02 +05:30
Jannat Patel e67b37be28 Merge pull request #260 from pateljannat/course-cards-cleanup 2021-11-12 19:35:52 +05:30
Jannat Patel 1fa7dfe41f fix: removed arrow interaction 2021-11-12 19:20:18 +05:30
Jannat Patel e781071ebf Merge pull request #257 from pateljannat/empty-states 2021-11-12 18:48:12 +05:30
Jannat Patel 1697c5d5b5 feat: search bar on course list 2021-11-12 10:10:39 +05:30
Jannat Patel 091fefb601 fix: removed unused css variables 2021-11-11 09:48:11 +05:30
Jannat Patel 7939e6c619 style: course cards and templates 2021-11-10 17:08:46 +05:30
Jannat Patel f8788dc32c fix: empty state logo and link style 2021-11-08 16:49:31 +05:30
Jannat Patel 4db51bff79 style: empty state for reviews 2021-11-04 22:03:26 +05:30
Jannat Patel 6f96da74c7 empty state for discussion 2021-11-02 18:27:52 +05:30
Jannat Patel f1692763d3 Merge pull request #255 from pateljannat/fixes 2021-11-01 15:08:00 +05:30
902 changed files with 42477 additions and 19527 deletions
+2 -2
View File
@@ -9,7 +9,7 @@ root = true
end_of_line = lf
insert_final_newline = true
charset = utf-8
indent_style = space
indent_style = tab
trim_trailing_whitespace = true
# Python
@@ -26,4 +26,4 @@ indent_style = tab
# HTML, CSS, javascript, JSON and YAML
[*.{html,css,js,json,yml,yaml}]
indent_size = 2
indent_size = 4
+37
View File
@@ -0,0 +1,37 @@
[flake8]
ignore =
E121,
E126,
E127,
E128,
E203,
E225,
E226,
E231,
E241,
E251,
E261,
E265,
E302,
E303,
E305,
E402,
E501,
E741,
W291,
W292,
W293,
W391,
W503,
W504,
F403,
B007,
B950,
W191,
E124, # closing bracket, irritating while writing QB code
E131, # continuation line unaligned for hanging indent
E123, # closing bracket does not match indentation of opening bracket's line
E101, # ensured by use of black
max-line-length = 200
exclude=.github/helper/semgrep_rules
+74
View File
@@ -0,0 +1,74 @@
[flake8]
ignore =
B001,
B007,
B009,
B010,
B950,
E101,
E111,
E114,
E116,
E117,
E121,
E122,
E123,
E124,
E125,
E126,
E127,
E128,
E131,
E201,
E202,
E203,
E211,
E221,
E222,
E223,
E224,
E225,
E226,
E228,
E231,
E241,
E242,
E251,
E261,
E262,
E265,
E266,
E271,
E272,
E273,
E274,
E301,
E302,
E303,
E305,
E306,
E402,
E501,
E502,
E701,
E702,
E703,
E741,
F401,
F403,
F405,
W191,
W291,
W292,
W293,
W391,
W503,
W504,
E711,
E129,
F841,
E713,
E712,
max-line-length = 200
+46
View File
@@ -0,0 +1,46 @@
#!/bin/bash
set -e
cd ~ || exit
echo "Setting Up Bench..."
pip install frappe-bench
bench -v init frappe-bench --skip-assets --python "$(which python)"
cd ./frappe-bench || exit
bench -v setup requirements
echo "Setting Up LMS App..."
bench get-app lms "${GITHUB_WORKSPACE}"
echo "Setting Up Sites & Database..."
mkdir ~/frappe-bench/sites/lms.test
cp "${GITHUB_WORKSPACE}/.github/helper/site_config.json" ~/frappe-bench/sites/lms.test/site_config.json
mariadb --host 127.0.0.1 --port 3306 -u root -p123 -e "SET GLOBAL character_set_server = 'utf8mb4'";
mariadb --host 127.0.0.1 --port 3306 -u root -p123 -e "SET GLOBAL collation_server = 'utf8mb4_unicode_ci'";
mariadb --host 127.0.0.1 --port 3306 -u root -p123 -e "CREATE DATABASE test_lms";
mariadb --host 127.0.0.1 --port 3306 -u root -p123 -e "CREATE USER 'test_lms'@'localhost' IDENTIFIED BY 'test_lms'";
mariadb --host 127.0.0.1 --port 3306 -u root -p123 -e "GRANT ALL PRIVILEGES ON \`test_lms\`.* TO 'test_lms'@'localhost'";
mariadb --host 127.0.0.1 --port 3306 -u root -p123 -e "FLUSH PRIVILEGES";
echo "Setting Up Procfile..."
sed -i 's/^watch:/# watch:/g' Procfile
sed -i 's/^schedule:/# schedule:/g' Procfile
echo "Starting Bench..."
bench start &> bench_start.log &
CI=Yes bench build &
build_pid=$!
bench --site lms.test reinstall --yes
bench --site lms.test install-app lms
wait $build_pid
+14
View File
@@ -0,0 +1,14 @@
#!/bin/bash
set -e
echo "Setting Up System Dependencies..."
sudo apt update
sudo apt remove mysql-server mysql-client
sudo apt install libcups2-dev redis-server mariadb-client-10.6
install_wkhtmltopdf() {
wget -q https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6-1/wkhtmltox_0.12.6-1.focal_amd64.deb
sudo apt install ./wkhtmltox_0.12.6-1.focal_amd64.deb
}
install_wkhtmltopdf &
+20
View File
@@ -0,0 +1,20 @@
{
"db_host": "127.0.0.1",
"db_port": 3306,
"db_name": "test_lms",
"db_password": "test_lms",
"allow_tests": true,
"enable_ui_tests": true,
"db_type": "mariadb",
"auto_email_id": "test@example.com",
"mail_server": "smtp.example.com",
"mail_login": "test@example.com",
"mail_password": "test",
"admin_password": "admin",
"root_login": "root",
"root_password": "123",
"host_name": "http://lms.test:8000",
"monitor": 1,
"server_script_enabled": true,
"mute_emails": true
}
+32
View File
@@ -0,0 +1,32 @@
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="4 2 193 52">
<g filter="url(#filter0_dd)">
<rect x="4" y="2" width="193" height="52" rx="6" fill="#2490EF"/>
<path d="M28 22.2891H32.8786V35.5H36.2088V22.2891H41.0874V19.5H28V22.2891Z" fill="white"/>
<path d="M41.6982 35.5H45.0129V28.7109C45.0129 27.2344 46.0866 26.2188 47.5494 26.2188C48.0085 26.2188 48.6388 26.2969 48.95 26.3984V23.4453C48.6543 23.375 48.2419 23.3281 47.9074 23.3281C46.5691 23.3281 45.472 24.1094 45.0362 25.5938H44.9117V23.5H41.6982V35.5Z" fill="white"/>
<path d="M52.8331 40C55.2996 40 56.6068 38.7344 57.2837 36.7969L61.9289 23.5156L58.4197 23.5L55.9221 32.3125H55.7976L53.3233 23.5H49.8374L54.1247 35.8437L53.9302 36.3516C53.4944 37.4766 52.6619 37.5312 51.4947 37.1719L50.7478 39.6562C51.2224 39.8594 51.9927 40 52.8331 40Z" fill="white"/>
<path d="M73.6142 35.7344C77.2401 35.7344 79.4966 33.2422 79.4966 29.5469C79.4966 25.8281 77.2401 23.3438 73.6142 23.3438C69.9883 23.3438 67.7319 25.8281 67.7319 29.5469C67.7319 33.2422 69.9883 35.7344 73.6142 35.7344ZM73.6298 33.1562C71.9569 33.1562 71.101 31.6171 71.101 29.5233C71.101 27.4296 71.9569 25.8827 73.6298 25.8827C75.2715 25.8827 76.1274 27.4296 76.1274 29.5233C76.1274 31.6171 75.2715 33.1562 73.6298 33.1562Z" fill="white"/>
<path d="M84.7253 28.5625C84.7331 27.0156 85.6512 26.1094 86.9895 26.1094C88.3201 26.1094 89.1215 26.9844 89.1137 28.4531V35.5H92.4284V27.8594C92.4284 25.0625 90.7945 23.3438 88.3046 23.3438C86.5306 23.3438 85.2466 24.2187 84.7097 25.6172H84.5697V23.5H81.4106V35.5H84.7253V28.5625Z" fill="white"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M102.429 19.5H113.429V22.3141H102.429V19.5ZM102.429 35.5V26.6794H112.699V29.4982H105.94V35.5H102.429Z" fill="white"/>
<path d="M131.584 24.9625C131.09 21.5057 128.345 19.5 124.785 19.5C120.589 19.5 117.429 22.463 117.429 27.4924C117.429 32.5142 120.55 35.4848 124.785 35.4848C128.604 35.4848 131.137 33.0916 131.584 30.1211L128.651 30.1059C128.282 31.9293 126.745 32.9549 124.824 32.9549C122.22 32.9549 120.354 31.0632 120.354 27.4924C120.354 23.9824 122.204 22.0299 124.832 22.0299C126.784 22.0299 128.314 23.1011 128.651 24.9625H131.584Z" fill="white"/>
<path d="M136.409 19.7124H133.571V35.2718H136.409V19.7124Z" fill="white"/>
<path d="M144.031 35.5001C147.56 35.5001 149.803 33.0917 149.803 29.483C149.803 25.8667 147.56 23.4507 144.031 23.4507C140.502 23.4507 138.259 25.8667 138.259 29.483C138.259 33.0917 140.502 35.5001 144.031 35.5001ZM144.047 33.2969C142.094 33.2969 141.137 31.6103 141.137 29.4754C141.137 27.3406 142.094 25.6312 144.047 25.6312C145.968 25.6312 146.925 27.3406 146.925 29.4754C146.925 31.6103 145.968 33.2969 144.047 33.2969Z" fill="white"/>
<path d="M159.338 30.3641C159.338 32.1419 158.028 33.0232 156.773 33.0232C155.409 33.0232 154.499 32.0887 154.499 30.6072V23.6025H151.66V31.0327C151.66 33.8361 153.307 35.4239 155.675 35.4239C157.479 35.4239 158.749 34.5046 159.298 33.1979H159.424V35.272H162.176V23.6025H159.338V30.3641Z" fill="white"/>
<path d="M169.014 35.4769C171.084 35.4769 172.017 34.2841 172.464 33.4332H172.637V35.2718H175.429V19.7124H172.582V25.532H172.464C172.033 24.6887 171.147 23.4503 169.022 23.4503C166.238 23.4503 164.05 25.5624 164.05 29.4522C164.05 33.2965 166.175 35.4769 169.014 35.4769ZM169.806 33.2205C167.931 33.2205 166.943 31.6251 166.943 29.437C166.943 27.2642 167.916 25.7067 169.806 25.7067C171.633 25.7067 172.637 27.173 172.637 29.437C172.637 31.701 171.617 33.2205 169.806 33.2205Z" fill="white"/>
</g>
<defs>
<filter id="filter0_dd" x="0" y="0" width="201" height="60" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
<feFlood flood-opacity="0" result="BackgroundImageFix"/>
<feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
<feOffset/>
<feGaussianBlur stdDeviation="0.25"/>
<feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.5 0"/>
<feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow"/>
<feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
<feOffset dy="2"/>
<feGaussianBlur stdDeviation="2"/>
<feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.13 0"/>
<feBlend mode="normal" in2="effect1_dropShadow" result="effect2_dropShadow"/>
<feBlend mode="normal" in="SourceGraphic" in2="effect2_dropShadow" result="shape"/>
</filter>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 4.3 KiB

+8 -9
View File
@@ -1,4 +1,4 @@
name: Run tests
name: Server Tests
on:
push:
branches:
@@ -32,11 +32,11 @@ jobs:
- name: setup python
uses: actions/setup-python@v2
with:
python-version: '3.9'
python-version: '3.10'
- name: setup node
uses: actions/setup-node@v2
with:
node-version: '14'
node-version: '18'
check-latest: true
- name: setup cache for bench
uses: actions/cache@v2
@@ -57,15 +57,15 @@ jobs:
mkdir -p ~/bench-cache
(cd && tar czf ~/bench-cache/bench.tgz frappe-bench)
fi
- name: add school app to bench
- name: add lms app to bench
working-directory: /home/runner/frappe-bench
run: bench get-app school $GITHUB_WORKSPACE
run: bench get-app lms $GITHUB_WORKSPACE
- name: create bench site
working-directory: /home/runner/frappe-bench
run: bench new-site --mariadb-root-password root --admin-password admin frappe.local
- name: install school app
- name: install lms app
working-directory: /home/runner/frappe-bench
run: bench --verbose --site frappe.local install-app school
run: bench --site frappe.local install-app lms
- name: setup requirements
working-directory: /home/runner/frappe-bench
run: bench setup requirements --dev
@@ -77,5 +77,4 @@ jobs:
run: bench --site frappe.local build
- name: run tests
working-directory: /home/runner/frappe-bench
run: bench --site frappe.local run-tests --app school
run: bench --site frappe.local run-tests --app lms
+33
View File
@@ -0,0 +1,33 @@
name: Linters
on:
pull_request:
workflow_dispatch:
push:
branches: [ main ]
jobs:
linters:
name: Semantic Commits
runs-on: ubuntu-latest
if: github.event_name == 'pull_request'
steps:
- uses: actions/checkout@v3
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.10'
- name: Install and Run Pre-commit
uses: pre-commit/action@v2.0.3
- name: Download Semgrep rules
run: git clone --depth 1 https://github.com/frappe/semgrep-rules.git frappe-semgrep-rules
- name: Download semgrep
run: pip install semgrep
- name: Run Semgrep rules
run: semgrep ci --config ./frappe-semgrep-rules/rules
+19
View File
@@ -0,0 +1,19 @@
name: Semantic Pull Request
on:
push:
branches: [ main ]
pull_request: {}
jobs:
# This workflow contains a single job called "build"
semantic:
name: Validate PR title
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v2
- uses: zeke/semantic-pull-requests@main
+121
View File
@@ -0,0 +1,121 @@
name: UI
on:
pull_request:
workflow_dispatch:
push:
branches: [ main ]
permissions:
# Do not change this as GITHUB_TOKEN is being used by roulette
contents: read
jobs:
test:
runs-on: ubuntu-latest
if: ${{ github.repository_owner == 'frappe' }}
timeout-minutes: 60
strategy:
fail-fast: false
name: UI Tests (Cypress)
services:
mariadb:
image: mariadb:10.6
env:
MARIADB_ROOT_PASSWORD: 123
ports:
- 3306:3306
options: --health-cmd="mysqladmin ping" --health-interval=5s --health-timeout=2s --health-retries=3
steps:
- name: Clone
uses: actions/checkout@v3
- name: Setup Python
uses: actions/setup-python@v4
with:
python-version: '3.11'
- name: Check for valid Python & Merge Conflicts
run: |
python -m compileall -q -f "${GITHUB_WORKSPACE}"
if grep -lr --exclude-dir=node_modules "^<<<<<<< " "${GITHUB_WORKSPACE}"
then echo "Found merge conflicts"
exit 1
fi
- uses: actions/setup-node@v3
with:
node-version: 18
check-latest: true
- name: Add to Hosts
run: |
echo "127.0.0.1 lms.test" | sudo tee -a /etc/hosts
- name: Cache pip
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/*requirements.txt', '**/pyproject.toml', '**/setup.py') }}
restore-keys: |
${{ runner.os }}-pip-
${{ runner.os }}-
- name: Get yarn cache directory path
id: yarn-cache-dir-path
run: echo "dir=$(yarn cache dir)" >> $GITHUB_OUTPUT
- uses: actions/cache@v3
id: yarn-cache
with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: ${{ runner.os }}-yarn-ui-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-ui-
- name: Cache cypress binary
uses: actions/cache@v3
with:
path: ~/.cache/Cypress
key: ${{ runner.os }}-cypress
- name: Install Dependencies
run: |
bash ${GITHUB_WORKSPACE}/.github/helper/install_dependencies.sh
bash ${GITHUB_WORKSPACE}/.github/helper/install.sh
env:
BEFORE: ${{ env.GITHUB_EVENT_PATH.before }}
AFTER: ${{ env.GITHUB_EVENT_PATH.after }}
TYPE: ui
DB: mariadb
- name: Site Setup
run: |
cd ~/frappe-bench/
bench --site lms.test execute frappe.utils.install.complete_setup_wizard
bench --site lms.test execute frappe.tests.ui_test_helpers.create_test_user
- name: cypress pre-requisites
run: |
cd ~/frappe-bench/apps/lms
yarn add cypress@^10 --no-lockfile
- name: UI Tests
run: cd ~/frappe-bench/ && bench --site lms.test run-ui-tests lms --headless
env:
CYPRESS_BASE_URL: http://lms.test:8000
CYPRESS_RECORD_KEY: 095366ec-7b9f-41bd-aeec-03bb76d627fe
- name: Stop server and wait for coverage file
run: |
ps -ef | grep "[f]rappe serve" | awk '{print $2}' | xargs kill -s SIGINT
sleep 5
- name: Show bench output
if: ${{ always() }}
run: cat ~/frappe-bench/bench_start.log || true
+4 -2
View File
@@ -3,8 +3,10 @@
*.egg-info
*.swp
tags
school/docs/current
school/public/dist
lms/docs/current
lms/public/dist
__pycache__/
*.py[cod]
*$py.class
node_modules
package-lock.json
+57
View File
@@ -0,0 +1,57 @@
exclude: 'node_modules|.git'
default_stages: [commit]
fail_fast: false
repos:
- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.3.0
hooks:
- id: trailing-whitespace
files: "lms.*"
exclude: ".*json$|.*txt$|.*csv|.*md|.*svg"
- id: check-yaml
- id: check-merge-conflict
- id: check-ast
- id: check-json
- id: check-toml
- id: debug-statements
- repo: https://github.com/asottile/pyupgrade
rev: v2.34.0
hooks:
- id: pyupgrade
args: ['--py310-plus']
- repo: https://github.com/adityahase/black
rev: 9cb0a69f4d0030cdf687eddf314468b39ed54119
hooks:
- id: black
additional_dependencies: ['click==8.0.4']
- repo: https://github.com/pre-commit/mirrors-prettier
rev: v2.7.1
hooks:
- id: prettier
types_or: [javascript]
# Ignore any files that might contain jinja / bundles
exclude: |
(?x)^(
lms/public/dist/.*|
.*node_modules.*|
.*boilerplate.*|
lms/www/website_script.js|
lms/templates/includes/.*|
lms/public/js/lib/.*
)$
- repo: https://github.com/PyCQA/flake8
rev: 5.0.4
hooks:
- id: flake8
additional_dependencies: ['flake8-bugbear',]
args: ['--config', '.github/helper/flake8.conf']
ci:
autoupdate_schedule: weekly
skip: []
submodules: false
+1 -1
View File
@@ -1,5 +1,5 @@
1. Go to the apps/school directory of your installation and execute git pull --unshallow to ensure that you have the full git repository. Also fork the frappe/school repository on GitHub.
1. Go to the apps/lms directory of your installation and execute git pull --unshallow to ensure that you have the full git repository. Also fork the frappe/lms repository on GitHub.
1. Check out a working branch in git (e.g. git checkout -b my-new-branch).
1. Make your proposed changes to the source
1. Run your local version (e.g. bench start in your bench installation). Make sure that your changes work the way you want them to.
+12 -12
View File
@@ -4,15 +4,15 @@ include *.json
include *.md
include *.py
include *.txt
recursive-include school *.css
recursive-include school *.csv
recursive-include school *.html
recursive-include school *.ico
recursive-include school *.js
recursive-include school *.json
recursive-include school *.md
recursive-include school *.png
recursive-include school *.py
recursive-include school *.svg
recursive-include school *.txt
recursive-exclude school *.pyc
recursive-include lms *.css
recursive-include lms *.csv
recursive-include lms *.html
recursive-include lms *.ico
recursive-include lms *.js
recursive-include lms *.json
recursive-include lms *.md
recursive-include lms *.png
recursive-include lms *.py
recursive-include lms *.svg
recursive-include lms *.txt
recursive-exclude lms *.pyc
+97 -13
View File
@@ -1,25 +1,109 @@
## School
<p align="center">
<a href="https://www.frappelms.com/">
<img src="https://frappelms.com/files/lms-logo-medium.png" alt="Frappe LMS" width="120px" height="25px">
</a>
<p align="center">Easy to use, open source, learning management system.</p>
</p>
Create online courses without much hassle.
![Course Home](/school/public/images/course-home.png)
&nbsp;
<p align="center">
<a href="https://www.producthunt.com/posts/frappe-lms?utm_source=badge-top-post-topic-badge&utm_medium=badge&utm_souce=badge-frappe&#0045;lms" target="_blank"><img src="https://api.producthunt.com/widgets/embed-image/v1/top-post-topic-badge.svg?post_id=396079&theme=dark&period=weekly&topic_id=204" alt="Frappe&#0032;LMS - Easy&#0032;to&#0032;use&#0044;&#0032;100&#0037;&#0032;open&#0032;source&#0032;learning&#0032;management&#0032;system | Product Hunt" style="width: 250px; height: 54px;" width="250" height="54" /></a>
</p>
<div align="center" style="max-height: 40px;">
<a href="https://frappecloud.com/lms/signup">
<img src=".github/try-on-f-cloud.svg" height="40">
</a>
</div>
&nbsp;
<p align="center">
<a href="https://dashboard.cypress.io/projects/vandxn/runs">
<img alt="cypress" src="https://img.shields.io/endpoint?url=https://dashboard.cypress.io/badge/simple/vandxn/main&style=flat&logo=cypress">
</a>
<a href="https://github.com/frappe/lms/blob/main/LICENSE">
<img alt="license" src="https://img.shields.io/badge/license-AGPLv3-blue">
</a>
</p>
<img width="1402" alt="Lesson" src="https://frappelms.com/files/banner.png">
<details>
<summary>Show more screenshots</summary>
<img width="1520" alt="ss1" src="https://user-images.githubusercontent.com/31363128/210056046-584bc8aa-d28c-4514-b031-73817012837d.png">
<img width="830" alt="ss2" src="https://user-images.githubusercontent.com/31363128/210056097-36849182-6db0-43a2-8c62-5333cd2aedf4.png">
<img width="941" alt="ss3" src="https://user-images.githubusercontent.com/31363128/210056134-01a7c429-1ef4-434e-9d43-128dda35d7e5.png">
</details>
Frappe LMS is an easy-to-use, open-source learning management system. You can use it to create and share online courses. The app has a clear UI that helps students focus only on what's important and assists in distraction-free learning.
You can create courses and lessons through simple forms. Lessons can be in the form of text, videos, quizzes or a combination of all these. You can keep your students engaged with quizzes to help revise and test the concepts learned. Course Instructors and Students can reach out to each other through the discussions section available for each lesson and get queries resolved.
## Features
- Create online courses. 📚
- Add detailed descriptions and preview videos to the course. 🎬
- Add videos, quizzes, and assignments to your lessons and make them interesting and interactive 📝
- Discussions section below each lesson where instructors and students can interact with each other. 💬
- Create batches to group your students based on courses and track their progress 🏛
- Statistics dashboard that provides all important numbers at a glimpse. 📈
- Job Board where users can post and look for jobs. 💼
- People directory with each person's profile page 👨‍👩‍👧‍👦
- Set cover image, profile photo, short bio, and other professional information. 🦹🏼‍♀️
- Simple layout that optimizes readability 🤓
- Delightful user experience in overall usage ✨
1. Simple Backend Forms.
1. The UI is clean and minimal.
1. Lessons can be in the form of texts, videos, quizzes or a combination of all of these.
## Tech Stack
## Development Setup
Frappe LMS is built on [Frappe Framework](https://frappeframework.com) which is a batteries-included python web framework.
These are some of the tools it's built on:
- [Python](https://www.python.org)
- [Redis](https://redis.io/)
- [MariaDB](https://mariadb.org/)
- [Socket.io](https://socket.io/)
1. [Through Docker](docker-installation.md)
1. [Direct install through bench](bench-installation.md)
## Local Setup
### Docker
You need Docker, docker-compose, and git setup on your machine. Refer to [Docker documentation](https://docs.docker.com/). After that, run the following commands:
```
git clone https://github.com/frappe/lms
cd apps/lms/docker
docker-compose up
```
Wait for some time until the setup script creates a site. After that, you can access `http://localhost:8000` in your browser and the app's login screen should show up.
### Frappe Bench
Currently, this app depends on the `develop` branch of [frappe](https://github.com/frappe/frappe).
1. Setup frappe-bench by following [this guide](https://frappeframework.com/docs/v14/user/en/installation)
1. In the frappe-bench directory, run `bench start` and keep it running. Open a new terminal session and cd into the `frappe-bench` directory.
1. Run the following commands:
```sh
bench new-site lms.test
bench get-app lms
bench --site lms.test install-app lms
bench --site lms.test add-to-hosts
1. Now, you can access the site at `http://lms.test:8000`
### Contributing
## Deployment
Frappe LMS is an app built on top of the Frappe Framework. So, you can follow any deployment guide for hosting a Frappe Framework-based site.
1. [Contribution Guidelines](Contribution.md)
### Managed Hosting
Frappe LMS can be deployed in a few clicks on [Frappe Cloud](https://frappecloud.com/marketplace/apps/lms).
### Self-hosting
If you want to self-host, you can follow official [Frappe Bench Installation](https://github.com/frappe/bench#installation) instructions.
## Bugs and Feature Requests
If you find any bugs or have a feature idea for the app, feel free to report them here on [GitHub Issues](https://github.com/frappe/lms/issues). Make sure you share enough information (app screenshots, browser console screenshots, stack traces, etc) for project maintainers.
## License
[GNU AFFERO GENERAL PUBLIC LICENSE](license.txt)
Distributed under [GNU AFFERO GENERAL PUBLIC LICENSE](license.txt)
+5 -5
View File
@@ -2,9 +2,9 @@ To setup the repository locally follow the steps mentioned below:
1. Install bench and setup a frappe-bench directory by following the [Installation Steps](https://frappeframework.com/docs/user/en/installation).
1. Start the server by running bench start.
1. In a separate terminal window, create a new site by running bench new-site school.test.
1. Fork the school app
1. In a separate terminal window, create a new site by running bench new-site lms.test.
1. Fork the LMS app
1. Run bench get-app <url-of-your-form>.
1. Run bench --site school.test install-app school.
1. Map your site to localhost with the command ```bench --site school.test add-to-hosts```
1. Now open the URL http://school.test:8000/ in your browser, you should see the app running.
1. Run bench --site lms.test install-app lms.
1. Map your site to localhost with the command ```bench --site lms.test add-to-hosts```
1. Now open the URL http://lms.test:8000/ in your browser, you should see the app running.
+18
View File
@@ -0,0 +1,18 @@
const { defineConfig } = require("cypress");
module.exports = defineConfig({
projectId: "vandxn",
adminPassword: "admin",
testUser: "frappe@example.com",
defaultCommandTimeout: 20000,
pageLoadTimeout: 15000,
video: true,
videoUploadOnPasses: false,
retries: {
runMode: 2,
openMode: 0,
},
e2e: {
baseUrl: "http://dd1:8000",
},
});
+133
View File
@@ -0,0 +1,133 @@
describe("Course Creation", () => {
it("creates a new course", () => {
cy.login();
cy.visit("/courses");
// Create a course
cy.get("a.btn").contains("Create a Course").click();
cy.wait(1000);
cy.url().should("include", "/courses/new-course/edit");
cy.get("#title").type("Test Course");
cy.get("#intro").type("Test Course Short Introduction");
cy.get("#description").type("Test Course Description");
cy.get("#video-link").type("-LPmw2Znl2c");
cy.get("#tags-input").type("Test");
cy.get("#published").check();
cy.wait(1000);
cy.button("Save").click();
// Add Chapter
cy.wait(1000);
cy.link("Course Outline").click();
cy.wait(1000);
cy.get(".edit-header .btn-add-chapter").click();
cy.wait(500);
cy.get("#chapter-title").type("Test Chapter");
cy.get("#chapter-description").type("Test Chapter Description");
cy.button("Save").click();
// Add Lesson
cy.wait(1000);
cy.link("Add Lesson").click();
cy.wait(1000);
cy.get("#lesson-title").type("Test Lesson");
// Content
cy.get(".collapse-section.collapsed:first").click();
cy.get("#lesson-content .ce-block")
.click()
.type(
"This is an extremely big paragraph that is meant to test the UI. This is a very long paragraph. It contains more than once sentence. Its meant to be this long as this is a UI test. Its unbearably long and I'm not sure why I'm typing this much. I'm just going to keep typing until I feel like its long enough. I think its long enough now. I'm going to stop typing now. {enter}"
);
cy.get("#lesson-content .ce-toolbar__plus").click();
cy.get('#lesson-content [data-item-name="youtube"]').click();
cy.get('input[data-fieldname="youtube"]').type("GoDtyItReto");
cy.button("Insert").click();
cy.wait(1000);
cy.button("Save").click();
// View Course
cy.wait(1000);
cy.visit("/courses");
cy.get(".course-card-title:first").contains("Test Course");
cy.get(".course-card:first").click();
cy.url().should("include", "/courses/test-course");
cy.get("#title").contains("Test Course");
cy.get(".preview-video").should(
"have.attr",
"src",
"https://www.youtube.com/embed/-LPmw2Znl2c"
);
cy.get("#intro").contains("Test Course Short Introduction");
// View Chapter
cy.get(".chapter-title-main:first").contains("Test Chapter");
cy.get(".chapter-description:first").contains(
"Test Chapter Description"
);
cy.get(".lesson-info:first").contains("Test Lesson");
cy.get(".lesson-info:first").click();
// View Lesson
cy.wait(1000);
cy.url().should("include", "learn/1.1");
cy.get("#title").contains("Test Lesson");
cy.get(".lesson-video iframe").should(
"have.attr",
"src",
"https://www.youtube.com/embed/GoDtyItReto"
);
cy.get(".lesson-content-card").contains(
"This is an extremely big paragraph that is meant to test the UI. This is a very long paragraph. It contains more than once sentence. Its meant to be this long as this is a UI test. Its unbearably long and I'm not sure why I'm typing this much. I'm just going to keep typing until I feel like its long enough. I think its long enough now. I'm going to stop typing now."
);
// Add Discussion
cy.get(".reply").click();
cy.wait(500);
cy.get(".discussion-modal").should("be.visible");
// Enter title
cy.get(".modal .topic-title")
.type("Discussion from tests")
.should("have.value", "Discussion from tests");
// Enter comment
cy.get(".modal .discussions-comment").type(
"This is a discussion from the cypress ui tests."
);
// Submit
cy.get(".modal .submit-discussion").click();
cy.wait(2000);
// Check if discussion is added to page and content is visible
cy.get(".sidebar-parent:first .discussion-topic-title").should(
"have.text",
"Discussion from tests"
);
cy.get(".sidebar-parent:first .discussion-topic-title").click();
cy.get(".discussion-on-page:visible").should("have.class", "show");
cy.get(
".discussion-on-page:visible .reply-card .reply-text .ql-editor p"
).should(
"have.text",
"This is a discussion from the cypress ui tests."
);
cy.get(".discussion-form:visible .discussions-comment").type(
"This is a discussion from the cypress ui tests. \n\nThis comment was entered through the commentbox on the page."
);
cy.get(".discussion-form:visible .submit-discussion").click();
cy.wait(3000);
cy.get(".discussion-on-page:visible").should("have.class", "show");
cy.get(".discussion-on-page:visible")
.children(".reply-card")
.eq(1)
.find(".reply-text")
.should(
"have.text",
"This is a discussion from the cypress ui tests. This comment was entered through the commentbox on the page.\n"
);
});
});
+5
View File
@@ -0,0 +1,5 @@
{
"name": "Using fixtures to represent data",
"email": "hello@cypress.io",
"body": "Fixtures are a great way to mock data for responses to routes"
}
+55
View File
@@ -0,0 +1,55 @@
// ***********************************************
// This example commands.js shows you how to
// create various custom commands and overwrite
// existing commands.
//
// For more comprehensive examples of custom
// commands please read more here:
// https://on.cypress.io/custom-commands
// ***********************************************
//
//
// -- This is a parent command --
// Cypress.Commands.add('login', (email, password) => { ... })
//
//
// -- This is a child command --
// Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... })
//
//
// -- This is a dual command --
// Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... })
//
//
// -- This will overwrite an existing command --
// Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... })
Cypress.Commands.add("login", (email, password) => {
if (!email) {
email = Cypress.config("testUser") || "Administrator";
}
if (!password) {
password = Cypress.config("adminPassword");
}
cy.request({
url: "/api/method/login",
method: "POST",
body: { usr: email, pwd: password },
});
});
Cypress.Commands.add("button", (text) => {
return cy.get(`button:contains("${text}")`);
});
Cypress.Commands.add("link", (text) => {
return cy.get(`a:contains("${text}")`);
});
Cypress.Commands.add("iconButton", (text) => {
return cy.get(`button[aria-label="${text}"]`);
});
Cypress.Commands.add("dialog", (selector) => {
return cy.get(`[role=dialog] ${selector}`);
});
+20
View File
@@ -0,0 +1,20 @@
// ***********************************************************
// This example support/e2e.js is processed and
// loaded automatically before your test files.
//
// This is a great place to put global configuration and
// behavior that modifies Cypress.
//
// You can change the location of this file or turn off
// automatically serving support files with the
// 'supportFile' configuration option.
//
// You can read more here:
// https://on.cypress.io/configuration
// ***********************************************************
// Import commands.js using ES2015 syntax:
import "./commands";
// Alternatively you can use CommonJS syntax:
// require('./commands')
-25
View File
@@ -1,25 +0,0 @@
version: "3"
services:
mariadb:
image: mariadb
volumes:
- mariadb-storage:/var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=root
command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
bench:
image: anandology/frappe-bench:2021.10
volumes:
- .:/opt/frappe-bench/apps/school
environment:
- FRAPPE_APPS=school
- FRAPPE_ALLOW_TESTS=true
- FRAPPE_SITE_NAME=frappe.localhost
depends_on:
- mariadb
ports:
- 8000:8000
- 9000:9000
volumes:
mariadb-storage: {}
+2 -2
View File
@@ -1,9 +1,9 @@
**Step 1:** Clone the repo
```
$ git clone https://github.com/frappe/school.git
$ git clone https://github.com/frappe/lms.git
$ cd school
$ cd lms
```
**Step 2:** Run docker-compose
+32
View File
@@ -0,0 +1,32 @@
version: "3.7"
name: lms
services:
mariadb:
image: mariadb:10.6
command:
- --character-set-server=utf8mb4
- --collation-server=utf8mb4_unicode_ci
- --skip-character-set-client-handshake
- --skip-innodb-read-only-compressed # Temporary fix for MariaDB 10.6
environment:
MYSQL_ROOT_PASSWORD: 123
volumes:
- mariadb-data:/var/lib/mysql
redis:
image: redis:alpine
frappe:
image: frappe/bench:latest
command: bash /workspace/init.sh
environment:
- SHELL=/bin/bash
working_dir: /home/frappe
volumes:
- .:/workspace
ports:
- 8000:8000
- 9000:9000
volumes:
mariadb-data:
+41
View File
@@ -0,0 +1,41 @@
#!bin/bash
if [ -d "/home/frappe/frappe-bench/apps/frappe" ]; then
echo "Bench already exists, skipping init"
cd frappe-bench
bench start
else
echo "Creating new bench..."
fi
export PATH="${NVM_DIR}/versions/node/v${NODE_VERSION_DEVELOP}/bin/:${PATH}"
bench init --skip-redis-config-generation frappe-bench
cd frappe-bench
# Use containers instead of localhost
bench set-mariadb-host mariadb
bench set-redis-cache-host redis:6379
bench set-redis-queue-host redis:6379
bench set-redis-socketio-host redis:6379
# Remove redis, watch from Procfile
sed -i '/redis/d' ./Procfile
sed -i '/watch/d' ./Procfile
bench get-app lms
bench new-site lms.localhost \
--force \
--mariadb-root-password 123 \
--admin-password admin \
--no-mariadb-socket
bench --site lms.localhost install-app lms
bench --site lms.localhost set-config developer_mode 1
bench --site lms.localhost clear-cache
bench --site lms.localhost set-config mute_emails 1
bench use lms.localhost
bench start
+1
View File
@@ -0,0 +1 @@
__version__ = "1.0.0"
@@ -1,7 +1,6 @@
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from frappe import _
def get_data():
return [
{
@@ -9,6 +8,6 @@ def get_data():
"color": "grey",
"icon": "octicon octicon-file-directory",
"type": "module",
"label": _("Community")
"label": _("Community"),
}
]
@@ -7,5 +7,6 @@ Configuration for docs
# headline = "App that does everything"
# sub_heading = "Yes, you got that right the first time, everything"
def get_context(context):
context.brand_html = "Community"
File diff suppressed because it is too large Load Diff
+114
View File
@@ -0,0 +1,114 @@
[
{
"docstatus": 0,
"doctype": "Function",
"function": "Consulting",
"modified": "2021-12-14 15:16:26.189604",
"name": "Consulting"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Data & Analytics",
"modified": "2021-12-14 15:16:26.341051",
"name": "Data & Analytics"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Design & Creative",
"modified": "2021-12-14 15:16:26.343820",
"name": "Design & Creative"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Engineering (Non Software)",
"modified": "2021-12-14 15:16:26.346329",
"name": "Engineering (Non Software)"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Finance, Investment & Accounting",
"modified": "2021-12-14 15:16:26.351518",
"name": "Finance, Investment & Accounting"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Human Resource & Recruiting",
"modified": "2021-12-14 15:16:26.354310",
"name": "Human Resource & Recruiting"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Legal",
"modified": "2021-12-14 15:16:26.356844",
"name": "Legal"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Marketing, Advertising & PR",
"modified": "2021-12-14 15:16:26.359511",
"name": "Marketing, Advertising & PR"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Operations & Admin",
"modified": "2021-12-14 15:16:26.362571",
"name": "Operations & Admin"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Project Management",
"modified": "2021-12-14 15:16:26.365033",
"name": "Project Management"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Product",
"modified": "2021-12-14 15:16:26.367804",
"name": "Product"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Research, Training & Education",
"modified": "2021-12-14 15:16:26.370085",
"name": "Research, Training & Education"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Sales & Customer Service",
"modified": "2021-12-14 15:16:26.372635",
"name": "Sales & Customer Service"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Supply Chain, Logistics Strategy & Management",
"modified": "2021-12-14 15:16:26.375091",
"name": "Supply Chain, Logistics Strategy & Management"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Other",
"modified": "2021-12-14 15:16:26.377761",
"name": "Other"
},
{
"docstatus": 0,
"doctype": "Function",
"function": "Engineering (Software & IT)",
"modified": "2021-12-14 15:16:26.348864",
"name": "Engineering (Software & IT)"
}
]
+170
View File
@@ -0,0 +1,170 @@
[
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Accounting",
"modified": "2021-12-14 15:21:18.044741",
"name": "Accounting"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Ads, Marketing, PR & Events",
"modified": "2021-12-14 15:21:18.069794",
"name": "Ads, Marketing, PR & Events"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Agriculture, Fishing & Forestry",
"modified": "2021-12-14 15:21:18.074148",
"name": "Agriculture, Fishing & Forestry"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Architecture",
"modified": "2021-12-14 15:21:18.078250",
"name": "Architecture"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Aviation & Aerospace",
"modified": "2021-12-14 15:21:18.082127",
"name": "Aviation & Aerospace"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Banking, Financial Services & Insurance",
"modified": "2021-12-14 15:21:18.087499",
"name": "Banking, Financial Services & Insurance"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Biotech & Pharmaceuticals",
"modified": "2021-12-14 15:21:18.092094",
"name": "Biotech & Pharmaceuticals"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Construction & Real Estate",
"modified": "2021-12-14 15:21:18.095728",
"name": "Construction & Real Estate"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Consulting & Professional Services",
"modified": "2021-12-14 15:21:18.099171",
"name": "Consulting & Professional Services"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Energy & Utilities",
"modified": "2021-12-14 15:21:18.114022",
"name": "Energy & Utilities"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Food & Beverages",
"modified": "2021-12-14 15:21:18.124655",
"name": "Food & Beverages"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Health & Medical",
"modified": "2021-12-14 15:21:18.127914",
"name": "Health & Medical"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Hospitality & Tourism",
"modified": "2021-12-14 15:21:18.130783",
"name": "Hospitality & Tourism"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "IT / Ecommerce / Internet",
"modified": "2021-12-14 15:21:18.134069",
"name": "IT / Ecommerce / Internet"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Manufacturing & Production",
"modified": "2021-12-14 15:21:18.137362",
"name": "Manufacturing & Production"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Media & Entertainment",
"modified": "2021-12-14 15:21:18.140180",
"name": "Media & Entertainment"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Public Service & NGOs",
"modified": "2021-12-14 15:21:18.143125",
"name": "Public Service & NGOs"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Retail, Fashion & FMCG",
"modified": "2021-12-14 15:21:18.146020",
"name": "Retail, Fashion & FMCG"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Staffing & Recruiting",
"modified": "2021-12-14 15:21:18.149084",
"name": "Staffing & Recruiting"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Transportation & Logistics",
"modified": "2021-12-14 15:21:18.151952",
"name": "Transportation & Logistics"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Security & Law Enforcement",
"modified": "2021-12-14 15:21:18.154929",
"name": "Security & Law Enforcement"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Other",
"modified": "2021-12-14 15:21:18.157766",
"name": "Other"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Education & Training",
"modified": "2021-12-14 15:21:18.105864",
"name": "Education & Training"
},
{
"docstatus": 0,
"doctype": "Industry",
"industry": "Engineering",
"modified": "2021-12-14 15:21:18.119149",
"name": "Engineering"
}
]
+323
View File
@@ -0,0 +1,323 @@
from . import __version__ as app_version
app_name = "frappe_lms"
app_title = "Frappe LMS"
app_publisher = "Frappe"
app_description = "Frappe LMS App"
app_icon = "octicon octicon-file-directory"
app_color = "grey"
app_email = "school@frappe.io"
app_license = "AGPL"
# Includes in <head>
# ------------------
# include js, css files in header of desk.html
# app_include_css = "/assets/lms/css/lms.css"
# app_include_js = "/assets/lms/js/lms.js"
# include js, css files in header of web template
web_include_css = "lms.bundle.css"
# web_include_css = "/assets/lms/css/lms.css"
web_include_js = ["website.bundle.js"]
# include custom scss in every website theme (without file extension ".scss")
# website_theme_scss = "lms/public/scss/website"
# include js, css files in header of web form
# webform_include_js = {"doctype": "public/js/doctype.js"}
# webform_include_css = {"doctype": "public/css/doctype.css"}
# include js in page
# page_js = {"page" : "public/js/file.js"}
# include js in doctype views
# doctype_js = {"doctype" : "public/js/doctype.js"}
# doctype_list_js = {"doctype" : "public/js/doctype_list.js"}
# doctype_tree_js = {"doctype" : "public/js/doctype_tree.js"}
# doctype_calendar_js = {"doctype" : "public/js/doctype_calendar.js"}
# Home Pages
# ----------
# application home page (will override Website Settings)
# home_page = "login"
# website user home page (by Role)
# role_home_page = {
# "Role": "home_page"
# }
# Generators
# ----------
# automatically create page for each record of this doctype
# website_generators = ["Web Page"]
# Installation
# ------------
# before_install = "lms.install.before_install"
after_install = "lms.install.after_install"
after_sync = "lms.install.after_sync"
before_uninstall = "lms.install.before_uninstall"
setup_wizard_requires = "assets/lms/js/setup_wizard.js"
# Desk Notifications
# ------------------
# See frappe.core.notifications.get_notification_config
# notification_config = "lms.notifications.get_notification_config"
# Permissions
# -----------
# Permissions evaluated in scripted ways
# permission_query_conditions = {
# "Event": "frappe.desk.doctype.event.event.get_permission_query_conditions",
# }
#
# has_permission = {
# "Event": "frappe.desk.doctype.event.event.has_permission",
# }
# DocType Class
# ---------------
# Override standard doctype classes
override_doctype_class = {
"User": "lms.overrides.user.CustomUser",
"Web Template": "lms.overrides.web_template.CustomWebTemplate",
}
# Document Events
# ---------------
# Hook on document methods and events
doc_events = {
"Discussion Reply": {"after_insert": "lms.lms.utils.create_notification_log"},
"Course Lesson": {"on_update": "lms.lms.doctype.lms_quiz.lms_quiz.update_lesson_info"},
}
# Scheduled Tasks
# ---------------
scheduler_events = {
"hourly": [
"lms.lms.doctype.lms_certificate_request.lms_certificate_request.schedule_evals"
]
}
fixtures = ["Custom Field", "Function", "Industry"]
# Testing
# -------
# before_tests = "lms.install.before_tests"
# Overriding Methods
# ------------------------------
#
# override_whitelisted_methods = {
# "frappe.desk.doctype.event.event.get_events": "lms.event.get_events"
# }
#
# each overriding function accepts a `data` argument;
# generated from the base implementation of the doctype dashboard,
# along with any modifications made in other Frappe apps
# override_doctype_dashboards = {
# "Task": "lms.task.get_dashboard_data"
# }
# exempt linked doctypes from being automatically cancelled
#
# auto_cancel_exempted_doctypes = ["Auto Repeat"]
# Add all simple route rules here
website_route_rules = [
{"from_route": "/sketches/<sketch>", "to_route": "sketches/sketch"},
{"from_route": "/courses/<course>", "to_route": "courses/course"},
{"from_route": "/courses/<course>/edit", "to_route": "courses/create"},
{"from_route": "/courses/<course>/outline", "to_route": "courses/outline"},
{"from_route": "/courses/<course>/<certificate>", "to_route": "courses/certificate"},
{"from_route": "/courses/<course>/learn", "to_route": "batch/learn"},
{
"from_route": "/courses/<course>/learn/<int:chapter>.<int:lesson>",
"to_route": "batch/learn",
},
{
"from_route": "/courses/<course>/learn/<int:chapter>.<int:lesson>/edit",
"to_route": "batch/edit",
},
{"from_route": "/quizzes", "to_route": "batch/quiz_list"},
{"from_route": "/quizzes/<quizname>", "to_route": "batch/quiz"},
{"from_route": "/batches/<batchname>", "to_route": "batches/batch"},
{"from_route": "/courses/<course>/progress", "to_route": "batch/progress"},
{"from_route": "/courses/<course>/join", "to_route": "batch/join"},
{"from_route": "/courses/<course>/manage", "to_route": "cohorts"},
{"from_route": "/courses/<course>/cohorts/<cohort>", "to_route": "cohorts/cohort"},
{
"from_route": "/courses/<course>/cohorts/<cohort>/<page>",
"to_route": "cohorts/cohort",
},
{
"from_route": "/courses/<course>/subgroups/<cohort>/<subgroup>",
"to_route": "cohorts/subgroup",
},
{
"from_route": "/courses/<course>/subgroups/<cohort>/<subgroup>/<page>",
"to_route": "cohorts/subgroup",
},
{
"from_route": "/courses/<course>/join/<cohort>/<subgroup>/<invite_code>",
"to_route": "cohorts/join",
},
{"from_route": "/users", "to_route": "profiles/profile"},
{"from_route": "/jobs/<job>", "to_route": "jobs/job"},
{
"from_route": "/batches/<batchname>/students/<username>",
"to_route": "/batches/progress",
},
{"from_route": "/assignments/<assignment>", "to_route": "assignments/assignment"},
{
"from_route": "/assignment-submission/<assignment>/<submission>",
"to_route": "assignment_submission/assignment_submission",
},
{
"from_route": "/quiz-submission/<quiz>/<submission>",
"to_route": "quiz_submission/quiz_submission",
},
{
"from_route": "/billing/<module>/<modulename>",
"to_route": "billing/billing",
},
{
"from_route": "/batches/details/<batchname>",
"to_route": "batches/batch_details",
},
{
"from_route": "/certified-participants",
"to_route": "certified_participants/certified_participants",
},
]
website_redirects = [
{"source": "/update-profile", "target": "/edit-profile"},
{"source": "/dashboard", "target": "/courses"},
{"source": "/community", "target": "/people"},
]
update_website_context = [
"lms.widgets.update_website_context",
]
jinja = {
"methods": [
"lms.page_renderers.get_profile_url",
"lms.overrides.user.get_enrolled_courses",
"lms.overrides.user.get_course_membership",
"lms.overrides.user.get_authored_courses",
"lms.overrides.user.get_palette",
"lms.lms.utils.get_membership",
"lms.lms.utils.get_lessons",
"lms.lms.utils.get_tags",
"lms.lms.utils.get_instructors",
"lms.lms.utils.get_students",
"lms.lms.utils.get_average_rating",
"lms.lms.utils.is_certified",
"lms.lms.utils.get_lesson_index",
"lms.lms.utils.get_lesson_url",
"lms.lms.utils.get_chapters",
"lms.lms.utils.get_slugified_chapter_title",
"lms.lms.utils.get_progress",
"lms.lms.utils.render_html",
"lms.lms.utils.is_mentor",
"lms.lms.utils.is_cohort_staff",
"lms.lms.utils.get_mentors",
"lms.lms.utils.get_reviews",
"lms.lms.utils.is_eligible_to_review",
"lms.lms.utils.get_initial_members",
"lms.lms.utils.get_sorted_reviews",
"lms.lms.utils.is_instructor",
"lms.lms.utils.convert_number_to_character",
"lms.lms.utils.get_signup_optin_checks",
"lms.lms.utils.get_popular_courses",
"lms.lms.utils.format_amount",
"lms.lms.utils.first_lesson_exists",
"lms.lms.utils.get_courses_under_review",
"lms.lms.utils.has_course_instructor_role",
"lms.lms.utils.has_course_moderator_role",
"lms.lms.utils.get_certificates",
"lms.lms.utils.format_number",
"lms.lms.utils.get_lesson_count",
"lms.lms.utils.get_all_memberships",
"lms.lms.utils.get_filtered_membership",
"lms.lms.utils.show_start_learing_cta",
"lms.lms.utils.can_create_courses",
"lms.lms.utils.get_telemetry_boot_info",
"lms.lms.utils.is_onboarding_complete",
"lms.www.utils.is_student",
],
"filters": [],
}
## Specify the additional tabs to be included in the user profile page.
## Each entry must be a subclass of lms.lms.plugins.ProfileTab
# profile_tabs = []
## Specify the extension to be used to control what scripts and stylesheets
## to be included in lesson pages. The specified value must be be a
## subclass of lms.plugins.PageExtension
# lms_lesson_page_extension = None
# lms_lesson_page_extensions = [
# "lms.plugins.LiveCodeExtension"
# ]
has_website_permission = {
"LMS Certificate Evaluation": "lms.lms.doctype.lms_certificate_evaluation.lms_certificate_evaluation.has_website_permission"
}
profile_mandatory_fields = [
"first_name",
"last_name",
"user_image",
"bio",
"linkedin",
"education",
"skill",
"preferred_functions",
"preferred_industries",
"dream_companies",
"attire",
"collaboration",
"role",
"location_preference",
"time",
"company_type",
]
## Markdown Macros for Lessons
lms_markdown_macro_renderers = {
"Exercise": "lms.plugins.exercise_renderer",
"Quiz": "lms.plugins.quiz_renderer",
"YouTubeVideo": "lms.plugins.youtube_video_renderer",
"Video": "lms.plugins.video_renderer",
"Assignment": "lms.plugins.assignment_renderer",
"Embed": "lms.plugins.embed_renderer",
"Audio": "lms.plugins.audio_renderer",
"PDF": "lms.plugins.pdf_renderer",
}
# page_renderer to manage profile pages
page_renderer = [
"lms.page_renderers.ProfileRedirectPage",
"lms.page_renderers.ProfilePage",
]
# set this to "/" to have profiles on the top-level
profile_url_prefix = "/users/"
signup_form_template = "lms.plugins.show_custom_signup"
on_session_creation = "lms.overrides.user.on_session_creation"
+184
View File
@@ -0,0 +1,184 @@
import frappe
from frappe.desk.page.setup_wizard.setup_wizard import add_all_roles_to
def after_install():
add_pages_to_nav()
def after_sync():
create_lms_roles()
set_default_home()
set_default_certificate_print_format()
add_all_roles_to("Administrator")
def add_pages_to_nav():
pages = [
{"label": "Explore", "idx": 1},
{"label": "Courses", "url": "/courses", "parent": "Explore", "idx": 2},
{"label": "Batches", "url": "/batches", "parent": "Explore", "idx": 3},
{"label": "Statistics", "url": "/statistics", "parent": "Explore", "idx": 4},
{"label": "Jobs", "url": "/jobs", "parent": "Explore", "idx": 5},
{"label": "People", "url": "/community", "parent": "Explore", "idx": 6},
]
for page in pages:
filters = frappe._dict()
if page.get("url"):
filters["url"] = ["like", "%" + page.get("url") + "%"]
else:
filters["label"] = page.get("label")
if not frappe.db.exists("Top Bar Item", filters):
frappe.get_doc(
{
"doctype": "Top Bar Item",
"label": page.get("label"),
"url": page.get("url"),
"parent_label": page.get("parent"),
"idx": page.get("idx"),
"parent": "Website Settings",
"parenttype": "Website Settings",
"parentfield": "top_bar_items",
}
).save()
def before_uninstall():
delete_custom_fields()
delete_lms_roles()
def create_lms_roles():
create_course_creator_role()
create_moderator_role()
create_evaluator_role()
create_lms_student_role()
def delete_lms_roles():
roles = ["Course Creator", "Moderator"]
for role in roles:
if frappe.db.exists("Role", role):
frappe.db.delete("Role", role)
def set_default_home():
frappe.db.set_single_value("Portal Settings", "default_portal_home", "/courses")
def create_course_creator_role():
if not frappe.db.exists("Role", "Course Creator"):
role = frappe.get_doc(
{
"doctype": "Role",
"role_name": "Course Creator",
"home_page": "",
"desk_access": 0,
}
)
role.save()
def create_moderator_role():
if not frappe.db.exists("Role", "Moderator"):
role = frappe.get_doc(
{
"doctype": "Role",
"role_name": "Moderator",
"home_page": "",
"desk_access": 0,
}
)
role.save()
def create_evaluator_role():
if not frappe.db.exists("Role", "Class Evaluator"):
role = frappe.new_doc("Role")
role.update(
{
"role_name": "Class Evaluator",
"home_page": "",
"desk_access": 0,
}
)
role.save()
def create_lms_student_role():
if not frappe.db.exists("Role", "LMS Student"):
role = frappe.new_doc("Role")
role.update(
{
"role_name": "LMS Student",
"home_page": "",
"desk_access": 0,
}
)
role.save()
def set_default_certificate_print_format():
filters = {
"doc_type": "LMS Certificate",
"property": "default_print_format",
}
if not frappe.db.exists("Property Setter", filters):
filters.update(
{
"doctype_or_field": "DocType",
"property_type": "Data",
"value": "Certificate",
}
)
doc = frappe.new_doc("Property Setter")
doc.update(filters)
doc.save()
def delete_custom_fields():
fields = [
"user_category",
"headline",
"college",
"city",
"verify_terms",
"country",
"preferred_location",
"preferred_functions",
"preferred_industries",
"work_environment_column",
"time",
"role",
"carrer_preference_details",
"skill",
"certification_details",
"internship",
"branch",
"github",
"medium",
"linkedin",
"profession",
"looking_for_job",
"cover_image" "work_environment",
"dream_companies",
"career_preference_column",
"attire",
"collaboration",
"location_preference",
"company_type",
"skill_details",
"certification",
"education",
"work_experience",
"education_details",
"hide_private",
"work_experience_details",
"profile_complete",
]
for field in fields:
frappe.db.delete("Custom Field", {"fieldname": field})
@@ -0,0 +1,9 @@
// Copyright (c) 2021, Frappe and contributors
// For license information, please see license.txt
frappe.ui.form.on("Job Opportunity", {
refresh: (frm) => {
if (frm.doc.name)
frm.add_web_link(`/jobs/${frm.doc.name}`, "See on Website");
},
});
@@ -0,0 +1,157 @@
{
"actions": [],
"allow_import": 1,
"allow_rename": 1,
"autoname": "format: JOB-{#####}",
"creation": "2022-02-07 12:01:41.074418",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"job_title",
"location",
"disabled",
"column_break_5",
"type",
"status",
"section_break_6",
"description",
"company_details_section",
"company_name",
"company_website",
"column_break_11",
"company_logo",
"application_link"
],
"fields": [
{
"fieldname": "job_title",
"fieldtype": "Data",
"in_list_view": 1,
"in_standard_filter": 1,
"label": "Job Title",
"reqd": 1
},
{
"fieldname": "location",
"fieldtype": "Data",
"in_list_view": 1,
"in_standard_filter": 1,
"label": "Location",
"reqd": 1
},
{
"fieldname": "column_break_5",
"fieldtype": "Column Break"
},
{
"default": "Full Time",
"fieldname": "type",
"fieldtype": "Select",
"label": "Type",
"options": "Full Time\nPart Time\nFreelance\nContract",
"reqd": 1
},
{
"default": "Open",
"fieldname": "status",
"fieldtype": "Select",
"in_list_view": 1,
"in_standard_filter": 1,
"label": "Status",
"options": "Open\nClosed"
},
{
"fieldname": "section_break_6",
"fieldtype": "Section Break"
},
{
"fieldname": "description",
"fieldtype": "Text Editor",
"label": "Description",
"reqd": 1
},
{
"fieldname": "company_details_section",
"fieldtype": "Section Break",
"label": "Company Details"
},
{
"fieldname": "company_name",
"fieldtype": "Data",
"in_list_view": 1,
"in_standard_filter": 1,
"label": "Company Name",
"reqd": 1
},
{
"fieldname": "company_website",
"fieldtype": "Data",
"label": "Company Website",
"reqd": 1
},
{
"fieldname": "column_break_11",
"fieldtype": "Column Break"
},
{
"fieldname": "company_logo",
"fieldtype": "Attach Image",
"label": "Company Logo",
"reqd": 1
},
{
"fieldname": "application_link",
"fieldtype": "Data",
"label": "Application Form Link",
"reqd": 1
},
{
"default": "0",
"fieldname": "disabled",
"fieldtype": "Check",
"label": "Disabled"
}
],
"index_web_pages_for_search": 1,
"links": [],
"make_attachments_public": 1,
"modified": "2023-09-29 17:03:30.825021",
"modified_by": "Administrator",
"module": "Job",
"name": "Job Opportunity",
"naming_rule": "Expression",
"owner": "Administrator",
"permissions": [
{
"create": 1,
"delete": 1,
"email": 1,
"export": 1,
"print": 1,
"read": 1,
"report": 1,
"role": "System Manager",
"select": 1,
"share": 1,
"write": 1
},
{
"create": 1,
"email": 1,
"export": 1,
"if_owner": 1,
"print": 1,
"read": 1,
"report": 1,
"role": "LMS Student",
"select": 1,
"share": 1,
"write": 1
}
],
"sort_field": "modified",
"sort_order": "DESC",
"states": [],
"title_field": "job_title"
}
@@ -0,0 +1,41 @@
# Copyright (c) 2021, Frappe and contributors
# For license information, please see license.txt
import frappe
from frappe import _
from frappe.model.document import Document
from frappe.utils import get_link_to_form
from frappe.utils.user import get_system_managers
from lms.lms.utils import validate_image
class JobOpportunity(Document):
def validate(self):
self.validate_urls()
self.company_logo = validate_image(self.company_logo)
def validate_urls(self):
frappe.utils.validate_url(self.company_website, True)
frappe.utils.validate_url(self.application_link, True)
@frappe.whitelist()
def report(job, reason):
system_managers = get_system_managers(only_name=True)
user = frappe.db.get_value("User", frappe.session.user, "full_name")
subject = _("User {0} has reported the job post {1}").format(user, job)
args = {
"job": job,
"job_url": get_link_to_form("Job Opportunity", job),
"user": user,
"reason": reason,
}
frappe.sendmail(
recipients=system_managers,
subject=subject,
header=[subject, "green"],
template="job_report",
args=args,
now=True,
)
@@ -0,0 +1,9 @@
# Copyright (c) 2021, Frappe and Contributors
# See license.txt
# import frappe
import unittest
class TestJobOpportunity(unittest.TestCase):
pass
@@ -0,0 +1,7 @@
// Copyright (c) 2022, Frappe and contributors
// For license information, please see license.txt
frappe.ui.form.on("Job Settings", {
// refresh: function(frm) {
// }
});
@@ -0,0 +1,54 @@
{
"actions": [],
"allow_rename": 1,
"creation": "2022-02-07 12:01:41.422955",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"allow_posting",
"title",
"subtitle"
],
"fields": [
{
"default": "0",
"fieldname": "allow_posting",
"fieldtype": "Check",
"label": "Allow Job Posting From Website"
},
{
"fieldname": "title",
"fieldtype": "Data",
"label": "Job Board Title"
},
{
"fieldname": "subtitle",
"fieldtype": "Data",
"label": "Job Board Subtitle"
}
],
"index_web_pages_for_search": 1,
"issingle": 1,
"links": [],
"modified": "2022-02-11 15:56:38.958317",
"modified_by": "Administrator",
"module": "Job",
"name": "Job Settings",
"owner": "Administrator",
"permissions": [
{
"create": 1,
"delete": 1,
"email": 1,
"print": 1,
"read": 1,
"role": "System Manager",
"share": 1,
"write": 1
}
],
"sort_field": "modified",
"sort_order": "DESC",
"states": []
}
@@ -1,8 +1,9 @@
# Copyright (c) 2021, FOSS United and contributors
# Copyright (c) 2022, Frappe and contributors
# For license information, please see license.txt
# import frappe
from frappe.model.document import Document
class Speaker(Document):
class JobSettings(Document):
pass
@@ -0,0 +1,9 @@
# Copyright (c) 2022, Frappe and Contributors
# See license.txt
# import frappe
import unittest
class TestJobSettings(unittest.TestCase):
pass
@@ -0,0 +1,28 @@
{
"attach_print": 0,
"channel": "Email",
"creation": "2021-12-30 12:29:56.533903",
"days_in_advance": 0,
"docstatus": 0,
"doctype": "Notification",
"document_type": "Job Opportunity",
"enabled": 1,
"event": "New",
"idx": 0,
"is_standard": 1,
"message": "Hey,\n\nA new Job Opportunity has been created. \n\n<p>Company Name: {{ doc.company_name}}</p>\n<p>Job Title: {{ doc.job_title}}</p>\n<p>Job Location: {{ doc.location}}</p><br>\n<p>Job Description: {{ doc.description}}</p><br>\n\n<p>Find all the posted jobs <a href=\"{{ frappe.utils.get_url() }}/app/job-opportunity\">here</a>.</p><br>\n",
"modified": "2021-12-30 12:54:13.382512",
"modified_by": "Administrator",
"module": "Job",
"name": "New job alert",
"owner": "Administrator",
"recipients": [
{
"receiver_by_role": "System Manager"
}
],
"send_system_notification": 0,
"send_to_all_assignees": 0,
"sender_email": "",
"subject": "New job added by {{ doc.company_name}}"
}
@@ -0,0 +1,10 @@
Hey,
A new Job Opportunity has been created.
<p>Company Name: {{ doc.company_name}}</p>
<p>Job Title: {{ doc.job_title}}</p>
<p>Job Location: {{ doc.location}}</p><br>
<p>Job Description: {{ doc.description}}</p><br>
<p>Find all the posted jobs <a href="{{ frappe.utils.get_url() }}/app/job-opportunity">here</a>.</p><br>
@@ -1,5 +1,6 @@
import frappe
def get_context(context):
# do your magic here
pass
@@ -0,0 +1,7 @@
frappe.ready(function () {
frappe.web_form.after_save = () => {
setTimeout(() => {
window.location.href = `/jobs`;
});
};
});
@@ -0,0 +1,151 @@
{
"accept_payment": 0,
"allow_comments": 0,
"allow_delete": 0,
"allow_edit": 1,
"allow_incomplete": 0,
"allow_multiple": 1,
"allow_print": 0,
"amount": 0.0,
"amount_based_on_field": 0,
"apply_document_permissions": 1,
"button_label": "Save",
"creation": "2021-12-27 17:02:12.461145",
"custom_css": "[data-doctype=\"Web Form\"] {\n max-width: 720px;\n margin: 6rem auto;\n}",
"doc_type": "Job Opportunity",
"docstatus": 0,
"doctype": "Web Form",
"idx": 0,
"is_standard": 1,
"list_columns": [],
"login_required": 1,
"max_attachment_size": 0,
"modified": "2022-09-15 17:22:43.957184",
"modified_by": "Administrator",
"module": "Job",
"name": "job-opportunity",
"owner": "Administrator",
"payment_button_label": "Buy Now",
"published": 1,
"route": "job-opportunity",
"show_attachments": 0,
"show_list": 1,
"show_sidebar": 0,
"success_message": "",
"success_url": "/jobs",
"title": "Job Opportunity",
"web_form_fields": [
{
"allow_read_on_all_link_options": 0,
"fieldname": "job_title",
"fieldtype": "Data",
"hidden": 0,
"label": "Job Title",
"max_length": 0,
"max_value": 0,
"read_only": 0,
"reqd": 1,
"show_in_filter": 0
},
{
"allow_read_on_all_link_options": 0,
"fieldname": "location",
"fieldtype": "Data",
"hidden": 0,
"label": "Location",
"max_length": 0,
"max_value": 0,
"read_only": 0,
"reqd": 1,
"show_in_filter": 0
},
{
"allow_read_on_all_link_options": 0,
"default": "Full Time",
"fieldname": "type",
"fieldtype": "Select",
"hidden": 0,
"label": "Type",
"max_length": 0,
"max_value": 0,
"options": "Full Time\nPart Time\nFreelance\nContract",
"read_only": 0,
"reqd": 1,
"show_in_filter": 0
},
{
"allow_read_on_all_link_options": 0,
"default": "Open",
"fieldname": "status",
"fieldtype": "Select",
"hidden": 0,
"label": "Status",
"max_length": 0,
"max_value": 0,
"options": "Open\nClosed",
"read_only": 0,
"reqd": 0,
"show_in_filter": 0
},
{
"allow_read_on_all_link_options": 0,
"fieldname": "company_name",
"fieldtype": "Data",
"hidden": 0,
"label": "Company Name",
"max_length": 0,
"max_value": 0,
"read_only": 0,
"reqd": 1,
"show_in_filter": 0
},
{
"allow_read_on_all_link_options": 0,
"fieldname": "company_website",
"fieldtype": "Data",
"hidden": 0,
"label": "Company Website",
"max_length": 0,
"max_value": 0,
"read_only": 0,
"reqd": 1,
"show_in_filter": 0
},
{
"allow_read_on_all_link_options": 0,
"fieldname": "company_logo",
"fieldtype": "Attach Image",
"hidden": 0,
"label": "Company Logo",
"max_length": 0,
"max_value": 0,
"read_only": 0,
"reqd": 1,
"show_in_filter": 0
},
{
"allow_read_on_all_link_options": 0,
"fieldname": "application_link",
"fieldtype": "Data",
"hidden": 0,
"label": "Application Form Link",
"max_length": 0,
"max_value": 0,
"read_only": 0,
"reqd": 1,
"show_in_filter": 0
},
{
"allow_read_on_all_link_options": 0,
"fieldname": "description",
"fieldtype": "Text Editor",
"hidden": 0,
"label": "Description",
"max_length": 0,
"max_value": 0,
"read_only": 0,
"reqd": 1,
"show_in_filter": 0
}
]
}
@@ -1,5 +1,6 @@
import frappe
def get_context(context):
# do your magic here
pass
+141
View File
@@ -0,0 +1,141 @@
"""API methods for the LMS.
"""
import frappe
@frappe.whitelist()
def autosave_section(section, code):
"""Saves the code edited in one of the sections."""
doc = frappe.get_doc(
doctype="Code Revision", section=section, code=code, author=frappe.session.user
)
doc.insert()
return {"name": doc.name}
@frappe.whitelist()
def submit_solution(exercise, code):
"""Submits a solution.
@exerecise: name of the exercise to submit
@code: solution to the exercise
"""
ex = frappe.get_doc("LMS Exercise", exercise)
if not ex:
return
doc = ex.submit(code)
return {"name": doc.name, "creation": doc.creation}
@frappe.whitelist()
def save_current_lesson(course_name, lesson_name):
"""Saves the current lesson for a student/mentor."""
name = frappe.get_value(
doctype="LMS Enrollment",
filters={"course": course_name, "member": frappe.session.user},
fieldname="name",
)
if not name:
return
doc = frappe.get_doc("LMS Enrollment", name)
doc.current_lesson = lesson_name
doc.save()
return {"current_lesson": doc.current_lesson}
@frappe.whitelist()
def join_cohort(course, cohort, subgroup, invite_code):
"""Creates a Cohort Join Request for given user."""
course_doc = frappe.get_doc("LMS Course", course)
cohort_doc = course_doc and course_doc.get_cohort(cohort)
subgroup_doc = cohort_doc and cohort_doc.get_subgroup(subgroup)
if not subgroup_doc or subgroup_doc.invite_code != invite_code:
return {"ok": False, "error": "Invalid join link"}
data = {
"doctype": "Cohort Join Request",
"cohort": cohort_doc.name,
"subgroup": subgroup_doc.name,
"email": frappe.session.user,
"status": "Pending",
}
# Don't insert duplicate records
if frappe.db.exists(data):
return {"ok": True, "status": "record found"}
else:
doc = frappe.get_doc(data)
doc.insert()
return {"ok": True, "status": "record created"}
@frappe.whitelist()
def approve_cohort_join_request(join_request):
r = frappe.get_doc("Cohort Join Request", join_request)
sg = r and frappe.get_doc("Cohort Subgroup", r.subgroup)
if not sg or r.status not in ["Pending", "Accepted"]:
return {"ok": False, "error": "Invalid Join Request"}
if (
not sg.is_manager(frappe.session.user) and "System Manager" not in frappe.get_roles()
):
return {"ok": False, "error": "Permission Deined"}
r.status = "Accepted"
r.save()
return {"ok": True}
@frappe.whitelist()
def reject_cohort_join_request(join_request):
r = frappe.get_doc("Cohort Join Request", join_request)
sg = r and frappe.get_doc("Cohort Subgroup", r.subgroup)
if not sg or r.status not in ["Pending", "Rejected"]:
return {"ok": False, "error": "Invalid Join Request"}
if (
not sg.is_manager(frappe.session.user) and "System Manager" not in frappe.get_roles()
):
return {"ok": False, "error": "Permission Deined"}
r.status = "Rejected"
r.save()
return {"ok": True}
@frappe.whitelist()
def undo_reject_cohort_join_request(join_request):
r = frappe.get_doc("Cohort Join Request", join_request)
sg = r and frappe.get_doc("Cohort Subgroup", r.subgroup)
# keeping Pending as well to consider the case of duplicate requests
if not sg or r.status not in ["Pending", "Rejected"]:
return {"ok": False, "error": "Invalid Join Request"}
if (
not sg.is_manager(frappe.session.user) and "System Manager" not in frappe.get_roles()
):
return {"ok": False, "error": "Permission Deined"}
r.status = "Pending"
r.save()
return {"ok": True}
@frappe.whitelist()
def add_mentor_to_subgroup(subgroup, email):
try:
sg = frappe.get_doc("Cohort Subgroup", subgroup)
except frappe.DoesNotExistError:
return {"ok": False, "error": f"Invalid subgroup: {subgroup}"}
if (
not sg.get_cohort().is_admin(frappe.session.user)
and "System Manager" not in frappe.get_roles()
):
return {"ok": False, "error": "Permission Deined"}
try:
user = frappe.get_doc("User", email)
except frappe.DoesNotExistError:
return {"ok": False, "error": f"Invalid user: {email}"}
sg.add_mentor(email)
return {"ok": True}
@@ -2,23 +2,26 @@
"based_on": "creation",
"chart_name": "Course Enrollments",
"chart_type": "Count",
"color": "#4463F0",
"creation": "2021-09-30 12:23:09.414853",
"custom_options": "{\"type\": \"line\", \"axisOptions\": {\"xIsSeries\": 1}, \"lineOptions\": {\"regionFill\": 1}}",
"docstatus": 0,
"doctype": "Dashboard Chart",
"document_type": "LMS Batch Membership",
"document_type": "LMS Enrollment",
"dynamic_filters_json": "[]",
"filters_json": "[]",
"group_by_type": "Count",
"idx": 0,
"idx": 1,
"is_public": 1,
"is_standard": 1,
"last_synced_on": "2021-10-17 13:32:21.745498",
"modified": "2021-10-21 17:31:06.997133",
"last_synced_on": "2022-10-20 10:46:56.859520",
"modified": "2022-10-20 11:30:26.863009",
"modified_by": "Administrator",
"module": "LMS",
"name": "Course Enrollments",
"number_of_groups": 0,
"owner": "basawaraj@erpnext.com",
"roles": [],
"source": "",
"time_interval": "Daily",
"timeseries": 1,
@@ -0,0 +1,33 @@
{
"based_on": "creation",
"chart_name": "Lesson Completion",
"chart_type": "Count",
"color": "#4463F0",
"creation": "2022-11-09 16:52:19.021695",
"custom_options": "{\"type\": \"line\", \"axisOptions\": {\"xIsSeries\": 1}, \"lineOptions\": {\"regionFill\": 1}}",
"docstatus": 0,
"doctype": "Dashboard Chart",
"document_type": "LMS Course Progress",
"dynamic_filters_json": "[]",
"filters_json": "[]",
"group_by_type": "Count",
"idx": 0,
"is_public": 1,
"is_standard": 1,
"modified": "2022-11-09 16:52:52.241756",
"modified_by": "Administrator",
"module": "LMS",
"name": "Lesson Completion",
"number_of_groups": 0,
"owner": "Administrator",
"parent_document_type": "",
"roles": [],
"source": "",
"time_interval": "Daily",
"timeseries": 1,
"timespan": "Last Month",
"type": "Line",
"use_report_chart": 0,
"value_based_on": "",
"y_axis": []
}
@@ -0,0 +1,33 @@
{
"based_on": "creation",
"chart_name": "New Signups",
"chart_type": "Count",
"color": "#4463F0",
"creation": "2021-09-28 18:57:50.047656",
"custom_options": "{\"type\": \"line\", \"axisOptions\": {\"xIsSeries\": 1}, \"lineOptions\": {\"regionFill\": 1}}",
"docstatus": 0,
"doctype": "Dashboard Chart",
"document_type": "User",
"dynamic_filters_json": "[]",
"filters_json": "[]",
"group_by_type": "Count",
"idx": 1,
"is_public": 1,
"is_standard": 1,
"last_synced_on": "2022-10-20 10:46:56.849265",
"modified": "2022-10-20 11:31:17.184897",
"modified_by": "Administrator",
"module": "LMS",
"name": "New Signups",
"number_of_groups": 0,
"owner": "basawaraj@erpnext.com",
"roles": [],
"source": "",
"time_interval": "Daily",
"timeseries": 1,
"timespan": "Last Quarter",
"type": "Line",
"use_report_chart": 0,
"value_based_on": "",
"y_axis": []
}
@@ -0,0 +1,51 @@
{
"actions": [],
"autoname": "autoincrement",
"creation": "2022-11-09 16:23:26.454527",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"course",
"title",
"evaluator"
],
"fields": [
{
"fieldname": "course",
"fieldtype": "Link",
"in_list_view": 1,
"label": "Course",
"options": "LMS Course",
"reqd": 1
},
{
"fetch_from": "course.title",
"fieldname": "title",
"fieldtype": "Data",
"in_list_view": 1,
"label": "Course Title",
"read_only": 1
},
{
"fieldname": "evaluator",
"fieldtype": "Link",
"in_list_view": 1,
"label": "Evaluator",
"options": "Course Evaluator"
}
],
"index_web_pages_for_search": 1,
"istable": 1,
"links": [],
"modified": "2023-08-28 10:03:02.960844",
"modified_by": "Administrator",
"module": "LMS",
"name": "Batch Course",
"naming_rule": "Autoincrement",
"owner": "Administrator",
"permissions": [],
"sort_field": "modified",
"sort_order": "DESC",
"states": []
}
@@ -1,8 +1,9 @@
# Copyright (c) 2021, FOSS United and contributors
# Copyright (c) 2022, Frappe and contributors
# For license information, please see license.txt
# import frappe
from frappe.model.document import Document
class Attendee(Document):
class BatchCourse(Document):
pass
@@ -0,0 +1,7 @@
// Copyright (c) 2022, Frappe and contributors
// For license information, please see license.txt
frappe.ui.form.on("Batch Student", {
// refresh: function(frm) {
// }
});
@@ -0,0 +1,76 @@
{
"actions": [],
"allow_rename": 1,
"creation": "2022-11-09 16:20:44.602545",
"default_view": "List",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"student_details_section",
"student",
"payment",
"confirmation_email_sent",
"column_break_oduu",
"student_name",
"username"
],
"fields": [
{
"fieldname": "student",
"fieldtype": "Link",
"in_list_view": 1,
"label": "Student",
"options": "User",
"reqd": 1
},
{
"fetch_from": "student.full_name",
"fieldname": "student_name",
"fieldtype": "Data",
"in_list_view": 1,
"label": "Student Name",
"read_only": 1
},
{
"fetch_from": "student.username",
"fieldname": "username",
"fieldtype": "Data",
"label": "Username",
"read_only": 1
},
{
"fieldname": "student_details_section",
"fieldtype": "Section Break",
"label": "Student Details"
},
{
"fieldname": "column_break_oduu",
"fieldtype": "Column Break"
},
{
"fieldname": "payment",
"fieldtype": "Link",
"label": "Payment",
"options": "LMS Payment"
},
{
"default": "0",
"fieldname": "confirmation_email_sent",
"fieldtype": "Check",
"label": "Confirmation Email Sent"
}
],
"index_web_pages_for_search": 1,
"istable": 1,
"links": [],
"modified": "2023-10-09 17:09:50.481794",
"modified_by": "Administrator",
"module": "LMS",
"name": "Batch Student",
"owner": "Administrator",
"permissions": [],
"sort_field": "modified",
"sort_order": "DESC",
"states": []
}
@@ -1,8 +1,9 @@
# Copyright (c) 2021, FOSS United and contributors
# Copyright (c) 2022, Frappe and contributors
# For license information, please see license.txt
# import frappe
from frappe.model.document import Document
class Exhibitor(Document):
class BatchStudent(Document):
pass
@@ -0,0 +1,9 @@
# Copyright (c) 2022, Frappe and Contributors
# See license.txt
# import frappe
from frappe.tests.utils import FrappeTestCase
class TestBatchStudent(FrappeTestCase):
pass
@@ -1,8 +1,7 @@
// Copyright (c) 2021, Frappe and contributors
// For license information, please see license.txt
frappe.ui.form.on('TShirt Sizes', {
frappe.ui.form.on("Certification", {
// refresh: function(frm) {
// }
});
@@ -0,0 +1,74 @@
{
"actions": [],
"allow_rename": 1,
"autoname": "hash",
"creation": "2021-12-07 12:20:37.143096",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"certification_name",
"organization",
"description",
"column_break_4",
"expire",
"issue_date",
"expiration_date"
],
"fields": [
{
"fieldname": "certification_name",
"fieldtype": "Data",
"in_list_view": 1,
"label": "Certification Name",
"reqd": 1
},
{
"fieldname": "organization",
"fieldtype": "Data",
"in_list_view": 1,
"label": "Organization",
"reqd": 1
},
{
"fieldname": "issue_date",
"fieldtype": "Date",
"in_list_view": 1,
"label": "Issue Date",
"reqd": 1
},
{
"fieldname": "description",
"fieldtype": "Small Text",
"label": "Description"
},
{
"depends_on": "eval: !doc.expire",
"fieldname": "expiration_date",
"fieldtype": "Data",
"label": "Expiration Date"
},
{
"default": "0",
"fieldname": "expire",
"fieldtype": "Check",
"label": "This certificate does no expire"
},
{
"fieldname": "column_break_4",
"fieldtype": "Column Break"
}
],
"index_web_pages_for_search": 1,
"istable": 1,
"links": [],
"modified": "2021-12-21 10:05:43.377876",
"modified_by": "Administrator",
"module": "LMS",
"name": "Certification",
"naming_rule": "Random",
"owner": "Administrator",
"permissions": [],
"sort_field": "modified",
"sort_order": "DESC"
}
@@ -1,10 +1,9 @@
# -*- coding: utf-8 -*-
# Copyright (c) 2021, Frappe and contributors
# For license information, please see license.txt
from __future__ import unicode_literals
# import frappe
from frappe.model.document import Document
class TShirtSizes(Document):
class Certification(Document):
pass
@@ -0,0 +1,9 @@
# Copyright (c) 2021, Frappe and Contributors
# See license.txt
# import frappe
import unittest
class TestCertification(unittest.TestCase):
pass
@@ -1,5 +1,6 @@
{
"actions": [],
"autoname": "hash",
"creation": "2021-07-27 16:25:02.903245",
"doctype": "DocType",
"editable_grid": 1,
@@ -20,13 +21,15 @@
"index_web_pages_for_search": 1,
"istable": 1,
"links": [],
"modified": "2021-09-30 10:35:30.014950",
"modified": "2022-03-15 09:39:41.937565",
"modified_by": "Administrator",
"module": "LMS",
"name": "Chapter Reference",
"naming_rule": "Random",
"owner": "Administrator",
"permissions": [],
"sort_field": "modified",
"sort_order": "DESC",
"states": [],
"track_changes": 1
}
@@ -4,5 +4,6 @@
# import frappe
from frappe.model.document import Document
class ChapterReference(Document):
pass
@@ -1,8 +1,7 @@
// Copyright (c) 2021, FOSS United and contributors
// For license information, please see license.txt
frappe.ui.form.on('Talk', {
frappe.ui.form.on("Cohort", {
// refresh: function(frm) {
// }
});
+133
View File
@@ -0,0 +1,133 @@
{
"actions": [],
"allow_rename": 1,
"autoname": "format:{course}/{slug}",
"creation": "2021-11-19 11:45:31.016097",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"course",
"title",
"slug",
"section_break_2",
"instructor",
"status",
"column_break_4",
"begin_date",
"end_date",
"duration",
"section_break_8",
"description",
"pages"
],
"fields": [
{
"fieldname": "description",
"fieldtype": "Markdown Editor",
"label": "Description"
},
{
"fieldname": "instructor",
"fieldtype": "Link",
"label": "Instructor",
"options": "User",
"reqd": 1
},
{
"fieldname": "status",
"fieldtype": "Select",
"label": "Status",
"options": "Upcoming\nLive\nCompleted\nCancelled",
"reqd": 1
},
{
"fieldname": "begin_date",
"fieldtype": "Date",
"label": "Begin Date"
},
{
"fieldname": "end_date",
"fieldtype": "Date",
"label": "End Date"
},
{
"fieldname": "duration",
"fieldtype": "Data",
"label": "Duration"
},
{
"fieldname": "slug",
"fieldtype": "Data",
"in_list_view": 1,
"label": "Slug",
"reqd": 1,
"unique": 1
},
{
"fieldname": "column_break_4",
"fieldtype": "Column Break"
},
{
"fieldname": "section_break_8",
"fieldtype": "Section Break"
},
{
"fieldname": "section_break_2",
"fieldtype": "Section Break"
},
{
"fieldname": "title",
"fieldtype": "Data",
"in_list_view": 1,
"label": "Title",
"reqd": 1
},
{
"fieldname": "course",
"fieldtype": "Link",
"in_list_view": 1,
"label": "Course",
"options": "LMS Course",
"reqd": 1
},
{
"fieldname": "pages",
"fieldtype": "Table",
"label": "Pages",
"options": "Cohort Web Page"
}
],
"index_web_pages_for_search": 1,
"links": [
{
"group": "Links",
"link_doctype": "Cohort Subgroup",
"link_fieldname": "cohort"
}
],
"modified": "2022-10-13 15:46:32.322926",
"modified_by": "Administrator",
"module": "LMS",
"name": "Cohort",
"naming_rule": "Expression",
"owner": "Administrator",
"permissions": [
{
"create": 1,
"delete": 1,
"email": 1,
"export": 1,
"print": 1,
"read": 1,
"report": 1,
"role": "System Manager",
"share": 1,
"write": 1
}
],
"sort_field": "modified",
"sort_order": "DESC",
"states": [],
"track_changes": 1
}
+79
View File
@@ -0,0 +1,79 @@
# Copyright (c) 2021, FOSS United and contributors
# For license information, please see license.txt
import frappe
from frappe.model.document import Document
class Cohort(Document):
def get_url(self):
return f"{frappe.utils.get_url()}/courses/{self.course}/cohorts/{self.slug}"
def get_subgroups(self, include_counts=False, sort_by=None):
names = frappe.get_all("Cohort Subgroup", filters={"cohort": self.name}, pluck="name")
subgroups = [frappe.get_cached_doc("Cohort Subgroup", name) for name in names]
subgroups = sorted(subgroups, key=lambda sg: sg.title)
if include_counts:
mentors = self._get_subgroup_counts("Cohort Mentor")
students = self._get_subgroup_counts("LMS Enrollment")
join_requests = self._get_subgroup_counts("Cohort Join Request", status="Pending")
for s in subgroups:
s.num_mentors = mentors.get(s.name, 0)
s.num_students = students.get(s.name, 0)
s.num_join_requests = join_requests.get(s.name, 0)
if sort_by:
subgroups.sort(key=lambda sg: getattr(sg, sort_by), reverse=True)
return subgroups
def _get_subgroup_counts(self, doctype, **kw):
rows = frappe.get_all(
doctype,
filters={"cohort": self.name, **kw},
fields=["subgroup", "count(*) as count"],
group_by="subgroup",
)
return {row["subgroup"]: row["count"] for row in rows}
def _get_count(self, doctype, **kw):
filters = {"cohort": self.name, **kw}
return frappe.db.count(doctype, filters=filters)
def get_page_template(self, slug, scope=None):
p = self.get_page(slug, scope=scope)
return p and p.get_template_html()
def get_page(self, slug, scope=None):
for p in self.pages:
if p.slug == slug and scope in [p.scope, None]:
return p
def get_pages(self, scope=None):
return [p for p in self.pages if scope in [p.scope, None]]
def get_stats(self):
return {
"subgroups": self._get_count("Cohort Subgroup"),
"mentors": self._get_count("Cohort Mentor"),
"students": self._get_count("LMS Enrollment"),
"join_requests": self._get_count("Cohort Join Request", status="Pending"),
}
def get_subgroup(self, slug):
q = dict(cohort=self.name, slug=slug)
name = frappe.db.get_value("Cohort Subgroup", q, "name")
return name and frappe.get_doc("Cohort Subgroup", name)
def get_mentor(self, email):
q = dict(cohort=self.name, email=email)
name = frappe.db.get_value("Cohort Mentor", q, "name")
return name and frappe.get_doc("Cohort Mentor", name)
def is_mentor(self, email):
q = {"doctype": "Cohort Mentor", "cohort": self.name, "email": email}
return frappe.db.exists(q)
def is_admin(self, email):
q = {"doctype": "Cohort Staff", "cohort": self.name, "email": email, "role": "Admin"}
return frappe.db.exists(q)
@@ -4,5 +4,6 @@
# import frappe
import unittest
class TestTalk(unittest.TestCase):
class TestCohort(unittest.TestCase):
pass
@@ -0,0 +1,7 @@
// Copyright (c) 2021, FOSS United and contributors
// For license information, please see license.txt
frappe.ui.form.on("Cohort Join Request", {
// refresh: function(frm) {
// }
});
@@ -1,51 +1,60 @@
{
"actions": [],
"creation": "2021-02-12 18:36:08.324156",
"allow_rename": 1,
"creation": "2021-11-19 16:27:41.716509",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"project",
"intro",
"status",
"project_owner"
"cohort",
"email",
"column_break_3",
"subgroup",
"status"
],
"fields": [
{
"fieldname": "project",
"fieldname": "cohort",
"fieldtype": "Link",
"in_list_view": 1,
"label": "Project",
"options": "Community Project",
"label": "Cohort",
"options": "Cohort",
"reqd": 1
},
{
"fieldname": "intro",
"fieldtype": "Small Text",
"fieldname": "subgroup",
"fieldtype": "Link",
"in_list_view": 1,
"label": "Intro",
"label": "Subgroup",
"options": "Cohort Subgroup",
"reqd": 1
},
{
"fieldname": "email",
"fieldtype": "Link",
"in_list_view": 1,
"label": "E-Mail",
"options": "User",
"reqd": 1
},
{
"default": "Pending",
"fieldname": "status",
"fieldtype": "Select",
"in_list_view": 1,
"label": "Status",
"options": "Pending\nAccepted\nRejected"
},
{
"fieldname": "project_owner",
"fieldtype": "Data",
"label": "Project Owner",
"options": "Email"
"fieldname": "column_break_3",
"fieldtype": "Column Break"
}
],
"index_web_pages_for_search": 1,
"links": [],
"modified": "2021-03-04 19:44:09.832170",
"modified": "2023-09-29 17:08:18.950560",
"modified_by": "Administrator",
"module": "Hackathon",
"name": "Community Project Member",
"module": "LMS",
"name": "Cohort Join Request",
"owner": "Administrator",
"permissions": [
{
@@ -61,17 +70,19 @@
"write": 1
},
{
"create": 1,
"email": 1,
"export": 1,
"print": 1,
"read": 1,
"report": 1,
"role": "Participant",
"share": 1
"role": "LMS Student",
"share": 1,
"write": 1
}
],
"quick_entry": 1,
"sort_field": "modified",
"sort_order": "DESC",
"states": [],
"track_changes": 1
}
@@ -0,0 +1,52 @@
# Copyright (c) 2021, FOSS United and contributors
# For license information, please see license.txt
import frappe
from frappe.model.document import Document
class CohortJoinRequest(Document):
def on_update(self):
if self.status == "Accepted":
self.ensure_student()
def ensure_student(self):
# case 1 - user is already a member
q = {
"doctype": "LMS Enrollment",
"cohort": self.cohort,
"subgroup": self.subgroup,
"member": self.email,
"member_type": "Student",
}
if frappe.db.exists(q):
return
# case 2 - user has signed up for this course, possibly not this cohort
cohort = frappe.get_doc("Cohort", self.cohort)
q = {
"doctype": "LMS Enrollment",
"course": cohort.course,
"member": self.email,
"member_type": "Student",
}
name = frappe.db.exists(q)
if name:
doc = frappe.get_doc("LMS Enrollment", name)
doc.cohort = self.cohort
doc.subgroup = self.subgroup
doc.save(ignore_permissions=True)
else:
# case 3 - user has not signed up for this course yet
data = {
"doctype": "LMS Enrollment",
"course": cohort.course,
"cohort": self.cohort,
"subgroup": self.subgroup,
"member": self.email,
"member_type": "Student",
"role": "Member",
}
doc = frappe.get_doc(data)
doc.insert(ignore_permissions=True)
@@ -0,0 +1,9 @@
# Copyright (c) 2021, FOSS United and Contributors
# See license.txt
# import frappe
import unittest
class TestCohortJoinRequest(unittest.TestCase):
pass
@@ -1,8 +1,7 @@
// Copyright (c) 2021, FOSS United and contributors
// For license information, please see license.txt
frappe.ui.form.on('Host', {
frappe.ui.form.on("Cohort Mentor", {
// refresh: function(frm) {
// }
});
@@ -1,57 +1,57 @@
{
"actions": [],
"creation": "2021-02-15 11:04:02.748879",
"allow_rename": 1,
"creation": "2021-11-19 15:31:47.129156",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"first_name",
"last_name",
"cohort",
"email",
"student",
"organization_college"
"subgroup",
"course"
],
"fields": [
{
"fieldname": "first_name",
"fieldtype": "Data",
"fieldname": "cohort",
"fieldtype": "Link",
"in_list_view": 1,
"label": "First Name",
"reqd": 1
},
{
"fieldname": "last_name",
"fieldtype": "Data",
"in_list_view": 1,
"label": "Last Name",
"in_standard_filter": 1,
"label": "Cohort",
"options": "Cohort",
"reqd": 1
},
{
"fieldname": "email",
"fieldtype": "Data",
"fieldtype": "Link",
"in_list_view": 1,
"label": "Email",
"options": "Email",
"label": "E-mail",
"options": "User",
"reqd": 1
},
{
"default": "0",
"fieldname": "student",
"fieldtype": "Check",
"label": "Student"
"fieldname": "subgroup",
"fieldtype": "Link",
"in_list_view": 1,
"label": "Primary Subgroup",
"options": "Cohort Subgroup",
"reqd": 1
},
{
"fieldname": "organization_college",
"fieldtype": "Data",
"label": "Organization/College"
"fetch_from": "cohort.course",
"fieldname": "course",
"fieldtype": "Link",
"label": "Course",
"options": "LMS Course",
"read_only": 1
}
],
"index_web_pages_for_search": 1,
"links": [],
"modified": "2021-02-15 11:04:02.748879",
"modified": "2021-11-29 16:32:33.235281",
"modified_by": "Administrator",
"module": "Community",
"name": "Community Participant",
"module": "LMS",
"name": "Cohort Mentor",
"owner": "Administrator",
"permissions": [
{
@@ -67,7 +67,6 @@
"write": 1
}
],
"quick_entry": 1,
"sort_field": "modified",
"sort_order": "DESC",
"track_changes": 1
@@ -0,0 +1,13 @@
# Copyright (c) 2021, FOSS United and contributors
# For license information, please see license.txt
import frappe
from frappe.model.document import Document
class CohortMentor(Document):
def get_subgroup(self):
return frappe.get_doc("Cohort Subgroup", self.subgroup)
def get_user(self):
return frappe.get_doc("User", self.email)
@@ -4,5 +4,6 @@
# import frappe
import unittest
class TestEventDetails(unittest.TestCase):
class TestCohortMentor(unittest.TestCase):
pass
@@ -1,8 +1,7 @@
// Copyright (c) 2021, FOSS United and contributors
// For license information, please see license.txt
frappe.ui.form.on('Exercise', {
frappe.ui.form.on("Cohort Staff", {
// refresh: function(frm) {
// }
});
@@ -1,54 +1,61 @@
{
"actions": [],
"creation": "2021-08-16 15:47:19.494055",
"allow_rename": 1,
"creation": "2021-11-19 15:35:00.551949",
"doctype": "DocType",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
"student",
"issue_date",
"column_break_3",
"cohort",
"course",
"expiry_date"
"column_break_3",
"email",
"role"
],
"fields": [
{
"fieldname": "student",
"fieldname": "cohort",
"fieldtype": "Link",
"in_list_view": 1,
"in_standard_filter": 1,
"label": "Student",
"options": "User"
"label": "Cohort",
"options": "Cohort",
"reqd": 1
},
{
"fieldname": "issue_date",
"fieldtype": "Date",
"label": "Issue Date"
"fieldname": "email",
"fieldtype": "Link",
"in_list_view": 1,
"label": "User",
"options": "User",
"reqd": 1
},
{
"fieldname": "role",
"fieldtype": "Select",
"in_list_view": 1,
"label": "Role",
"options": "Admin\nManager\nStaff",
"reqd": 1
},
{
"fetch_from": "cohort.course",
"fieldname": "course",
"fieldtype": "Link",
"label": "Course",
"options": "LMS Course",
"read_only": 1
},
{
"fieldname": "column_break_3",
"fieldtype": "Column Break"
},
{
"fieldname": "course",
"fieldtype": "Link",
"in_list_view": 1,
"in_standard_filter": 1,
"label": "Course",
"options": "LMS Course"
},
{
"fieldname": "expiry_date",
"fieldtype": "Date",
"label": "Expiry Date"
}
],
"index_web_pages_for_search": 1,
"links": [],
"modified": "2021-08-16 15:47:19.494055",
"modified": "2021-12-16 15:16:04.042372",
"modified_by": "Administrator",
"module": "LMS",
"name": "LMS Certification",
"name": "Cohort Staff",
"owner": "Administrator",
"permissions": [
{
@@ -4,5 +4,6 @@
# import frappe
from frappe.model.document import Document
class EventDetails(Document):
class CohortStaff(Document):
pass
@@ -4,5 +4,6 @@
# import frappe
import unittest
class TestAttendee(unittest.TestCase):
class TestCohortStaff(unittest.TestCase):
pass

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