این پنجمین راهنما در مجموعه مروری بر افزونههای Classroom است.
در این راهنما، مثالی را از مرحله پیشبینی قبلی تغییر میدهید تا یک پیوست از نوع فعالیت تولید شود. اینها هر پیوستی هستند که نیاز به ارسال دانشآموز دارند، مانند پاسخ کتبی، مسابقه، یا سایر مصنوعات ایجاد شده توسط دانشآموز.
تمایز بین پیوستهای نوع محتوا و نوع فعالیت مهم است. پیوستهای نوع فعالیت به روشهای زیر با نوع محتوا متفاوت هستند:
- دکمه "Turn In" در سمت راست بالای iframe Student View ظاهر می شود.
- آنها یک شناسه منحصر به فرد برای کار دانش آموز ارائه می دهند.
- کارت پیوست آنها در رابط کاربری کلاس روم نشان داده میشود.
- آنها می توانند برای تکلیفی که به آن تعلق دارند نمره تعیین کنند.
برای بحث در مورد درجه بندی، راهنما بعدی را ببینید. در طول این راهنما موارد زیر را تکمیل می کنید:
- درخواستهای ایجاد پیوست قبلی را به API Classroom تغییر دهید تا یک پیوست از نوع فعالیت ایجاد کنید.
- اجرای ذخیره سازی مداوم برای ارسالی دانش آموزان.
- مسیر قبلی نمای دانشجویی را تغییر دهید تا ورودی دانشآموز را بپذیرید.
- مسیری برای ارائه iframe بررسی کار دانشجویی ارائه دهید.
پس از اتمام، میتوانید هنگام ورود به عنوان معلم، پیوستهایی از نوع فعالیت در تکالیف از طریق رابط کاربری Google Classroom ایجاد کنید. دانشآموزان کلاس نیز میتوانند فعالیت را در iframe تکمیل کرده و پاسخ ارسال کنند. معلم میتواند موارد ارسالی دانشآموز را در رابط کاربری درجهبندی Classroom مشاهده کند.
برای اهداف این مثال، از الگوی پیوست از مرحله پیشین استفاده مجدد کنید که تصویری از یک نقطه عطف معروف و شرحی با نام علامت مشخصه را نشان میدهد. این فعالیت شامل ترغیب دانش آموز برای ارائه نام نقطه عطف است.
درخواست ایجاد پیوست را اصلاح کنید
به بخشی از کد خود بروید که در آن یک پیوست از نوع محتوا را در مرحله پیشین ایجاد کرده اید. مورد کلیدی در اینجا نمونهای از یک شی AddOnAttachment است که قبلا teacherViewUri
، studentViewUri
و title
برای پیوست مشخص کردهایم.
در حالی که همه پیوستهای افزودنی به این سه فیلد نیاز دارند، وجود یا عدم وجود studentWorkReviewUri
تعیین میکند که پیوست از نوع فعالیت یا محتوا باشد. یک درخواست CREATE
با یک studentWorkReviewUri
پر شده تبدیل به یک پیوست از نوع فعالیت می شود، در حالی که یک درخواست CREATE
بدون studentWorkReviewUri
به یک پیوست از نوع محتوا تبدیل می شود.
تنها تغییری که باید در این درخواست انجام شود پر کردن فیلد studentWorkReviewUri
است. یک مسیر با نام مناسب را در اینجا اضافه کنید. شما آن را در مرحله بعد اجرا می کنید.
پایتون
در مثال ارائه شده ما، این در روش create_attachments
در فایل webapp/attachment_routes.py
است.
attachment = {
# Specifies the route for a teacher user.
"teacherViewUri": {
"uri":
flask.url_for(
"load_activity_attachment",
_scheme='https',
_external=True),
},
# Specifies the route for a student user.
"studentViewUri": {
"uri":
flask.url_for(
"load_activity_attachment",
_scheme='https',
_external=True)
},
# Specifies the route for a teacher user when the attachment is
# loaded in the Classroom grading view.
# The presence of this field marks this as an activity-type attachment.
"studentWorkReviewUri": {
"uri":
flask.url_for(
"view_submission", _scheme='https', _external=True)
},
# The title of the attachment.
"title": f"Attachment {attachment_count}",
}
ذخیره سازی دائمی برای پیوست های نوع محتوا اضافه کنید
پاسخ دانش آموز به فعالیت ما را ثبت کنید. میتوانید بعداً وقتی معلم ارسالی را در iframe بررسی کار دانشجویی مشاهده کرد، آن را جستجو کنید.
یک طرح پایگاه داده برای Submission
تنظیم کنید. مثال ارائه شده ما از دانش آموزان انتظار دارد که نام نقطه عطف نشان داده شده در یک تصویر را وارد کنند. بنابراین یک Submission
حاوی ویژگی های زیر است:
-
attachment_id
: یک شناسه منحصر به فرد برای پیوست. توسط Classroom تخصیص داده شد و در هنگام ایجاد پیوست در پاسخ بازگردانده شد. -
submission_id
: یک شناسه برای ارسال دانشجو. توسط Classroom اختصاص داده شد و در پاسخgetAddOnContext
در نمای دانشجو بازگردانده شد.
-
student_response
: پاسخ ارائه شده توسط دانشجو.
پایتون
اجرای SQLite و flask_sqlalchemy
را از مراحل قبل گسترش دهید.
به فایلی بروید که در آن جداول قبلی را تعریف کرده اید (اگر از مثال ارائه شده ما پیروی می کنید models.py
). موارد زیر را در پایین فایل اضافه کنید.
# Database model to represent a student submission.
class Submission(db.Model):
# The attachmentId is the unique identifier for the attachment.
submission_id = db.Column(db.String(120), primary_key=True)
# The unique identifier for the student's submission.
attachment_id = db.Column(db.String(120), primary_key=True)
# The student's response to the question prompt.
student_response = db.Column(db.String(120))
کلاس Submission
جدید را با مسیرهای مدیریت پیوست خود به فایل سرور وارد کنید.
مسیر Student View را تغییر دهید
سپس، مسیر قبلی Student View را تغییر دهید تا یک فرم کوچک نشان داده شود و ورودی دانشآموز را بپذیرید. میتوانید از بیشتر کدهای پیشفرض قبلی دوباره استفاده کنید.
کد سروری را که مسیر را برای نمای دانشجویی شما فراهم می کند، پیدا کنید. این مسیری است که در قسمت studentViewUri
هنگام ایجاد یک پیوست مشخص شده است. اولین تغییری که باید انجام دهید استخراج submissionId
از پاسخ getAddOnContext
است.
پایتون
در مثال ارائه شده ما، این در روش load_activity_attachment
در فایل webapp/attachment_routes.py
است.
# Issue a request to the courseWork.getAddOnContext endpoint
addon_context_response = classroom_service.courses().courseWork(
).getAddOnContext(
courseId=flask.session["courseId"],
itemId=flask.session["itemId"]).execute()
# One of studentContext or teacherContext will be populated.
user_context = "student" if addon_context_response.get(
"studentContext") else "teacher"
# If the user is a student...
if user_context == "student":
# Extract the submissionId from the studentContext object.
# This value is provided by Google Classroom.
flask.session["submissionId"] = addon_context_response.get(
"studentContext").get("submissionId")
همچنین ممکن است بخواهید درخواستی برای دریافت وضعیت ارسال دانشجو صادر کنید. پاسخ حاوی یک مقدار SubmissionState
است که وضعیتهایی را نشان میدهد مانند اینکه آیا دانشآموز پیوست را باز کرده است یا آن را تحویل داده است. اگر نمیخواهید ویرایشهای ارسالی ارائهشده را مجاز نکنید، یا اگر علاقهمند به ارائه معلم هستید، ممکن است مفید باشد. بینش پیشرفت دانش آموزان خود:
پایتون
در مثال ارائه شده ما، این ادامه روش load_activity_attachment
بالا است.
# Issue a request to get the status of the student submission.
submission_response = classroom_service.courses().courseWork(
).addOnAttachments().studentSubmissions().get(
courseId=flask.session["courseId"],
itemId=flask.session["itemId"],
attachmentId=flask.session["attachmentId"],
submissionId=flask.session["submissionId"]).execute()
در نهایت، اطلاعات پیوست را از پایگاه داده ما واکشی کنید و یک فرم ورودی ارائه دهید. فرم در مثال ارائه شده ما شامل یک فیلد ورودی رشته و یک دکمه ارسال است. تصویر نقطه عطف را نشان دهید و از دانش آموز بخواهید نام آن را وارد کند. پس از ارائه پاسخ، آن را در پایگاه داده ما ثبت کنید.
پایتون
در مثال ارائه شده ما، این ادامه روش load_activity_attachment
بالا است.
# Look up the attachment in the database.
attachment = Attachment.query.get(flask.session["attachmentId"])
message_str = f"I see that you're a {user_context}! "
message_str += (
f"I've loaded the attachment with ID {attachment.attachment_id}. "
if user_context == "teacher" else
"Please complete the activity below.")
form = activity_form_builder()
if form.validate_on_submit():
# Record the student's response in our database.
# Check if the student has already submitted a response.
# If so, update the response stored in the database.
student_submission = Submission.query.get(flask.session["submissionId"])
if student_submission is not None:
student_submission.student_response = form.student_response.data
else:
# Store the student's response by the submission ID.
new_submission = Submission(
submission_id=flask.session["submissionId"],
attachment_id=flask.session["attachmentId"],
student_response=form.student_response.data)
db.session.add(new_submission)
db.session.commit()
return flask.render_template(
"acknowledge-submission.html",
message="Your response has been recorded. You can close the " \
"iframe now.",
instructions="Please Turn In your assignment if you have " \
"completed all tasks."
)
# Show the activity.
return flask.render_template(
"show-activity-attachment.html",
message=message_str,
image_filename=attachment.image_filename,
image_caption=attachment.image_caption,
user_context=user_context,
form=form,
responses=response_strings)
برای تمایز بین کاربران، عملکرد ارسال را غیرفعال کنید و در عوض پاسخ صحیح را در نمای معلم نشان دهید.
یک مسیر برای iframe بررسی کار دانشجویی اضافه کنید
در نهایت، یک مسیر برای ارائه iframe Student Work Review اضافه کنید. نام این مسیر باید با نام ارائه شده برای studentWorkReviewUri
هنگام ایجاد پیوست مطابقت داشته باشد. این مسیر زمانی باز می شود که معلم مطالب ارسالی دانش آموز را در رابط کاربری کلاس درس مشاهده کند.
وقتی Classroom iframe Student Work Review را باز میکند، پارامتر query submissionId
را دریافت میکنید. از آن برای بازیابی کار دانش آموز از پایگاه داده محلی خود استفاده کنید:
پایتون
در مثال ارائه شده ما، این در فایل webapp/attachment_routes.py
است.
@app.route("/view-submission")
def view_submission():
"""
Render a student submission using the show-student-submission.html template.
"""
# Save the query parameters passed to the iframe in the session, just as we did
# in previous routes. Abbreviated here for readability.
add_iframe_query_parameters_to_session(flask.request.args)
# For the sake of brevity in this example, we'll skip the conditional logic
# to see if we need to authorize the user as we have done in previous steps.
# We can assume that the user that reaches this route is a teacher that has
# already authorized and created an attachment using the add-on.
# In production, we recommend fully validating the user's authorization at
# this stage as well.
# Look up the student's submission in our database.
student_submission = Submission.query.get(flask.session["submissionId"])
# Look up the attachment in the database.
attachment = Attachment.query.get(student_submission.attachment_id)
# Render the student's response alongside the correct answer.
return flask.render_template(
"show-student-submission.html",
message=f"Loaded submission {student_submission.submission_id} for "\
f"attachment {attachment.attachment_id}.",
student_response=student_submission.student_response,
correct_answer=attachment.image_caption)
افزونه را تست کنید
آزمایش مراحل افزودنی مربوط به مرحله پیشین را تکرار کنید. شما باید پیوستی داشته باشید که دانش آموز بتواند آن را باز کند.
مراحل زیر را برای آزمایش پیوست فعالیت انجام دهید:
- به عنوان یکی از کاربران آزمون دانش آموز خود در همان کلاس با کاربر آزمون معلم وارد Google Classroom شوید.
- به برگه Classwork بروید و تکلیف آزمایشی را گسترش دهید.
- برای باز کردن نمای دانشجو و ارسال پاسخ برای فعالیت، روی کارت پیوست افزودنی کلیک کنید.
- پس از اتمام فعالیت، iframe را ببندید. در صورت تمایل، روی دکمه Turn In کلیک کنید.
پس از تکمیل فعالیت، نباید تغییری در Classroom مشاهده کنید. اکنون iframe بررسی کار دانشجویی را آزمایش کنید:
- به عنوان کاربر آزمون معلم وارد Classroom شوید.
- ستون مربوط به تکلیف آزمون خود را در برگه نمرات پیدا کنید. روی نام تکلیف آزمون خود کلیک کنید.
- کارت کاربر دانشجوی آزمون را پیدا کنید. روی پیوست روی کارت کلیک کنید.
تأیید کنید که ارسال صحیح برای دانش آموز ظاهر می شود.
تبریک می گویم! برای ادامه مرحله بعدی آماده هستید: همگام سازی نمرات پیوست .