JS integration library for CKAN data catalog
You have a fully functional widget in the "build" folder. It is made of an index.html file and some css and js files. Look inside the index.html to see the parameters you can set, and the filters you can play with. Make the "ckan_api" parameter point towards the CKAN instance you want to integrate. Copy this part into your own web page if you wish so. See the app.css file to change the styles and colors of the widget, and make it fit your own environment.
See below for full developpers instructions.
Node <= 16
cd ckan-widget
npm install && npm start
Then open http://localhost:3000/ to see the widget app.
To bundle ckan widget for production run
cd ckan-widget && npm run build
Minified bundle should be created inside build directory.
Requierments: proceed with instalation
- Update the version number in ckan-widget/package.json
- Delete the build folder :
rm -Rf build
- Build :
cd ckan-widget/ ; npm run build
- Update the build id in this document and that the HTML snippets match the index.html generate by the build
- Commit
- Tag
- Push on Github.com
There is a HTML file (build/index.html) which integrates the widget. You should be able to open the index.html from build folder
in browser with doubleclick
from file location, without the need of npm or any server.
Full code of build/index.html file (the build version is minified, you should be able to make it readable usind a indenter program such as https://www.freeformatter.com/html-formatter.html) :
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<link href="./app.css" rel="stylesheet">
<link href="./static/css/main.css" rel="stylesheet">
<title>Catalogue CKAN</title>
<link href="./static/css/main.4d1cfba5.chunk.css" rel="stylesheet">
</head>
<body>
<div id="ckan-widget"></div>
<script>!function(a){function e(e){for(var t,r,n=e[0],o=e[1],u=e[2],i=0,l=[];i<n.length;i++)r=n[i],Object.prototype.hasOwnProperty.call(c,r)&&c[r]&&l.push(c[r][0]),c[r]=0;for(t in o)Object.prototype.hasOwnProperty.call(o,t)&&(a[t]=o[t]);for(s&&s(e);l.length;)l.shift()();return p.push.apply(p,u||[]),f()}function f(){for(var e,t=0;t<p.length;t++){for(var r=p[t],n=!0,o=1;o<r.length;o++){var u=r[o];0!==c[u]&&(n=!1)}n&&(p.splice(t--,1),e=i(i.s=r[0]))}return e}var r={},c={1:0},p=[];function i(e){if(r[e])return r[e].exports;var t=r[e]={i:e,l:!1,exports:{}};return a[e].call(t.exports,t,t.exports,i),t.l=!0,t.exports}i.m=a,i.c=r,i.d=function(e,t,r){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(i.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var n in t)i.d(r,n,function(e){return t[e]}.bind(null,n));return r},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="./";var t=this["webpackJsonpckan-widget"]=this["webpackJsonpckan-widget"]||[],n=t.push.bind(t);t.push=e,t=t.slice();for(var o=0;o<t.length;o++)e(t[o]);var s=n;f()}([])</script><script src="./static/js/2.85a3e85f.chunk.js"></script><script src="./static/js/main.404aabed.chunk.js"></script>
</body>
<script src="./static/js/main.js" type="text/javascript"></script>
<script type="text/javascript">var config={};ckanWidget.init(config)</script>
</html>
To integrate the Widget in HTML page/Web App, take the JS and CSS files located at build/static/js
and build/static/css
and put wherever is suitable for the App/Page.
Then import the files in the Page. The format of the minified file names is main.id.chunk.js, x.y.chunk.js and main.id.chunk.css.
Also, you can rename the files if necessary.
The script line <script>!function(a)...</script>
is mandatory, it load the CKAN Widget in the variable ckanWidget
.
If you don't put it, you will have an error in the JavaScript console of the browser:
Uncaught ReferenceError: ckanWidget is not defined
Using the public/app.css
you can change the style of the Widget. HTML page example:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<link href="./app.css" rel="stylesheet">
<link href="./static/css/main.4d1cfba5.chunk.css" rel="stylesheet">
<title>Page Title</title>
</head>
<body>
<div id="ckan-widget"></div>
</body>
<script>!function(a){function e(e){for(var t,r,n=e[0],o=e[1],u=e[2],i=0,l=[];i<n.length;i++)r=n[i],Object.prototype.hasOwnProperty.call(c,r)&&c[r]&&l.push(c[r][0]),c[r]=0;for(t in o)Object.prototype.hasOwnProperty.call(o,t)&&(a[t]=o[t]);for(s&&s(e);l.length;)l.shift()();return p.push.apply(p,u||[]),f()}function f(){for(var e,t=0;t<p.length;t++){for(var r=p[t],n=!0,o=1;o<r.length;o++){var u=r[o];0!==c[u]&&(n=!1)}n&&(p.splice(t--,1),e=i(i.s=r[0]))}return e}var r={},c={1:0},p=[];function i(e){if(r[e])return r[e].exports;var t=r[e]={i:e,l:!1,exports:{}};return a[e].call(t.exports,t,t.exports,i),t.l=!0,t.exports}i.m=a,i.c=r,i.d=function(e,t,r){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(i.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var n in t)i.d(r,n,function(e){return t[e]}.bind(null,n));return r},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="./";var t=this["webpackJsonpckan-widget"]=this["webpackJsonpckan-widget"]||[],n=t.push.bind(t);t.push=e,t=t.slice();for(var o=0;o<t.length;o++)e(t[o]);var s=n;f()}([])</script>
<script src="./static/js/2.85a3e85f.chunk.js"></script>
<script type="text/javascript" src="./static/js/main.404aabed.chunk.js"></script>
<script type="text/javascript">
var config = {
ckan_api: 'https://ckan-api.com',
link_to_ckan_href: 'https://ckan-site/path-datasets/{name}/',
link_to_ckan_label: 'View on CKAN catalog',
ckan_organizations: ['org1', 'org2'],
ckan_groups: ['group1'],
ckan_tags: ['tag1'],
ckan_facets: {
res_format: 'HTML',
datatype: 'type'
},
facet_display: ['facet1','facet1','facet3'],
data_sort: 'title_string asc',
result_page_size: 25,
thumbnails_display: true,
header_display: true,
sidebar_display: true
}
// Will run the Widget with custom configuration
ckanWidget.init(config)
</script>
</html>
There must be <div id="ckan-widget"></div>
because the Widget looking for div
element with id ckan-widget
.
This example shows how you can pass configurations parameters.
The public/app.css
file contains the default style of the Widget. You can change/override the predefined style by changing this file.
In order to change the color of the Dataset's title put the following style in the public/app.css
along with the rest css:
h4.title {
color: rgb(194, 24, 185) !important
}
The Widget loads the configuration that is passed to the init
function at start up. If configuration is not passed to the init
function then, it starts with the default one. Here's an example of configuration object:
var config = {
ckan_api: 'https://ckan-api.com',
link_to_ckan_href: 'https://ckan-site/path-datasets/{name}/',
link_to_ckan_label: 'View on CKAN catalog',
ckan_organizations: ['org1', 'org2'],
ckan_groups: ['group1'],
ckan_tags: ['tag1'],
ckan_facets: {
res_format: 'HTML',
datatype: 'type'
},
facet_display: ['organization'],
data_sort: 'title_string asc',
result_page_size: 25,
thumbnails_display: true,
header_display: true,
sidebar_display: true
}
If you do not want to specify some configuration properties, just omit them. This is still valid configuration object:
var config = {
result_page_size: 25,
thumbnails_display: false
}
Configuration properties:
- ckan_api: Ckan API URL. Default to the
trouver.datasud.fr
one. - link_to_ckan_href : URL pattern of a record in the CKAN catalog,
- link_to_ckan_label : wording that will be displayed on the link to open the dataset in the CKAN catalog,
- ckan_organizations: CKAN Organizations names to be retrieved. Default to All. Else, comma separated list of Organizations IDs.
- ckan_groups: CKAN Groups names to be retrieved. Default to All. Else, comma separated list of Groups IDs.
- ckan_facets: key-values pair to be used to filter on the facets.
- ckan_tags: CKAN Tags names to be retrieved. Default to All. Else, comma separated list of Tags IDs.
- facet_display: list of the facets to be displayed in the widget. Default to all. Else, comma separated list of facets names.
- data_sort: sorting mode to be used. Same than the CKAN ones (popularity, relevance, last_modified, alpha…). Default to
score desc, metadata_modified desc
. - result_page_size: number of results per page(10, 25, 50, 100). Default to
10
. Max to100
. - thumbnails_display: boolean. Whether to display dataset's thumbnail or not. Default to
true
. - header_display: boolean. Whether to display widget header and search bar
- sidebar_display: boolean. Whether to display the sidebar
It is a little hard and tricky how to set the API Key securely. Fortunately create-react-app allows us to define environment variables while we are building the Widget by creating the .env
file in the root of the project at the same level where package.json
is. Afterward when we will integrate the Widget there is no need to define .env
file or set the enviroment variable manually, it is only needed for building the Widget.
To define environment variable, create a file called .env in the root of the project:
REACT_APP_API_KEY="API-KEY"
Then build the Widget:
npm run build
The value of the API key is accessible in the Widget as process.env.REACT_APP_API_KEY
.
Note: The environment variables define in .env
file must begin with REACT_APP_.
cd ckan-widget && npm test