let ol = require('openlayers');
let jsts = require('jsts/dist/jsts');
let parser = new jsts.io.OL3Parser(undefined, ol);
let AbstractOperation = require('../operations/abstract');
let DoesContainResult = require('../operations/types/doesContainResult');
/**
* Класс DoesContain
* @extends AbstractOperation
*/
class DoesContain extends AbstractOperation {
/**
* Создает экземпляр класса DoesContain
*/
constructor() {
super()
}
/**
*
* @param featureA
* @param featureB
* @return {boolean}
*/
execute(featureA, featureB) {
let doesContain = operation(featureA, featureB);
return new DoesContainResult({
result: doesContain
})
}
}
function operation(featureA, featureB) {
let geomA = parser.read(featureA.getGeometry());
let geomB = parser.read(featureB.getGeometry());
let result = geomA.contains(geomB);
return result
}
module.exports = DoesContain;