Skip to content

Commit

Permalink
Merge branch 'patch' into layer-view-data-id
Browse files Browse the repository at this point in the history
  • Loading branch information
AlexanderGeere authored Oct 31, 2024
2 parents 41dc4bc + f88d2f3 commit 3a50496
Show file tree
Hide file tree
Showing 48 changed files with 171 additions and 124 deletions.
17 changes: 0 additions & 17 deletions .eslintrc.js

This file was deleted.

4 changes: 2 additions & 2 deletions .github/workflows/codeql.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,10 @@ name: "CodeQL"

on:
push:
branches: [ "main" ]
branches: [ "main", "major", "minor", "patch" ]
pull_request:
# The branches below must be a subset of the branches above
branches: [ "main" ]
branches: [ "main", "major", "minor", "patch" ]
schedule:
- cron: '40 1 * * 2'

Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/deploy-docs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ name: Deploy static content to Pages
on:
# Runs on pushes targeting the default branch
push:
branches: ["main"]
branches: [ "main" ]

# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
Expand Down
24 changes: 24 additions & 0 deletions .github/workflows/eslint.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
name: ESLint

on:
push:
branches: [ "main", "major", "minor", "patch" ]
pull_request:
branches: [ "main", "major", "minor", "patch" ]

jobs:
eslint:
name: Run ESLint
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '20'

- name: Install dependencies
run: npm install

- name: Run ESLint
run: npx eslint . --max-warnings=0
4 changes: 2 additions & 2 deletions .github/workflows/unit_tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@ name: Codi unit tests

on:
push:
branches: [ main ]
branches: [ "main", "major", "minor", "patch" ]
pull_request:
branches: [ main ]
branches: [ "main", "major", "minor", "patch" ]

jobs:
build:
Expand Down
17 changes: 17 additions & 0 deletions DEVELOPING.md
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,23 @@ ESBuild must also be used to compile the CSS supporting the MAPP and MAPP.UI ele

npx esbuild --bundle public/css/_ui.css --outfile=public/css/ui.css --loader:.svg=dataurl

## ESLint

The codebase makes use of the [eslint](eslint.org) package to ensure that our code adhere to different rules and coding guidelines.
To run `eslint` you will need to have the development packages installed. You can ensure they are installed by running `npm install` in the root of the xyz directory.

To run the lint you can execute `npx eslint .` in the root of the application. This will show any issues there are with the codebase. You can also add the flag `--fix` to the command to allow eslint to fix any issues it may find.

eslint command

npx esbuild .

eslint command with fix

npx esbuild . --fix

There are other extensions you can use in your editor to get on the fly error highlighting where any rules are broken. Please look into what eslint supports in your environment.

## version.js hash

The mapp module object holds a hash of the latest release commit which can be generated by executing the version.js script in the root.
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
**v4.12.**
**v4.12.1**

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
![Codi Unit Tests](https://github.com/GEOLYTIX/xyz/actions/workflows/unit_tests.yml/badge.svg)
Expand Down
22 changes: 22 additions & 0 deletions eslint.config.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
export default [
{
ignores: ['public/js/lib/*', 'docs/**/*'],
},
{
files: ['**/*.js', '**/*.mjs'],
rules: {
quotes: ['error', 'single', { 'allowTemplateLiterals': true }],
'prefer-const': ['error', {
'destructuring': 'any',
'ignoreReadBeforeAssign': true
}],
'max-depth': ['error',
{
'max': 4
}
],
// 'complexity': ['error', { 'max': 15 }],
'no-nested-ternary': 'error'
}
}
];
2 changes: 1 addition & 1 deletion lib/layer/decorate.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -249,7 +249,7 @@ async function zoomToExtent(params) {
// Zooms to a specific extent.

// XMLHttpRequest to layer extent endpoint
let response = await mapp.utils.xhr(`${this.mapview.host}/api/query/layer_extent?` +
const response = await mapp.utils.xhr(`${this.mapview.host}/api/query/layer_extent?` +
mapp.utils.paramString({ // build query string for the url
locale: this.mapview.locale.key,
layer: this.key,
Expand Down
6 changes: 3 additions & 3 deletions lib/layer/featureFields.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -84,9 +84,9 @@ The jenks distribution method requires the stats.jenks utility method to calcula
@param {layer} layer A decorated mapp layer object.
*/
function jenks(layer) {
let theme = layer.style.theme;
const theme = layer.style.theme;

let n = Math.min(layer.featureFields[theme.field].values.length, theme.categories.length);
const n = Math.min(layer.featureFields[theme.field].values.length, theme.categories.length);

// Parse array values as float.
layer.featureFields[theme.field].values = layer.featureFields[theme.field].values.map(parseFloat);
Expand All @@ -113,7 +113,7 @@ The count distribution method counts values in the `featureFields.values[]` arra
@param {layer} layer A decorated mapp layer object.
*/
function count(layer) {
let theme = layer.style.theme;
const theme = layer.style.theme;

layer.featureFields[theme.field].values.forEach(val => {

Expand Down
2 changes: 1 addition & 1 deletion lib/layer/featureStyle.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ export default function featureStyle(layer) {

if (!layer.style.cluster) return;

let clusterScale = parseFloat(layer.style.cluster.clusterScale)
const clusterScale = parseFloat(layer.style.cluster.clusterScale)

// Spread cluster style into feature.style.
feature.style = {
Expand Down
2 changes: 1 addition & 1 deletion lib/layer/themes/distributed.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ export default function(theme, feature) {
theme.index = 0
}

let field = theme.field || 'id'
const field = theme.field || 'id'

// Get feature identifier for theme.
const val = feature.properties[field]
Expand Down
6 changes: 3 additions & 3 deletions lib/layer/themes/graduated.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ export default function (theme, feature) {
// The graduated theme requires feature.properties.
if (!feature.properties) return;

let catValue = Array.isArray(feature.properties.features) ?
const catValue = Array.isArray(feature.properties.features) ?

// Reduce array of features to sum catValue
feature.properties.features.reduce((total, F) => total + Number(F.getProperties()[theme.field]), 0) :
Expand All @@ -35,9 +35,9 @@ export default function (theme, feature) {
'greater_than': val => cat => val >= cat.value
}

let index = theme.categories.findIndex(graduated_breaks[theme.graduated_breaks](catValue))
const index = theme.categories.findIndex(graduated_breaks[theme.graduated_breaks](catValue))

let cat = theme.categories.at(index)
const cat = theme.categories.at(index)

// Spread cat style to retain scale property
feature.style = {
Expand Down
2 changes: 1 addition & 1 deletion lib/location/create.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ export default async function createLocation(feature, interaction, layer) {
setTimeout(checkFeature, 1000);

function checkFeature() {
let found = layer.features?.find(F => F.properties?.id === location.id);
const found = layer.features?.find(F => F.properties?.id === location.id);
if (found) {
layer.source.un('tileloadend', concatFeatures);
} else {
Expand Down
6 changes: 3 additions & 3 deletions lib/mapp.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ if (window.ol === undefined) {

} else {

let olVersion = parseFloat(ol?.util.VERSION)
const olVersion = parseFloat(ol?.util.VERSION)

console.log(`OpenLayers version ${olVersion}`)

Expand All @@ -70,9 +70,9 @@ if (window.ol === undefined) {
self.mapp = {
ol: _ol,

version: '4.12.',
version: '4.12.1',

hash: 'dcf15d344c332b668212c7cee1b967d0bd973393',
hash: 'd18842e399cba41278b14e6658d2706a692f9b19',

host: document.head?.dataset?.dir || '',

Expand Down
2 changes: 1 addition & 1 deletion lib/plugins/login.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,6 @@ export function login(plugin, mapview) {
btnColumn.appendChild(mapp.utils.html.node`
<a
title=${mapp.user ? mapp.dictionary.toolbar_logout : mapp.dictionary.toolbar_login}
href=${mapp.user ? "?logout=true" : "?login=true"}>
href=${mapp.user ? '?logout=true' : '?login=true'}>
<div class=${iconClass}>`);
}
2 changes: 1 addition & 1 deletion lib/ui/Gazetteer.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ export default gazetteer => {
if (!e.target.value.length) return;

// Get possible coordinates from input.
let ll = e.target.value.split(',').map(parseFloat)
const ll = e.target.value.split(',').map(parseFloat)

// Check whether coordinates are valid float values.
if (ll.length === 2 && ll.every(n => typeof n === 'number' && !isNaN(n) && isFinite(n))) {
Expand Down
2 changes: 1 addition & 1 deletion lib/ui/elements/legendIcon.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ function createIconFromArray(style) {
});
};

let legendScale = style.icon[0].legendScale || 1;
const legendScale = style.icon[0].legendScale || 1;

style.icon.forEach((icon) => {

Expand Down
2 changes: 1 addition & 1 deletion lib/ui/layers/filters.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -522,7 +522,7 @@ async function filter_in(layer, filter) {

const pattern = e.target.value;

let filtered = filter[filter.type].filter(val =>
const filtered = filter[filter.type].filter(val =>

// val may not be string.
val.toString().toLowerCase().startsWith(pattern.toLowerCase()))
Expand Down
2 changes: 1 addition & 1 deletion lib/ui/layers/legends/categorized.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ export default function categorizedTheme(layer) {
const cat_label = cat.label + (cat.count? ` [${cat.count}]`:'')

// Cat label with filter function.
let label = mapp.utils.html`<div
const label = mapp.utils.html`<div
class=${classList}
style="grid-column: 2;"
onclick=${e => catToggle(e, layer, cat)}>${cat_label}`
Expand Down
10 changes: 5 additions & 5 deletions lib/ui/locations/entries/cloudinary.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -186,10 +186,10 @@ function imageLoad(e, entry) {

img.onload = async () => {

let
canvas = mapp.utils.html.node`<canvas>`,
max_size = 1024,
width = img.width,
const canvas = mapp.utils.html.node`<canvas>`
const max_size = 1024

let width = img.width,
height = img.height

// resize
Expand Down Expand Up @@ -276,7 +276,7 @@ async function docLoad(e, entry) {

async function trash(e, entry) {

const confirm = await mapp.ui.elements.confirm({text: mapp.dictionary.remove_item_confirm});
const confirm = await mapp.ui.elements.confirm({ text: mapp.dictionary.remove_item_confirm });

if (!confirm) return;

Expand Down
2 changes: 1 addition & 1 deletion lib/utils/copyToClipboard.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
// Create temporary textarea to copy string to clipboard.
export function copyToClipboard(str) {

let textArea = document.body.appendChild(mapp.utils.html.node`
const textArea = document.body.appendChild(mapp.utils.html.node`
<textarea style="visibility=none;">`);

textArea.value = str;
Expand Down
4 changes: 2 additions & 2 deletions lib/utils/csvDownload.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ export default function csvDownload(data, params = {}) {

const rows = data.map(record => {

let row = Array.isArray(params.fields)
const row = Array.isArray(params.fields)
? fieldsFunction(record, params.fields)
: Object.values(record)

Expand Down Expand Up @@ -64,7 +64,7 @@ function fieldsFunction(record, fields) {
// Format number toLocaleString
if (field.formatter === 'toLocaleString') {

let val = parseFloat(record[field.field])
const val = parseFloat(record[field.field])

if (isNaN(val)) return;

Expand Down
4 changes: 2 additions & 2 deletions lib/utils/dataURLtoBlob.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,15 @@
export function dataURLtoBlob(dataURL) {

if (dataURL.indexOf(';base64,') == -1) {
let
const
parts = dataURL.split(','),
contentType = parts[0].split(':')[1],
raw = parts[1];

return new Blob([raw], { type: contentType });
}

let
const
parts = dataURL.split(';base64,'),
contentType = parts[0].split(':')[1],
raw = window.atob(parts[1]),
Expand Down
2 changes: 1 addition & 1 deletion lib/utils/merge.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ export default function mergeDeep(target, ...sources) {

if (Object.getPrototypeOf(source) !== Object.getPrototypeOf({})) continue;

if (key === "__proto__" || key === "constructor") continue;
if (key === '__proto__' || key === 'constructor') continue;

if (source[key] instanceof HTMLElement) {
console.warn(source[key])
Expand Down
4 changes: 2 additions & 2 deletions lib/utils/olStyle.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -89,12 +89,12 @@ export default function olStyle(style, feature) {
if (style.fillColor || style.strokeColor) {

// Create OL fill.
let fill = style.fillColor && new ol.style.Fill({
const fill = style.fillColor && new ol.style.Fill({
color: mapp.utils.hexa(style.fillColor, style.fillOpacity)
})

// Create OL stroke.
let stroke = style.strokeColor && new ol.style.Stroke({
const stroke = style.strokeColor && new ol.style.Stroke({
color: mapp.utils.hexa(style.strokeColor, style.strokeOpacity),
width: parseFloat(style.strokeWidth || 1)
})
Expand Down
2 changes: 1 addition & 1 deletion lib/utils/polygonIntersectFeatures.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ export function polygonIntersectFeatures(params) {
}

// Config for mapview draw interaction.
let interaction = {
const interaction = {

// Draw polygon.
type: 'Polygon',
Expand Down
Loading

0 comments on commit 3a50496

Please sign in to comment.