From a16748b00def38f559b5721823a763ed66167a3a Mon Sep 17 00:00:00 2001 From: Nate Armstrong Date: Tue, 18 Aug 2020 08:52:45 -0600 Subject: [PATCH] Student 6.8.2 Hotfixes (#938) Co-authored-by: Blackchai --- .../flutter_parent/lib/models/assignment.dart | 3 -- .../lib/models/assignment.g.dart | 44 +++++-------------- .../lib/screens/login_landing_screen.dart | 2 +- .../login/login_landing_screen_test.dart | 2 + .../fragment/InternalWebviewFragment.kt | 1 - .../student/router/RouteMatcher.kt | 1 + .../teacher/router/RouteMatcher.kt | 1 + .../canvasapi2/unit/AssignmentUnitTest.kt | 3 -- .../canvasapi2/unit/ConversationUnitTest.kt | 11 ----- .../canvasapi2/unit/TodoUnitTest.kt | 5 --- .../BaseLoginLandingPageActivity.kt | 1 + .../pandautils/utils/AssignmentUtils2.kt | 1 - 12 files changed, 18 insertions(+), 57 deletions(-) diff --git a/apps/flutter_parent/lib/models/assignment.dart b/apps/flutter_parent/lib/models/assignment.dart index 756f23ee9b..ce3d4d27dd 100644 --- a/apps/flutter_parent/lib/models/assignment.dart +++ b/apps/flutter_parent/lib/models/assignment.dart @@ -106,8 +106,6 @@ abstract class Assignment implements Built { bool get published; - bool get muted; - @nullable @BuiltValueField(wireName: 'group_category_id') String get groupCategoryId; @@ -139,7 +137,6 @@ abstract class Assignment implements Built { ..lockedForUser = false ..freeFormCriterionComments = false ..published = false - ..muted = false ..userSubmitted = false ..onlyVisibleToOverrides = false ..anonymousPeerReviews = false diff --git a/apps/flutter_parent/lib/models/assignment.g.dart b/apps/flutter_parent/lib/models/assignment.g.dart index 35e5ded5bb..e04fe657b5 100644 --- a/apps/flutter_parent/lib/models/assignment.g.dart +++ b/apps/flutter_parent/lib/models/assignment.g.dart @@ -146,8 +146,6 @@ class _$AssignmentSerializer implements StructuredSerializer { 'published', serializers.serialize(object.published, specifiedType: const FullType(bool)), - 'muted', - serializers.serialize(object.muted, specifiedType: const FullType(bool)), 'user_submitted', serializers.serialize(object.userSubmitted, specifiedType: const FullType(bool)), @@ -359,10 +357,6 @@ class _$AssignmentSerializer implements StructuredSerializer { result.published = serializers.deserialize(value, specifiedType: const FullType(bool)) as bool; break; - case 'muted': - result.muted = serializers.deserialize(value, - specifiedType: const FullType(bool)) as bool; - break; case 'group_category_id': result.groupCategoryId = serializers.deserialize(value, specifiedType: const FullType(String)) as String; @@ -521,8 +515,6 @@ class _$Assignment extends Assignment { @override final bool published; @override - final bool muted; - @override final String groupCategoryId; @override final bool userSubmitted; @@ -564,7 +556,6 @@ class _$Assignment extends Assignment { this.lockExplanation, this.freeFormCriterionComments, this.published, - this.muted, this.groupCategoryId, this.userSubmitted, this.onlyVisibleToOverrides, @@ -605,9 +596,6 @@ class _$Assignment extends Assignment { if (published == null) { throw new BuiltValueNullFieldError('Assignment', 'published'); } - if (muted == null) { - throw new BuiltValueNullFieldError('Assignment', 'muted'); - } if (userSubmitted == null) { throw new BuiltValueNullFieldError('Assignment', 'userSubmitted'); } @@ -661,7 +649,6 @@ class _$Assignment extends Assignment { lockExplanation == other.lockExplanation && freeFormCriterionComments == other.freeFormCriterionComments && published == other.published && - muted == other.muted && groupCategoryId == other.groupCategoryId && userSubmitted == other.userSubmitted && onlyVisibleToOverrides == other.onlyVisibleToOverrides && @@ -692,18 +679,18 @@ class _$Assignment extends Assignment { $jc( $jc( $jc( - $jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc(0, id.hashCode), name.hashCode), description.hashCode), dueAt.hashCode), pointsPossible.hashCode), courseId.hashCode), gradingType.hashCode), htmlUrl.hashCode), url.hashCode), quizId.hashCode), useRubricForGrading.hashCode), - submissionWrapper.hashCode), - assignmentGroupId.hashCode), - position.hashCode), - lockInfo.hashCode), - lockedForUser.hashCode), - lockAt.hashCode), - unlockAt.hashCode), - lockExplanation.hashCode), - freeFormCriterionComments.hashCode), - published.hashCode), - muted.hashCode), + $jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc(0, id.hashCode), name.hashCode), description.hashCode), dueAt.hashCode), pointsPossible.hashCode), courseId.hashCode), gradingType.hashCode), htmlUrl.hashCode), url.hashCode), quizId.hashCode), + useRubricForGrading.hashCode), + submissionWrapper.hashCode), + assignmentGroupId.hashCode), + position.hashCode), + lockInfo.hashCode), + lockedForUser.hashCode), + lockAt.hashCode), + unlockAt.hashCode), + lockExplanation.hashCode), + freeFormCriterionComments.hashCode), + published.hashCode), groupCategoryId.hashCode), userSubmitted.hashCode), onlyVisibleToOverrides.hashCode), @@ -738,7 +725,6 @@ class _$Assignment extends Assignment { ..add('lockExplanation', lockExplanation) ..add('freeFormCriterionComments', freeFormCriterionComments) ..add('published', published) - ..add('muted', muted) ..add('groupCategoryId', groupCategoryId) ..add('userSubmitted', userSubmitted) ..add('onlyVisibleToOverrides', onlyVisibleToOverrides) @@ -846,10 +832,6 @@ class AssignmentBuilder implements Builder { bool get published => _$this._published; set published(bool published) => _$this._published = published; - bool _muted; - bool get muted => _$this._muted; - set muted(bool muted) => _$this._muted = muted; - String _groupCategoryId; String get groupCategoryId => _$this._groupCategoryId; set groupCategoryId(String groupCategoryId) => @@ -918,7 +900,6 @@ class AssignmentBuilder implements Builder { _lockExplanation = _$v.lockExplanation; _freeFormCriterionComments = _$v.freeFormCriterionComments; _published = _$v.published; - _muted = _$v.muted; _groupCategoryId = _$v.groupCategoryId; _userSubmitted = _$v.userSubmitted; _onlyVisibleToOverrides = _$v.onlyVisibleToOverrides; @@ -972,7 +953,6 @@ class AssignmentBuilder implements Builder { lockExplanation: lockExplanation, freeFormCriterionComments: freeFormCriterionComments, published: published, - muted: muted, groupCategoryId: groupCategoryId, userSubmitted: userSubmitted, onlyVisibleToOverrides: onlyVisibleToOverrides, diff --git a/apps/flutter_parent/lib/screens/login_landing_screen.dart b/apps/flutter_parent/lib/screens/login_landing_screen.dart index fdcae4d7f3..f2e19c5f61 100644 --- a/apps/flutter_parent/lib/screens/login_landing_screen.dart +++ b/apps/flutter_parent/lib/screens/login_landing_screen.dart @@ -85,7 +85,7 @@ class LoginLandingScreen extends StatelessWidget { child: FullScreenScrollContainer( horizontalPadding: 0, children: [ - _helpRequestButton(context), + // _helpRequestButton(context), // add back after we make mobile login better Expanded(child: _body(context)), SizedBox(height: 56.0), // Sizedbox to offset helpRequestButton ], diff --git a/apps/flutter_parent/test/screens/login/login_landing_screen_test.dart b/apps/flutter_parent/test/screens/login/login_landing_screen_test.dart index a56e6ee538..ef8f27dc66 100644 --- a/apps/flutter_parent/test/screens/login/login_landing_screen_test.dart +++ b/apps/flutter_parent/test/screens/login/login_landing_screen_test.dart @@ -238,6 +238,7 @@ void main() { ApiPrefs.clean(); }); + /* Hiding the help button until we make mobile login better testWidgetsWithAccessibilityChecks('Tapping help button shows help dialog', (tester) async { await tester.pumpWidget(TestApp(LoginLandingScreen())); await tester.pumpAndSettle(); @@ -248,6 +249,7 @@ void main() { expect(find.byType(ErrorReportDialog), findsOneWidget); verify(analytics.logEvent(any)).called(1); }); + */ testWidgetsWithAccessibilityChecks('Uses two-finger double-tap to cycle login flows', (tester) async { await tester.pumpWidget(TestApp(LoginLandingScreen())); diff --git a/apps/student/src/main/java/com/instructure/student/fragment/InternalWebviewFragment.kt b/apps/student/src/main/java/com/instructure/student/fragment/InternalWebviewFragment.kt index 11f296db55..8642cd41d5 100644 --- a/apps/student/src/main/java/com/instructure/student/fragment/InternalWebviewFragment.kt +++ b/apps/student/src/main/java/com/instructure/student/fragment/InternalWebviewFragment.kt @@ -99,7 +99,6 @@ open class InternalWebviewFragment : ParentFragment() { originalUserAgentString = canvasWebView.settings.userAgentString canvasWebView.settings.userAgentString = ApiPrefs.userAgent canvasWebView.setInitialScale(100) - canvasWebView.settings.setSupportMultipleWindows(true) // Required to allow iFrames with links that have a target of '_blank' - see CanvasWebChromeClient#onCreateWindow() canvasWebView.canvasWebChromeClientCallback = CanvasWebView.CanvasWebChromeClientCallback { _, newProgress -> if (newProgress == 100) { diff --git a/apps/student/src/main/java/com/instructure/student/router/RouteMatcher.kt b/apps/student/src/main/java/com/instructure/student/router/RouteMatcher.kt index c58238c230..e661ba88e0 100644 --- a/apps/student/src/main/java/com/instructure/student/router/RouteMatcher.kt +++ b/apps/student/src/main/java/com/instructure/student/router/RouteMatcher.kt @@ -115,6 +115,7 @@ object RouteMatcher : BaseRouteMatcher() { routes.add(Route(courseOrGroup("/:${RouterParams.COURSE_ID}/files"), FileListFragment::class.java)) routes.add(Route(courseOrGroup("/:${RouterParams.COURSE_ID}/files/folder/:${RouterParams.FOLDER_NAME}"), RouteContext.FILE)) routes.add(Route(courseOrGroup("/:${RouterParams.COURSE_ID}/files/:${RouterParams.FILE_ID}/download"), RouteContext.FILE)) // trigger webview's download listener + routes.add(Route(courseOrGroup("/:${RouterParams.COURSE_ID}/files/:${RouterParams.FILE_ID}/preview"), RouteContext.FILE)) routes.add(Route(courseOrGroup("/:${RouterParams.COURSE_ID}/files/:${RouterParams.FILE_ID}"), RouteContext.FILE)) routes.add(Route(courseOrGroup("/:${RouterParams.COURSE_ID}/files/folder(\\/.*)*/:${RouterParams.FILE_ID}"), RouteContext.FILE)) routes.add(Route("/files/folder(\\/.*)*/:${RouterParams.FILE_ID}", RouteContext.FILE)) diff --git a/apps/teacher/src/main/java/com/instructure/teacher/router/RouteMatcher.kt b/apps/teacher/src/main/java/com/instructure/teacher/router/RouteMatcher.kt index c1a47da688..b1359866cc 100644 --- a/apps/teacher/src/main/java/com/instructure/teacher/router/RouteMatcher.kt +++ b/apps/teacher/src/main/java/com/instructure/teacher/router/RouteMatcher.kt @@ -88,6 +88,7 @@ object RouteMatcher : BaseRouteMatcher() { routes.add(Route(courseOrGroup("/:course_id/files"), FileListFragment::class.java)) routes.add(Route(courseOrGroup("/:course_id/files/:file_id/download"), RouteContext.FILE)) + routes.add(Route(courseOrGroup("/:course_id/files/:file_id/preview"), RouteContext.FILE)) routes.add(Route(courseOrGroup("/:course_id/files/:file_id"), RouteContext.FILE)) // Tries to get the folder or preview of file. File can be multiple folders deep (files/folder/folder1/folder2/folder3)... routes.add(Route(courseOrGroup("/:course_id/files/folder(\\/.*)*"), FileListFragment::class.java)) diff --git a/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/AssignmentUnitTest.kt b/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/AssignmentUnitTest.kt index 5f86fcffa0..e3c4ad5b2e 100644 --- a/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/AssignmentUnitTest.kt +++ b/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/AssignmentUnitTest.kt @@ -139,7 +139,6 @@ class AssignmentUnitTest : Assert() { "online_text_entry", "media_recording" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/2241839", "allowed_extensions": [ "doc", @@ -192,7 +191,6 @@ class AssignmentUnitTest : Assert() { "media_recording", "online_upload" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/3119886", "use_rubric_for_grading": true, "free_form_criterion_comments": false, @@ -406,7 +404,6 @@ class AssignmentUnitTest : Assert() { "online_url" ], "description": null, - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/836357/assignments/3546452", "locked_for_user": true, "lock_explanation": "unlocked" diff --git a/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/ConversationUnitTest.kt b/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/ConversationUnitTest.kt index 3b75dcd78a..b11fa3e9b0 100644 --- a/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/ConversationUnitTest.kt +++ b/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/ConversationUnitTest.kt @@ -474,7 +474,6 @@ class ConversationUnitTest : Assert() { "submission_types": [ "online_quiz" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/836357/assignments/3568225", "needs_grading_count": 0, "quiz_id": 1298486, @@ -538,7 +537,6 @@ class ConversationUnitTest : Assert() { "online_url", "media_recording" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/24219/assignments/405404", "needs_grading_count": 2, "use_rubric_for_grading": false, @@ -839,7 +837,6 @@ class ConversationUnitTest : Assert() { "submission_types": [ "online_text_entry" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/24219/assignments/3562637", "needs_grading_count": 0, "locked_for_user": false @@ -898,7 +895,6 @@ class ConversationUnitTest : Assert() { "submission_types": [ "online_text_entry" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/24219/assignments/2978687", "needs_grading_count": 2, "locked_for_user": false @@ -999,7 +995,6 @@ class ConversationUnitTest : Assert() { "submission_types": [ "online_text_entry" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/3507913", "needs_grading_count": 1, "locked_for_user": false @@ -1059,7 +1054,6 @@ class ConversationUnitTest : Assert() { "online_text_entry", "online_url" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/24219/assignments/3563900", "needs_grading_count": 1, "locked_for_user": false @@ -1118,7 +1112,6 @@ class ConversationUnitTest : Assert() { "submission_types": [ "none" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/836357/assignments/3488393", "needs_grading_count": 0, "locked_for_user": false @@ -1180,7 +1173,6 @@ class ConversationUnitTest : Assert() { "media_recording", "online_upload" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/24219/assignments/3562410", "needs_grading_count": 1, "locked_for_user": false @@ -1253,7 +1245,6 @@ class ConversationUnitTest : Assert() { "submission_types": [ "online_text_entry" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/3510750", "needs_grading_count": 0, "locked_for_user": false @@ -1319,7 +1310,6 @@ class ConversationUnitTest : Assert() { "submission_types": [ "online_quiz" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/2241845", "needs_grading_count": 0, "quiz_id": 757313, @@ -1380,7 +1370,6 @@ class ConversationUnitTest : Assert() { "submission_types": [ "none" ], - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/3484476", "needs_grading_count": 0, "locked_for_user": false diff --git a/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/TodoUnitTest.kt b/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/TodoUnitTest.kt index f0d5b3f01c..ec6624f5a1 100644 --- a/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/TodoUnitTest.kt +++ b/libs/canvas-api-2/src/test/java/com/instructure/canvasapi2/unit/TodoUnitTest.kt @@ -77,7 +77,6 @@ class TodoUnitTest : Assert() { "online_upload" ], "has_submitted_submissions": true, - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/5848306", "has_overrides": false, "published": true, @@ -119,7 +118,6 @@ class TodoUnitTest : Assert() { "media_recording" ], "has_submitted_submissions": true, - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/5375271", "has_overrides": false, "use_rubric_for_grading": true, @@ -258,7 +256,6 @@ class TodoUnitTest : Assert() { "media_recording" ], "has_submitted_submissions": false, - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/6624879", "has_overrides": true, "published": true, @@ -297,7 +294,6 @@ class TodoUnitTest : Assert() { "online_quiz" ], "has_submitted_submissions": true, - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/4691021", "has_overrides": false, "quiz_id": 1642787, @@ -339,7 +335,6 @@ class TodoUnitTest : Assert() { "online_quiz" ], "has_submitted_submissions": true, - "muted": false, "html_url": "https://mobiledev.instructure.com/courses/833052/assignments/6881563", "has_overrides": false, "quiz_id": 2421689, diff --git a/libs/login-api-2/src/main/java/com/instructure/loginapi/login/activities/BaseLoginLandingPageActivity.kt b/libs/login-api-2/src/main/java/com/instructure/loginapi/login/activities/BaseLoginLandingPageActivity.kt index b998ebc34e..70874e741d 100644 --- a/libs/login-api-2/src/main/java/com/instructure/loginapi/login/activities/BaseLoginLandingPageActivity.kt +++ b/libs/login-api-2/src/main/java/com/instructure/loginapi/login/activities/BaseLoginLandingPageActivity.kt @@ -125,6 +125,7 @@ abstract class BaseLoginLandingPageActivity : AppCompatActivity(), ErrorReportDi startActivity(i) } + helpButton.setHidden(true) // hiding the help button until we make mobile login better helpButton.onClickPopupMenu(getString(R.string.requestLoginHelp) to { requestLoginHelp() }) val remoteConfigParam = when { diff --git a/libs/pandautils/src/main/java/com/instructure/pandautils/utils/AssignmentUtils2.kt b/libs/pandautils/src/main/java/com/instructure/pandautils/utils/AssignmentUtils2.kt index e95caff02c..1d62448623 100644 --- a/libs/pandautils/src/main/java/com/instructure/pandautils/utils/AssignmentUtils2.kt +++ b/libs/pandautils/src/main/java/com/instructure/pandautils/utils/AssignmentUtils2.kt @@ -82,7 +82,6 @@ object AssignmentUtils2 { // Check to see if an assignment either // 1. Has not been graded // 2. Is "Pending Review" - // 3. Is not Posted - Muted is being deprecated, so we are only going to track postedAt. private fun hasNoGrade(assignment: Assignment, submission: Submission, isTeacher: Boolean): Boolean { return !submission.isGraded || Const.PENDING_REVIEW == submission.workflowState || (!isTeacher && assignment.submission?.postedAt == null) }