Files
iD/test/spec/ui/fields/access.js

150 lines
7.1 KiB
JavaScript

describe('iD.uiFieldAccess', function() {
var context, selection, field;
beforeEach(function() {
context = iD.coreContext().assetPath('../dist/').init();
selection = d3.select(document.createElement('div'));
field = iD.presetField('access', {
keys: ['access', 'foot', 'motor_vehicle', 'bicycle', 'horse'],
type: 'access'
});
});
it('creates inputs for a variety of modes of access', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
expect(selection.selectAll('.preset-access-access').size()).to.equal(1);
expect(selection.selectAll('.preset-access-foot').size()).to.equal(1);
expect(selection.selectAll('.preset-access-motor_vehicle').size()).to.equal(1);
expect(selection.selectAll('.preset-access-bicycle').size()).to.equal(1);
expect(selection.selectAll('.preset-access-horse').size()).to.equal(1);
});
it('does not include "yes", "designated", "dismount" options for general access (#934), (#2213)', function() {
var access = iD.uiFieldAccess(field, context);
var options = access.options('access').map(function(v) { return v.value; });
expect(options).not.to.include('yes');
expect(options).not.to.include('designated');
expect(options).not.to.include('dismount');
});
it('does include a "dismount" option for bicycles (#2726)', function() {
var access = iD.uiFieldAccess(field, context);
var options;
options = access.options('bicycle').map(function(v) { return v.value; });
expect(options).to.include('dismount');
options = access.options('foot').map(function(v) { return v.value; });
expect(options).not.to.include('dismount');
});
it('sets foot placeholder to "yes" for steps and pedestrian', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
access.tags({highway: 'steps'});
expect(selection.selectAll('.preset-input-access-foot').attr('placeholder')).to.equal('yes');
access.tags({highway: 'pedestrian'});
expect(selection.selectAll('.preset-input-access-foot').attr('placeholder')).to.equal('yes');
});
it('sets foot placeholder to "designated" for footways', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
access.tags({highway: 'footway'});
expect(selection.selectAll('.preset-input-access-foot').attr('placeholder')).to.equal('designated');
});
it('sets bicycle placeholder to "designated" for cycleways', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
access.tags({highway: 'cycleway'});
expect(selection.selectAll('.preset-input-access-bicycle').attr('placeholder')).to.equal('designated');
});
it('sets horse placeholder to "designated" for bridleways', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
access.tags({highway: 'bridleway'});
expect(selection.selectAll('.preset-input-access-horse').attr('placeholder')).to.equal('designated');
});
it('sets motor_vehicle placeholder to "no" for footways, steps, pedestrian, cycleway, bridleway, and path', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
['footway', 'steps', 'pedestrian', 'cycleway', 'bridleway', 'path'].forEach(function(value) {
access.tags({highway: value});
expect(selection.selectAll('.preset-input-access-motor_vehicle').attr('placeholder')).to.equal('no');
});
});
it('sets motor_vehicle placeholder to "yes" for various other highway tags', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
['residential', 'motorway', 'trunk', 'primary', 'secondary', 'tertiary', 'service',
'unclassified', 'motorway_link', 'trunk_link', 'primary_link', 'secondary_link', 'tertiary_link'].forEach(function(value) {
access.tags({highway: value});
expect(selection.selectAll('.preset-input-access-motor_vehicle').attr('placeholder')).to.equal('yes');
});
});
it('overrides a "yes" or "designated" placeholder with more specific access tag (#2213)', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
access.tags({highway: 'service', access: 'emergency'});
expect(selection.selectAll('.preset-input-access-motor_vehicle').attr('placeholder')).to.equal('emergency');
access.tags({highway: 'cycleway', access: 'permissive'});
expect(selection.selectAll('.preset-input-access-bicycle').attr('placeholder')).to.equal('permissive');
});
it('overrides a "no" placeholder with more specific access tag (#2763)', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
access.tags({highway: 'cycleway', access: 'destination'});
expect(selection.selectAll('.preset-input-access-motor_vehicle').attr('placeholder')).to.equal('destination');
});
it('sets bicycle and motor_vehicle placeholder to the value of the "vehicle" tag (id-tagging-schema#378)', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
access.tags({highway: 'residential', vehicle: 'destination'});
expect(selection.selectAll('.preset-input-access-motor_vehicle').attr('placeholder')).to.equal('destination');
expect(selection.selectAll('.preset-input-access-bicycle').attr('placeholder')).to.equal('destination');
});
it('sets foot, bicycle and horse placeholder to "no" when there a "motorroad=yes" tag (#9333)', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
access.tags({highway: 'primary', motorroad: 'yes'});
expect(selection.selectAll('.preset-input-access-foot').attr('placeholder')).to.equal('no');
expect(selection.selectAll('.preset-input-access-bicycle').attr('placeholder')).to.equal('no');
expect(selection.selectAll('.preset-input-access-horse').attr('placeholder')).to.equal('no');
});
it('sets correct placeholder on a multi selection', function() {
var access = iD.uiFieldAccess(field, context);
selection.call(access);
var tags = {highway: 'primary', foot: ['yes', 'no'], bicycle: ['no', undefined], vehicle: ['no', undefined]};
tags[Symbol.for('allTags')] = [
{highway: 'primary', foot: 'yes', bicycle: 'no'},
{highway: 'primary', foot: 'no', vehicle: 'no'}
];
access.tags(tags);
expect(selection.selectAll('.preset-input-access-foot').attr('placeholder')).to.equal(iD.localizer.t('inspector.multiple_values'));
expect(selection.selectAll('.preset-input-access-bicycle').attr('placeholder')).to.equal('no');
expect(selection.selectAll('.preset-input-access-motor_vehicle').attr('placeholder')).to.equal(iD.localizer.t('inspector.multiple_values'));
});
});