Focus: A Solid Task Manager

Hi, works well. I completed a task and it auto hide which is fine. I guess a red [ x ] to allow deleting a completed task would be nice too. Anyway nicely done Noel~!

Some apps suggest “default” pods which are generally; [user], [user], and [user], but i think it’s more a convenience.

Typing the location is fine as our browsers often remember the form inputs second time round. (on this app that seems disabled - a security feature perhaps). Logging out and entering another Pod cleared the workspace, and returning to the first Pod recovered the workspace fine here as well.

Yeah, I still have to add a lot of features, that is one of them :D.

Actually I removed it on purpose (the solid-auth-client library already does that using the modal login). I don’t like the fact that some platforms are given more visibility. Although I can agree that it can be easier for users, so I’ll keep that in mind for the future to find a better approach.

I haven’t done anything special for that, it’s just that being a JS application I’m not using a “name” attribute for the form input. Maybe it’d be a good idea to have one so that it remembers previous inputs as you mention.


Thanks @NoelDeMartin, this is a great app, both to show what can be done with solid and to actually use. I am happy to see it developing further.

1 Like

You could have a look at this thread I started earlier.


Awesome work, I have just some UX pointers if you are interested to hear them, PM me on Gitter or LinkedIn.

1 Like

Great app, @NoelDeMartin, very nice work! I think starting with the Schema types, as you have is good - likely to be widely recognized. As you add more features, you’ll need to look at more specific ontologies likes calendars and events.


Nice app!

Question, can I save tasks to my Pod?

A key pattern with Solid-based RWW apps is that the WebID-Profile doc of an authenticated User Identity should inform said app about about Data Storage location. Here are some WebID-Profile doc relations that are currently associated with this pattern, via my WebID-Profile doc:


As far as I understand, as long as you login with a solid account (instead of using the offline mode), tasks will be stored on your pod, right? My understanding of “pod” is the solid server. For example, one account in

This is something I don’t know about and I think it may be related with what @pheyvaer was talking about. I’ll look into it and if I’ve got some doubts I’ll let you know. Thanks for the links :slight_smile:

1 Like

Yes, this works fine. When creating a workspace, it shows my storage and then I can choose a name for it. I can then find the data at<name>/

When I am logged in I should be able to see my WebID as a hyperlink that anchors my literal label.

The pattern for this is <a href="{webid}">{object-of-foaf-name-relation}</a>.

In addition, it would be beneficial to inform the user about default storage via pattern:

<a href="{webid}">{object-of-foaf-name-relation}</a> default <a href="{object-of-pim-storage-relation-or-ldp-inbox-etc}"> storage </a> .

Can you elaborate what’s the benefit of doing that?

About the storage, I still have to read a couple of links that have been posted on this thread to learn what storages are. Once I know them, I’ll see how to approach your suggestion :).

It takes one mouse-click or a mouseover to see what Identity your application is working with :slight_smile:

Shouldn’t that be seen with the name already? Unless you have the same name in different servers (which I guess is common).

The problem I see with placing the link on the name as it’s implemented now, is that it is displayed on the navigation drawer at all times. And I’m not sure if I’d want to add a link in there just for this reason. Maybe what I can do is include it on a “settings” panel or others that I plan to include at some point. Basically I agree that this information should be accessible somewhere within the app, but I’m not sure if the navigation drawer is the most appropriate place.

Thanks for your feedback, I’ll think about it and let you know once I’ve added this :).

1 Like

Key thing is for a WebID (an HTTP URI) to exhibit the characteristics of this kind of URI :slight_smile:

Thank you for sharing this great example and your learning experience Noel! I very much appreciate your activity log. Very useful and inspiring.

1 Like

Thanks! I’ll be starting the continuation shortly where I apply some of the feedback and I’ll look into a better way to handle the data models :).


@NoelDeMartin great job on this app! If you’re still interested in exploring other ontologies, my team works with the Common Core Ontology. I know that we have some detailed task-related terms. If you’re interested in giving them a try, I think we could add some additional features to your app (like due dates etc). Let me know if you wanna give it a shot, we’re happy to help.

1 Like

That’d be great! I’ve actually been working for a while in a dev branch adding new features, and finding ontologies is still one of the main pain points. I’ll add descriptions (already implemented) and due dates to the next version, and I wouldn’t mind changing the ontologies because there won’t be a 1.0 stable version yet.

You can check out the ontologies I’m using at the moment here:


Great, I’m checking them out now!

It’s strange for me to use foaf:name for a Task or a List… I thought it was reserved for a Person, a friend of a friend.