Archive for March, 2008

I’ve been thinking a lot about effective strategies for surfacing material of particular interest to the learning community, in an active community blog.

For small communities - and ours, at 500+ students, is likely on the cusp re this - a river of news format, with author tagging and tag cloud display, may well suffice without the need for other surfacing methods. For larger communities, it may become essential to provide a method to surface material of particular interest to the community at large.

As I’ve noted earlier, I’m a bit reluctant - in part on the advice of some test users - to introduce social rating of peer-contributed content in this context (of a community blog for a small, closed learning community). I certainly can see some potentially positive aspects of peer ratings of contributed content - inspiration to make contributions constructive to the group’s collaborative learning, with positive reinforcement for doing so; along with the learning opportunities implicit in offering and in receiving peer review.

But I am concerned about some possibilities - that this could become a popularity contest either in fact or in perception; that ratings might have more to do with agreement with a student orthodoxy than with a post’s contribution to community learning; that poor peer ratings might serve to disenfranchise some students rather than to inspire continued effort. Although offering and receiving peer review may be a valuable learning opportunity and may contribute to maturation of both parties, these lessons likely require more interaction than can be effectively communicated thru an up/down vote.

In less personal settings - e.g. surfacing of aggregated 3rd-party news items, or in more disseminated communities such as those driving Digg - social ratings seem to be the ticket. Am wondering tho if other algorithms for surfacing of content might be better suited to a community discussion.

Gardner Campbell wrote a recent post in his blog, titled Mistakes as Portals. Got me thinking about this question specifically - is the voted-up post necessarily a more interesting learning opportunity than the voted-down post? I’m recalling a forum discussion from a class last fall; unable to find anyone to cover my class, I was forced to teach 2 weeks of a course at a distance, while teaching in Europe. I assigned readings, and set up forums on our class Moodle page for discussion, weighing in on my end from cybercafes while traveling. One student posted a comment that struck others - and me - as rather offensive. By the time I read it, given the timezone difference, there were already several reactive comments posted. I nudged gently with a reply, and watched the conversation shift to a productive learning opportunity that permitted the original poster some recovery of dignity, and incorporated some of her original thoughts into an understanding that transcended the original disagreements. My sense is, that in a Digg-like format, her initial posting would have been buried as unpopular, offensive and unaligned with student orthodoxy; she would likely have remained disenfranchised and we would have been denied a productive discussion.

So perhaps an alternative criterion on which to rate user posts, would be how much does it inspire community discussion? With this in mind, using the Drupal Views module, I set up a “most commented” page - filtering for posts which have received at least 3 comments, and listing these by descending order of # of comments received. Posts receiving active discussion will surface toward the top of this page. Promotion is based not on peer-review as such, but rather on quite objectively, how much did this post engage the community in discussion?

Here are the essential settings on the Views settings for this page, set up in “table view” format:

Fields:

Comments No Comments »

Comments No Comments »

[ok, I did skip #13 - but hey, I just recently suffered site outage, and (fortunately temporary!) loss of a domain name, when my (former) hosting company went belly-up one Saturday morning without notice - so perhaps I can be forgiven a little superstitious behavior!]

In addition to the user-contributed material on my site (blog posts in the community blog & in satellite groups; attachments to blog posts displayable in a mini-portfolio; and aggregated distributed content from user blogging on other platforms), I wanted to provide some focused 3rd party feeds - health news from the BBC and NPR, Terry Gross’s wonderful Fresh Air interviews, feeds from the Centers for Disease Control, &c. I’ve been providing these on the front page of our Moodle platform using Moodle’s rss aggregation module as a sideblock, but thought it might be interesting to add some features to these imported feeds - such as threaded discussion on selected news items, and social rating of news stories with ranking/surfacing of voted-up content.

I’ve played around with ways of doing this. Recently I’ve been playing around with Tony Mobily’s most excellent Drigg module for Drupal, & may have more to say about that later on a bit, after more of a trial. My present implementation tho, is muckled together from other Drupal plugins.

As the Aggregation module is employed for other purposes on the site, I added a 2nd feed aggregating module. After trying out several options, I ended up using the feedapi module. This does not have the full set of features available in the Aggregation module, but it is serving reasonably well for this purpose. With a little care in naming of node-types, these two aggregators seem to play well together. The feedapi module is configured to create Story nodes from the feed items, and these Story nodes are organized for display in various formats using the Views menu.

For social ranking of news items, I have the votingapi module installed, and the voting interface is configured using extra_voting_forms (I’ve also tried fivestar, which works nicely as well; it just comes down to a preference re user interface). This is set up to permit voting up/down of Story nodes containing news item content. Comments are enabled for the Story node.

I’ve also enabled the community tags module for Story nodes, to permit users to tag stories with terms relevant to our user community.

In addition to the pages displaying the raw news items, I’ve set up a page for “promoted” stories, with a views filter set for VotingAPI points vote result (sum) greater than or equal to a chosen value (in the sandbox site, I’ve set this at ≥2; in a site with more active members it could be set higher).

Users can now easily access relevant 3rd-party material (news feeds, feeds from 3rd-party blogs of interest, &c.); scan for relevant news items & read these; rate them according to interest/relevance to our learner community; and engage in discussion on the items. A table-view of feed items is header-sortable by user-ranking, number of comments, &c. & Items voted up in interest appear on the “promoted stories” page.

I currently have restricted the creation of new feeds to administrator; eventually I plan to open this to faculty, and it might be interesting to open it to the community at large.

Comments 1 Comment »

I’m quite intrigued with the distributed discussion on the near-mythical ‘eduglu,’ and the work that some folks - notably D’Arcy Norman - are doing to create an ‘eduglu’ platform.

The notion here, as I understand it, is to create a platform capable of aggregating users’ distributed content from all manner of online publishing platforms, displaying this in a central location, and developing algorithms (e.g. social rating ala Digg) to surface material of particular relevance to the goals of the learner community. Threaded commenting on this aggregated material then can weave this previously widely distributed content into a community dialog.

This is truly amazing stuff! e.g., I could maintain my own blog, such as this one, in WordPress, using the WP Feeds widget to create context-sensitive feeds; and publish one or more context-sensitive feeds - e.g., the ‘dogs’-tag feed - to the ‘eduglu’ platform to be shared within that community (see my sandbox site, my ‘dogs’ feed from this blog is imported there). The user is not constrained, and does not need to be ‘brought over,’ to the community platform; does not need to duplicate posts made to a broader or selected audience. Users can publish on their platform(s)-of-choice, and have all this brought together into the learning-community platform.

The issue I face in my institution, is that very few of our students, and even fewer of our faculty, publish any distributed content. We have an older demographic, and due to the nature of our studies, likely have a less cyber-active population than many other learning institutions might have.

I see this changing tho. Progressively over the past two years, there are more & more shiny white boxes showing up in the classroom (our demographic does seem to lean strongly toward macs, much to the consternation of our microsoft-oriented IT department, and to my delight as a mac-fanatic). Students have been enthusiastic about my screencast lecturettes and podcasts, provided for class preparation & review. More of our faculty have been adopting forums in our Moodle LMS for blended discussion in classes and clinics. I can particularly see a wave of possibility here, as this increasingly cyber-capable population moves out into the world as alumni, spread out geographically and in need of accessible continuing education and peer support.

The question of algorithms for ’surfacing’ of information in a platform such as this comes up. Likely in a small institution, such as ours, the combination of a ‘river of news’ with tags (& the wonderful Tagadelic tag-cloud plugin for Drupal) and with buddies links and organic groups for niche discussions, would suffice. As noted in a previous post (#10 in this series), social rating might be problematic, with the potential for individual disenfranchisement (I would love to hear folks’ experiences with peer rating in this context!). Perhaps some creative use of social tagging (such as provided by the Drupal Community Tags module) could extend the benefits of author tagging of content, and provide some of the benefits seen with social rating of content.

On the Social Learning Platform I’m developing (sandbox version at http://sandbox.similibus.org), I’m using the Aggregation module to bring distributed content into the Community Blog. Of the feed aggregation modules available for Drupal, this is the best of the lot for this purpose - it imports the original article’s tags into the Drupal taxonomy, includes enclosures and inline graphics, and creates Drupal nodes from feed items, permitting organization and display of these using the Views module (see #9 in this series, where I set up a ‘community blog’ view which includes imported feed items as nodes in the ‘river of news’ alongside blog posts created within the social learning platform).

Comments 1 Comment »

I wanted to include a place for users to upload/archive files (of all sorts), to serve as a simple ‘user portfolio’ section of the site. I played around a bunch with some of the file management modules for Drupal, and the site was getting more & more complicated; and I finally came around to the “keep it simple” mantra that I’m trying to use to dictate the rest of the site’s design.

Fortunately, the Views module came to my rescue again, here coupled in use with Drupal’s built-in taxonomy. I came back to the idea of providing users with a single entry type - blog posts (allowing attachments); and use Views and Taxonomy to provide ways of viewing and organizing blog-post attachments.

Below, are the Views settings for a “my public files” page:

filters:

____________________

I created an “exposed filter”, to permit the user to select their attached files by tag:

______________

and created a page layout in table form:

_______________________

This view collects all files that the user has submitted as attachments to blog posts, into a table on a single page; renders these sortable by name, upload date, tag; and searchable by tag.

The Views module will permit many different ways of viewing the collected files - e.g., views could be created for “my published files,” “my unpublished/private files,” “all users’ files,” “my buddies’ files,” &c.; and could include exposed filters to further parse display.

I’m quite happy with how all this worked out - it feels like a very organic solution from the users’ end. Rather than creating a dedicated file upload/archiving corner of the site, files are contributed through the blogging interface (as either public or private/unpublished blog posts); and are merely displayed and organized through this interface.

Comments No Comments »

Comments No Comments »

I played with the idea of setting up social rating of peer-contributed content on the site. The votingapi module sets up filter- and sort- fields which can be accessed by the Views module, to surface material which has acquired a threshold vote (average or accumulated score), sending these to a “promoted posts” page (filter e.g. VotingAPI points vote result (sum) ≥ 5); and/or to sort posts in descending order of voted score (using this same field as a sort criterion in the view).

However - a small number of trial users nixed the idea of peer rankings before it was out of the bag - with concerns of how peer rating of content might be perceived (esp. re the ability to “demote” or “vote down” ratings - or “offer low karma” in the language of the extra_voting_forms module). This latter concern could be avoided by selecting the “vote up only” option in extra_voting_forms, not permitting peers to demote the score of a contribution; or by using another ranking module, such as fivestar, which also integrates with votingapi. I can see their point - it does take a mature learner to be able to gracefully accept and profit from peer review (I’m picturing still another verse appended to Janis Ian’s At Seventeen …). I can also create terrific counter-arguments. Perhaps I folded to the democratic process too readily, before giving users a fair trial.

So here’s the deal. I’m a wimp on the issue. I would love to hear the experiences of others who have experimented with peer rating of user contributions. How have students responded/related to this? Have you seen threatened / disenfranchised / disillusioned users, and if so, how might this be addressed or perhaps even turned into a real-word learning opportunity?

The ability of this site to permit fresh-generated contributions, and integrate these with material aggregated from user contributions in other web-publications (via the Aggregation module), in part matches the work that D’Arcy Norman has been doing with his eduglu project; but without the added feature of social rating/surfacing.

I have retained the idea of social rating of content, but restricted to 3rd-party content; so am experimenting with social rating/surfacing of imported news feed items, using a separate aggregation module (feedapi).

Comments No Comments »

A key feature of this site, is reliance on the wonderful Views module for Drupal. This permits display of the community blog with various filters applied (all posts, user’s posts, buddies’ posts, &c.), in various modes (full post, table/list view with various fields displayed), in variable sort-order, &c.

I’ve created several views of user-submitted material, as seen in the “Community Blog Views,” “Views of My Groups,” and “My Stuff” menus.

e.g., below are the settings for the Community Blog (list view) page:

access: authenticated user
Provide page view - checked
URL - blog/community_blog_listview
View type - table view
fields:

filters:

____________________________________________________________________

note that this will display both Blog posts and feed item nodes generated from the feeds collected by the Aggregation module. The latter is made available to users who have outside blogs, so that users can aggregate feed items from their outside blogs into our community blog. (The other aggregator module I have installed - feedapi - will be used for news feeds, which will not be incorporated into the community blog, but rather displayed elsewhere on the site).

sort criteria:

Comments 1 Comment »

Comments No Comments »

We made the decision to restrict access to our site to authenticated members of our academic community. I have to admit that I do find myself a bit muddled on the whole issue of transparency / transparent life. Perhaps having been raised in the rural Midwest, and spending much of my adult life in downeast Maine - geographic locales where personal privacy is perhaps pathologically emphasized - has unduly influenced this ;^). When introducing blogging/journaling/portfolio production into an academic community, further issues come forward, and frankly, I’m confused by it all. The issue of the transparent life has come upon us rather abruptly as transportation and communication technologies have become more sophisticated and available; it will be the task of the next several generations to sort out the hows/whys/ifs/whatnots/inevitabilities of this.

I’d love to see some discussion on this topic. I’m sure there’s a lot of it out there on the ‘net. Thanks to folks taking the transparency option :^).

But anyhow -

In Adminster > Access control, I’ve given “anonymous user” no privileges, including no access content privileges in the node module section. Non-logged-in users will see only an “Access denied” page with login fields.

Prior to denying “anonymous user” node module > access content privileges, it is important to assure that you will not lock yourself out of the site! This is easy to do with Drupal (or perhaps I’m just particularly skilled at this …), and you’ll find a lot of desperate “help” messages in the Drupal forum on this issue. (You can get to a login page using http://yoursite.com/?q=user , if you are so unfortunate). But before denying “anonymous user” access, activate the LoginToboggan module; then go to Administer > User management > LoginToboggan, and set the Present login form on access denied (403): radio button to enabled.

I have been playing around with Drupal 6.x. It is not yet ready to go for this application, as several of the necessary modules have not yet been made 6.x-ready. But its granular permissions structure may permit greater flexibility - permitting users to elect to make some content world-visible while holding other content within the authenticated-user community. It’ll be fun to mess with when module development catches up.

Access control for “authenticated user” should be straightforward. In the node module section, I’ve given permission only for access content, create group content, and edit own group content. In the Aggregation module section, I’ve given permission for manage aggregation feeds, manage aggregation items, manage own feed items, and view aggregation items. Users can post only 2 kinds of content - Blog posts, and imported feeds & feed items from their external blog. This reflects in part a decision to keep it simple. As a postgraduate school, we have many students of the cyberphobic demographic; too many options could discourage use. (also - the Books node is reserved for administrator use for Help pages; the Stories node is reserved for administrator use, for the 2nd aggregation module - feedapi - to aggregate news feeds for the socially-rated news section of the site).

I’ve given creation and attachment permissions for audio files in the audio and audio_attachment sections, so that users can post streaming audio into their blog postings.

User use authorship needs to be enabled in the Authorship section, to associate full names with posts, rather than usernames (this option will be configured in the Authorship module admin).

Override node publishing options needs to be enabled in override_node_options module section, to permit users the option of posting unpublished posts.

Other permissions should be intuitive, but I’ll visit a few of these in turn as I get around to discussion of specific functionalities of the site.

Comments No Comments »