Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/melvincarvalho/clip
clipboard for the solid platform
https://github.com/melvincarvalho/clip
solid solid-app webid-tls
Last synced: about 1 month ago
JSON representation
clipboard for the solid platform
- Host: GitHub
- URL: https://github.com/melvincarvalho/clip
- Owner: melvincarvalho
- License: mit
- Created: 2015-07-01T21:35:17.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2020-01-04T07:36:11.000Z (almost 5 years ago)
- Last Synced: 2024-08-01T12:34:39.388Z (4 months ago)
- Topics: solid, solid-app, webid-tls
- Language: JavaScript
- Homepage:
- Size: 2.79 MB
- Stars: 4
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - melvincarvalho/clip - clipboard for the solid platform (others)
README
# clip
[![Join the chat at https://gitter.im/melvincarvalho/clip](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/melvincarvalho/clip?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
#clipboard for Solid apps
Running live here: https://melvincarvalho.github.io/clip/
Quick Start for contributors
----------------------------```
$ git clone git://github.com/melvincarvalho/clip
$ cd clip
$ sudo npm -g install bower
$ bower install
```# Tutorial
# Chapter 2 - Solid Clipboard
![](https://melvincarvalho.gitbooks.io/solid-tutorials/content/clip.png)
## Introduction
In this tutorial we will cover how to load and save data to a Personal Online Datastore (Pod). The app is a simple web clipboard that allows you to save data to a store and then recover it later.
*What you will learn*
* How to set up [rdflib.js](https://github.com/linkeddata/rdflib.js/) to work with the web of data
* How to read data from a Pod
* How to write data to a Pod
* How to change the location of the URL you are using
* How to change query string to allow bookmarking
* How to use the `#this` pattern
* How to use the `urn:tmp:` pattern## The App
This app builds on the previous hello world app, which enables login and logout by introducing Personal Data Stores (Pods) and allowing read and write to those stores using [rdflib.js](https://github.com/linkeddata/rdflib.js/). The app operates as a simple web clipboard that lets you save text to a location and retrieve it later.
The first thing that we will do is set up [rdflib.js](https://github.com/linkeddata/rdflib.js/). It is sourced in to index.html
```html
```After sourcing in the library, the first thing to do is to **initialize** a knowledge base graph, and a fetcher. This is done using the `$rdf` global variables.
```javascript
g = $rdf.graph();
f = $rdf.fetcher(g);
```The variable `g` will contain everything that is fetched using the fetcher, and also meta data about the documents that have been fetched. The variable `f` can be used to fetch documents.
For convenience some common namespaces are set up so that vocabs can be called conveniently with a shorthand using `$rdf.Namespace`
```javascript
var CHAT = $rdf.Namespace("https://ns.rww.io/chat#");
var CURR = $rdf.Namespace("https://w3id.org/cc#");
var DCT = $rdf.Namespace("http://purl.org/dc/terms/");
var FACE = $rdf.Namespace("https://graph.facebook.com/schema/~/");
var FOAF = $rdf.Namespace("http://xmlns.com/foaf/0.1/");
var LIKE = $rdf.Namespace("http://ontologi.es/like#");
var LDP = $rdf.Namespace("http://www.w3.org/ns/ldp#");
var MBLOG = $rdf.Namespace("http://www.w3.org/ns/mblog#");
var OWL = $rdf.Namespace("http://www.w3.org/2002/07/owl#");
var PIM = $rdf.Namespace("http://www.w3.org/ns/pim/space#");
var RDF = $rdf.Namespace("http://www.w3.org/1999/02/22-rdf-syntax-ns#");
var RDFS = $rdf.Namespace("http://www.w3.org/2000/01/rdf-schema#");
var SIOC = $rdf.Namespace("http://rdfs.org/sioc/ns#");
var SOLID = $rdf.Namespace("http://www.w3.org/ns/solid/app#");
var TMP = $rdf.Namespace("urn:tmp:");
```Next, we want to pull in the data, so we use the `nowOrWhenFetched` function of the fetcher to get data from Pod.
Before we can do this we must determine the location from the query string or from a default as follows, using the angularJS search function:
```javascript
var storageURI = 'https://clip.databox.me/Public/.clip/Public/test';
if ($location.search().storageURI) {
storageURI = $location.search().storageURI;
}
```For this app, the document is assumed to contain data of the form
```html
<#this> "data" .
```The data above uses the turtle notation. The `#this` subject is used to distinguish between document and data, and is similar to the 'this' keyword in JavaScript.
A best practice would be to mint an HTTP URI for the predicate. But for ease of demonstration purposes, a temporary URN is used at under the scheme urn:tmp:. It is advisable always to use HTTP URIs, rather than schemes such as urn:, when dealing with linked data, this will be covered in the next tutorial.
Now we can fetch the data:
```javascript
f.nowOrWhenFetched(storageURI, undefined, function(ok, body) {
var clipboard = g.any($rdf.sym(storageURI + '#this'), TMP('clipboard'));
$scope.clipboard = clipboard;
$scope.storageURI = storageURI;
});
```The `nowOrWhenFetched` will call a callback either if the document is loaded in the graph, or once it is fetched from the web. The `$rdf.sym` function simply changes a string into a URI by placing angle brackets around it. We use the function `g.any` to get the object of the namespace TMP of value 'clipboard'.
Once we have fetched this data we can set it to the screen, and also set the storageURI which has come back successfully.
To save the clipboard we issue a PUT request to the server.
```javascript
$http({
method: 'PUT',
url: $scope.storageURI,
withCredentials: true,
headers: {
"Content-Type": "text/turtle"
},
data: '<#this> """' + clipboard + '""" .',
}).
success(function(data, status, headers) {
$scope.notify('clipboard saved');
$location.search('storageURI', $scope.storageURI);
}).
error(function(data, status, headers) {
$scope.notify('could not save clipboard', 'error');
});
```
The line```javascript
$location.search('storageURI', $scope.storageURI);
```Changes the query string to the storage URI so that the clipboard can be bookmarked, or shared. It is important on the web that URIs reflect the state of a given app. Astute observers will also note that the address bar now becomes an input form where changing the query string can change the content.
Putting this all together it should be possible to see a demo as follows:
[Live Demo](http://melvincarvalho.github.io/clip/)
The default location for storing the clip in this demo is public `https://clip.databox.me/Public/.clip/Public/test` but in practice you would want to store data in a private workspace under your storage root. Automatically finding endpoints will be covered in future. See Appendix B for more details.
A typical location could be
```
/Private/.clip/clip1
```## Summary
In this tutorial we learnt how to set up [rdflib.js](https://github.com/linkeddata/rdflib.js/) in order to read and write structured data to a personal data server. We looked at patterns for naming and functions to read, write, and allow bookmarking. In the next tutorial we will look at how to embed media in a webpage.
## See Also
* [Source Code](https://github.com/melvincarvalho/clip)
* [Live Demo](http://melvincarvalho.github.io/clip/)
* [rdflib.js](https://github.com/linkeddata/rdflib.js/)