Merge pull request #1225 from colouring-cities/interface/ui-tweaks
Interface/UI tweaks
This commit is contained in:
commit
95d0fbd113
@ -19,7 +19,19 @@
|
|||||||
</Style>
|
</Style>
|
||||||
<Style name="base_night_outlines">
|
<Style name="base_night_outlines">
|
||||||
<Rule>
|
<Rule>
|
||||||
<LineSymbolizer stroke="#ff0000ff" stroke-width="1" />
|
<MaxScaleDenominator>20000</MaxScaleDenominator>
|
||||||
|
<MinScaleDenominator>1200</MinScaleDenominator>
|
||||||
|
<LineSymbolizer stroke="#0081AF" stroke-width="0.5"/>
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<MaxScaleDenominator>12000</MaxScaleDenominator>
|
||||||
|
<MinScaleDenominator>8000</MinScaleDenominator>
|
||||||
|
<LineSymbolizer stroke="#0081AF" stroke-width="1.8"/>
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<MaxScaleDenominator>8000</MaxScaleDenominator>
|
||||||
|
<MinScaleDenominator>0</MinScaleDenominator>
|
||||||
|
<LineSymbolizer stroke="#0081AF" stroke-width="4.0"/>
|
||||||
</Rule>
|
</Rule>
|
||||||
</Style>
|
</Style>
|
||||||
<Style name="base_boroughs">
|
<Style name="base_boroughs">
|
||||||
@ -913,6 +925,83 @@
|
|||||||
<LineSymbolizer stroke="#888" stroke-width="3.0"/>
|
<LineSymbolizer stroke="#888" stroke-width="3.0"/>
|
||||||
</Rule>
|
</Rule>
|
||||||
</Style>
|
</Style>
|
||||||
|
<Style name="original_landuse">
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Agriculture And Fisheries"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#73ccd1" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Minerals"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#45cce3" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Unclassified, presumed non-residential"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#6c6f8e" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Recreation And Leisure"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#ffbfbf" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Transport"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#b3de69" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Utilities And Infrastructure"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#cccccc" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Residential" and not ([typology_original_use_order] = "Garden buildings") and not ([typology_original_use_order] = "Hotels, boarding and guest houses") and not ([typology_original_use_verified])</Filter>
|
||||||
|
<PolygonSymbolizer fill="#252aa6" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Residential" and not ([typology_original_use_order] = "Garden buildings") and not ([typology_original_use_order] = "Hotels, boarding and guest houses") and ([typology_original_use_verified])</Filter>
|
||||||
|
<PolygonSymbolizer fill="#7025a6" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Residential" and [typology_original_use_order] = "Hotels, boarding and guest houses"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#3c4194" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Residential" and [typology_original_use_order] = "Garden buildings" </Filter>
|
||||||
|
<PolygonSymbolizer fill="#1157fa" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Community Services"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#fa667d" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Retail"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#ff8c00" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Industry And Business"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#f5f58f" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Vacant And Derelict"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#ffffff" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Defence"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#898944" />
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<Filter>[typology_original_use_order] = "Mixed Use"</Filter>
|
||||||
|
<PolygonSymbolizer fill="#e5050d" />
|
||||||
|
</Rule>
|
||||||
|
|
||||||
|
<Rule>
|
||||||
|
<MaxScaleDenominator>8530</MaxScaleDenominator>
|
||||||
|
<MinScaleDenominator>4264</MinScaleDenominator>
|
||||||
|
<LineSymbolizer stroke="#888" stroke-width="0.8"/>
|
||||||
|
</Rule>
|
||||||
|
<Rule>
|
||||||
|
<MaxScaleDenominator>4264</MaxScaleDenominator>
|
||||||
|
<MinScaleDenominator>0</MinScaleDenominator>
|
||||||
|
<LineSymbolizer stroke="#888" stroke-width="3.0"/>
|
||||||
|
</Rule>
|
||||||
|
</Style>
|
||||||
<Style name="disaster_severity">
|
<Style name="disaster_severity">
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[disaster_severity] = "Building destroyed"</Filter>
|
<Filter>[disaster_severity] = "Building destroyed"</Filter>
|
||||||
@ -1024,47 +1113,47 @@
|
|||||||
</Style>
|
</Style>
|
||||||
<Style name="typology_style_period">
|
<Style name="typology_style_period">
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Roman (43AD-410)"</Filter>
|
<Filter>[typology_style_period] = "43AD-410 (Roman)"</Filter>
|
||||||
<PolygonSymbolizer fill="#FFF739" />
|
<PolygonSymbolizer fill="#FFF739" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Medieval (410-1485)"</Filter>
|
<Filter>[typology_style_period] = "410-1485 (Medieval)"</Filter>
|
||||||
<PolygonSymbolizer fill="#C5BD00" />
|
<PolygonSymbolizer fill="#C5BD00" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Tudor (1485-1603)"</Filter>
|
<Filter>[typology_style_period] = "1485-1603 (Tudor)"</Filter>
|
||||||
<PolygonSymbolizer fill="#FF9A39" />
|
<PolygonSymbolizer fill="#FF9A39" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Stuart (1603 -1714)"</Filter>
|
<Filter>[typology_style_period] = "1603-1714 (Stuart)"</Filter>
|
||||||
<PolygonSymbolizer fill="#C56000" />
|
<PolygonSymbolizer fill="#C56000" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Georgian (1714-1837)"</Filter>
|
<Filter>[typology_style_period] = "1714-1837 (Georgian)"</Filter>
|
||||||
<PolygonSymbolizer fill="#EA8072" />
|
<PolygonSymbolizer fill="#EA8072" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Victorian (1837-1901)"</Filter>
|
<Filter>[typology_style_period] = "1837-1901 (Victorian)"</Filter>
|
||||||
<PolygonSymbolizer fill="#A71200" />
|
<PolygonSymbolizer fill="#A71200" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Edwardian (1901-1914)"</Filter>
|
<Filter>[typology_style_period] = "1901-1914 (Edwardian)"</Filter>
|
||||||
<PolygonSymbolizer fill="#A272D4" />
|
<PolygonSymbolizer fill="#A272D4" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "WWI - WWII (1914-45)"</Filter>
|
<Filter>[typology_style_period] = "1914-1945 (WWI-WWII)"</Filter>
|
||||||
<PolygonSymbolizer fill="#3988C5" />
|
<PolygonSymbolizer fill="#3988C5" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Post war (1945-1975)"</Filter>
|
<Filter>[typology_style_period] = "1946-1979 (Post war)"</Filter>
|
||||||
<PolygonSymbolizer fill="#5ADFA2" />
|
<PolygonSymbolizer fill="#5ADFA2" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Late 20th Century (1975-2000)"</Filter>
|
<Filter>[typology_style_period] = "1980-1999 (Late 20th Century)"</Filter>
|
||||||
<PolygonSymbolizer fill="#C2F47A" />
|
<PolygonSymbolizer fill="#C2F47A" />
|
||||||
</Rule>
|
</Rule>
|
||||||
<Rule>
|
<Rule>
|
||||||
<Filter>[typology_style_period] = "Early 21st Century (2000-Present)"</Filter>
|
<Filter>[typology_style_period] = "2000-2025 (Early 21st Century)"</Filter>
|
||||||
<PolygonSymbolizer fill="#6FB40A" />
|
<PolygonSymbolizer fill="#6FB40A" />
|
||||||
</Rule>
|
</Rule>
|
||||||
|
|
||||||
|
@ -965,6 +965,14 @@ export const buildingAttributesConfig = valueType<DataFieldConfig>()({ /* eslint
|
|||||||
verify: true
|
verify: true
|
||||||
},
|
},
|
||||||
typology_original_use : {
|
typology_original_use : {
|
||||||
|
edit: true,
|
||||||
|
derivedEdit: true,
|
||||||
|
verify: true
|
||||||
|
},
|
||||||
|
typology_original_use_verified: {
|
||||||
|
edit: true,
|
||||||
|
},
|
||||||
|
typology_original_use_order : {
|
||||||
edit: true,
|
edit: true,
|
||||||
verify: true
|
verify: true
|
||||||
},
|
},
|
||||||
|
@ -9,7 +9,7 @@ import { ArgumentError } from '../../errors/general';
|
|||||||
import { updateLandUse } from './landUse';
|
import { updateLandUse } from './landUse';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Process land use classifications - derive land use order from land use groups
|
* Process current land use classifications - derive land use order from land use groups
|
||||||
*/
|
*/
|
||||||
async function processCurrentLandUseClassifications(
|
async function processCurrentLandUseClassifications(
|
||||||
buildingId: number,
|
buildingId: number,
|
||||||
@ -40,6 +40,37 @@ async function processCurrentLandUseClassifications(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process original land use classifications - derive land use order from land use groups
|
||||||
|
*/
|
||||||
|
async function processOriginalLandUseClassifications(
|
||||||
|
buildingId: number,
|
||||||
|
buildingUpdate: Partial<BuildingAttributes>,
|
||||||
|
t?: ITask<any>
|
||||||
|
): Promise<any> {
|
||||||
|
const currentBuildingData = await getBuildingData(buildingId);
|
||||||
|
|
||||||
|
try {
|
||||||
|
const currentLandUseUpdate = await updateLandUse(
|
||||||
|
{
|
||||||
|
landUseGroup: currentBuildingData.typology_original_use,
|
||||||
|
landUseOrder: currentBuildingData.typology_original_use_order
|
||||||
|
}, {
|
||||||
|
landUseGroup: buildingUpdate.typology_original_use
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
return Object.assign({}, buildingUpdate, {
|
||||||
|
typology_original_use: currentLandUseUpdate.landUseGroup,
|
||||||
|
typology_original_use_order: currentLandUseUpdate.landUseOrder,
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
if(error instanceof ArgumentError && error.argumentName === 'landUseUpdate') {
|
||||||
|
error.argumentName = 'buildingUpdate';
|
||||||
|
}
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Process Dynamics data - check field relationships and sort demolished buildings by construction date
|
* Process Dynamics data - check field relationships and sort demolished buildings by construction date
|
||||||
@ -81,6 +112,9 @@ export async function processBuildingUpdate(buildingId: number, {attributes, use
|
|||||||
if(hasAnyOwnProperty(attributes, ['current_landuse_group'])) {
|
if(hasAnyOwnProperty(attributes, ['current_landuse_group'])) {
|
||||||
attributes = await processCurrentLandUseClassifications(buildingId, attributes, t);
|
attributes = await processCurrentLandUseClassifications(buildingId, attributes, t);
|
||||||
}
|
}
|
||||||
|
if(hasAnyOwnProperty(attributes, ['typology_original_use'])) {
|
||||||
|
attributes = await processOriginalLandUseClassifications(buildingId, attributes, t);
|
||||||
|
}
|
||||||
if(hasAnyOwnProperty(attributes, ['demolished_buildings', 'dynamics_has_demolished_buildings'])) {
|
if(hasAnyOwnProperty(attributes, ['demolished_buildings', 'dynamics_has_demolished_buildings'])) {
|
||||||
attributes = await processDynamicsDemolishedBuildings(buildingId, attributes, t);
|
attributes = await processDynamicsDemolishedBuildings(buildingId, attributes, t);
|
||||||
}
|
}
|
||||||
|
@ -99,7 +99,9 @@ const withCopyEdit: (wc: React.ComponentType<CategoryViewProps>) => DataContaine
|
|||||||
'likes_total',
|
'likes_total',
|
||||||
'community_type_worth_keeping_total',
|
'community_type_worth_keeping_total',
|
||||||
'community_local_significance_total',
|
'community_local_significance_total',
|
||||||
'community_expected_planning_application_total'
|
'community_expected_planning_application_total',
|
||||||
|
'typology_original_use',
|
||||||
|
'typology_original_use_verified'
|
||||||
]
|
]
|
||||||
for (let key in dataFields) {
|
for (let key in dataFields) {
|
||||||
let fieldName = props.building == undefined ? undefined : props.building[key];
|
let fieldName = props.building == undefined ? undefined : props.building[key];
|
||||||
@ -286,6 +288,13 @@ const withCopyEdit: (wc: React.ComponentType<CategoryViewProps>) => DataContaine
|
|||||||
|
|
||||||
this.doSubmit(edits);
|
this.doSubmit(edits);
|
||||||
}
|
}
|
||||||
|
if (slug == 'typology_original_use'){
|
||||||
|
const edits = {
|
||||||
|
'typology_original_use_verified': true
|
||||||
|
};
|
||||||
|
|
||||||
|
this.doSubmit(edits);
|
||||||
|
}
|
||||||
console.log(slug + " verify button clicked")
|
console.log(slug + " verify button clicked")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import React, { Fragment } from 'react';
|
import React, { Fragment } from 'react';
|
||||||
|
|
||||||
import '../../map/map-button.css';
|
import '../../map/map-button.css';
|
||||||
import { dataFields } from '../../config/data-fields-config';
|
import { commonSourceTypes, dataFields } from '../../config/data-fields-config';
|
||||||
import { MultiDataEntry } from '../data-components/multi-data-entry/multi-data-entry';
|
import { MultiDataEntry } from '../data-components/multi-data-entry/multi-data-entry';
|
||||||
import { DataEntryGroup } from '../data-components/data-entry-group';
|
import { DataEntryGroup } from '../data-components/data-entry-group';
|
||||||
import { DynamicsBuildingPane, DynamicsDataEntry } from './dynamics/dynamics-data-entry';
|
import { DynamicsBuildingPane, DynamicsDataEntry } from './dynamics/dynamics-data-entry';
|
||||||
@ -40,23 +40,47 @@ const AgeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
const ageLinkUrl = `/${props.mode}/${Category.Age}/${props.building.building_id}`;
|
const ageLinkUrl = `/${props.mode}/${Category.Age}/${props.building.building_id}`;
|
||||||
|
|
||||||
const { historicData, historicDataSwitchOnClick, darkLightTheme } = useDisplayPreferences();
|
const { historicData, historicDataSwitchOnClick, darkLightTheme } = useDisplayPreferences();
|
||||||
|
const { historicMap, historicMapSwitchOnClick } = useDisplayPreferences();
|
||||||
|
|
||||||
const switchToSurvivalMapStyle = (e) => {
|
const switchToSurvivalMapStyle = (e) => {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
props.onMapColourScale('survival_status');
|
||||||
|
historicMapSwitchOnClick(e);
|
||||||
|
|
||||||
if (props.mapColourScale == "survival_status") {
|
if (historicData === 'enabled') {
|
||||||
props.onMapColourScale('date_year');
|
|
||||||
historicDataSwitchOnClick(e);
|
historicDataSwitchOnClick(e);
|
||||||
}
|
}
|
||||||
else {
|
}
|
||||||
|
|
||||||
|
const switchToSurvivalDataStyle = (e) => {
|
||||||
|
e.preventDefault();
|
||||||
props.onMapColourScale('survival_status');
|
props.onMapColourScale('survival_status');
|
||||||
historicDataSwitchOnClick(e);
|
historicDataSwitchOnClick(e);
|
||||||
|
|
||||||
|
if (historicMap === 'enabled') {
|
||||||
|
historicMapSwitchOnClick(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const switchToAgeMapStyle = (e) => {
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
if (props.mapColourScale == "survival_status")
|
||||||
|
{
|
||||||
|
historicDataSwitchOnClick(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
props.onMapColourScale('date_year')
|
||||||
|
}
|
||||||
|
|
||||||
|
const switchToStylePeriodMapStyle = (e) => {
|
||||||
|
e.preventDefault();
|
||||||
|
props.onMapColourScale('typology_style_period')
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Fragment>
|
<Fragment>
|
||||||
<DataEntryGroup name="Building age">
|
<DataEntryGroup name="Building age/construction date">
|
||||||
<YearDataEntry
|
<YearDataEntry
|
||||||
year={props.building.date_year}
|
year={props.building.date_year}
|
||||||
upper={props.building.date_upper}
|
upper={props.building.date_upper}
|
||||||
@ -171,6 +195,64 @@ const AgeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
tooltip='Coming Soon'
|
tooltip='Coming Soon'
|
||||||
/>*/}
|
/>*/}
|
||||||
</DataEntryGroup>
|
</DataEntryGroup>
|
||||||
|
<DataEntryGroup name="Architectural style">
|
||||||
|
{(props.mapColourScale == "typology_style_period") ?
|
||||||
|
<button className={`map-switcher-inline enabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToAgeMapStyle}>
|
||||||
|
Click here to return to building age.
|
||||||
|
</button>
|
||||||
|
:
|
||||||
|
<button className={`map-switcher-inline disabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToStylePeriodMapStyle}>
|
||||||
|
Click here to show architectural style.
|
||||||
|
</button>
|
||||||
|
}
|
||||||
|
<SelectDataEntry
|
||||||
|
title={dataFields.typology_style_period.title}
|
||||||
|
slug="typology_style_period"
|
||||||
|
value={props.building.typology_style_period}
|
||||||
|
tooltip={dataFields.typology_style_period.tooltip}
|
||||||
|
options={dataFields.typology_style_period.items}
|
||||||
|
mode={props.mode}
|
||||||
|
copy={props.copy}
|
||||||
|
onChange={props.onChange}
|
||||||
|
/>
|
||||||
|
<Verification
|
||||||
|
slug="typology_style_period"
|
||||||
|
allow_verify={props.user !== undefined && props.building.typology_style_period !== null && !props.edited}
|
||||||
|
onVerify={props.onVerify}
|
||||||
|
user_verified={props.user_verified.hasOwnProperty("typology_style_period")}
|
||||||
|
user_verified_as={props.user_verified.typology_style_period}
|
||||||
|
verified_count={props.building.verified.typology_style_period}
|
||||||
|
/>
|
||||||
|
<SelectDataEntry
|
||||||
|
title={dataFields.typology_style_period_source_type.title}
|
||||||
|
slug="typology_style_period_source_type"
|
||||||
|
value={props.building.typology_style_period_source_type}
|
||||||
|
mode={props.mode}
|
||||||
|
copy={props.copy}
|
||||||
|
onChange={props.onChange}
|
||||||
|
tooltip={dataFields.typology_style_period_source_type.tooltip}
|
||||||
|
placeholder={dataFields.typology_style_period_source_type.example}
|
||||||
|
options={dataFields.typology_style_period_source_type.items}
|
||||||
|
/>
|
||||||
|
{(props.building.typology_style_period_source_type == commonSourceTypes[0] ||
|
||||||
|
props.building.typology_style_period_source_type == commonSourceTypes[1] ||
|
||||||
|
props.building.typology_style_period_source_type == null) ? <></> :
|
||||||
|
<>
|
||||||
|
<MultiDataEntry
|
||||||
|
title={dataFields.typology_style_period_source_links.title}
|
||||||
|
slug="typology_style_period_source_links"
|
||||||
|
value={props.building.typology_style_period_source_links}
|
||||||
|
mode={props.mode}
|
||||||
|
copy={props.copy}
|
||||||
|
onChange={props.onChange}
|
||||||
|
tooltip={dataFields.typology_style_period_source_links.tooltip}
|
||||||
|
placeholder="https://..."
|
||||||
|
editableEntries={true}
|
||||||
|
isUrl={true}
|
||||||
|
/>
|
||||||
|
</>
|
||||||
|
}
|
||||||
|
</DataEntryGroup>
|
||||||
<DataEntryGroup name="Cladding, extensions and retrofits">
|
<DataEntryGroup name="Cladding, extensions and retrofits">
|
||||||
<NumericDataEntry
|
<NumericDataEntry
|
||||||
slug='age_cladding_date'
|
slug='age_cladding_date'
|
||||||
@ -323,9 +405,6 @@ const AgeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
}
|
}
|
||||||
</DataEntryGroup>
|
</DataEntryGroup>
|
||||||
<DataEntryGroup name="Lifespan and site history">
|
<DataEntryGroup name="Lifespan and site history">
|
||||||
<button className={`map-switcher-inline ${props.mapColourScale == "survival_status" ? "enabled-state" : "disabled-state"} btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToSurvivalMapStyle}>
|
|
||||||
{(props.mapColourScale == "is_domestic")? 'Click here to hide historical maps':'Click here to show historical maps'}
|
|
||||||
</button>
|
|
||||||
<DataEntryGroup name="Constructions and demolitions on this site" showCount={false}>
|
<DataEntryGroup name="Constructions and demolitions on this site" showCount={false}>
|
||||||
<DynamicsBuildingPane>
|
<DynamicsBuildingPane>
|
||||||
<label>Current building (age data <Link to={ageLinkUrl}>editable here</Link>)</label>
|
<label>Current building (age data <Link to={ageLinkUrl}>editable here</Link>)</label>
|
||||||
@ -419,9 +498,24 @@ const AgeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
Choose a colour to indicate whether the building has survived.
|
Choose a colour to indicate whether the building has survived.
|
||||||
</i>
|
</i>
|
||||||
</div>
|
</div>
|
||||||
<button className={`map-switcher-inline ${props.mapColourScale == "survival_status" ? "enabled-state" : "disabled-state"} btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToSurvivalMapStyle}>
|
{(historicMap == "enabled") ?
|
||||||
{(props.mapColourScale == "is_domestic")? 'Click here to hide historical maps':'Click here to show historical maps'}
|
<button className={`map-switcher-inline enabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToAgeMapStyle}>
|
||||||
|
Click here to hide the 1890s OS historical map.
|
||||||
</button>
|
</button>
|
||||||
|
:
|
||||||
|
<button className={`map-switcher-inline disabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToSurvivalMapStyle}>
|
||||||
|
Click here to show the 1890s OS historical map.
|
||||||
|
</button>
|
||||||
|
}
|
||||||
|
{(historicData == "enabled") ?
|
||||||
|
<button className={`map-switcher-inline enabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToAgeMapStyle}>
|
||||||
|
Click here to hide the 1890s OS historical map with modern footprints.
|
||||||
|
</button>
|
||||||
|
:
|
||||||
|
<button className={`map-switcher-inline disabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToSurvivalDataStyle}>
|
||||||
|
Click here to show the 1890s OS historical map with modern footprints.
|
||||||
|
</button>
|
||||||
|
}
|
||||||
<SelectDataEntry
|
<SelectDataEntry
|
||||||
title={dataFields.survival_status.title}
|
title={dataFields.survival_status.title}
|
||||||
slug="survival_status"
|
slug="survival_status"
|
||||||
|
@ -138,6 +138,7 @@ const UseView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
/>
|
/>
|
||||||
</>
|
</>
|
||||||
}
|
}
|
||||||
|
<hr/>
|
||||||
{
|
{
|
||||||
props.mode != 'view' &&
|
props.mode != 'view' &&
|
||||||
<div>
|
<div>
|
||||||
|
@ -13,13 +13,6 @@ import { DataEntryGroup } from '../data-components/data-entry-group';
|
|||||||
import { MultiDataEntry } from '../data-components/multi-data-entry/multi-data-entry';
|
import { MultiDataEntry } from '../data-components/multi-data-entry/multi-data-entry';
|
||||||
import { useDisplayPreferences } from '../../displayPreferences-context';
|
import { useDisplayPreferences } from '../../displayPreferences-context';
|
||||||
|
|
||||||
const AttachmentFormOptions = [
|
|
||||||
"Detached",
|
|
||||||
"Semi-Detached",
|
|
||||||
"End-Terrace",
|
|
||||||
"Mid-Terrace"
|
|
||||||
];
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Type view/edit section
|
* Type view/edit section
|
||||||
*/
|
*/
|
||||||
@ -42,6 +35,10 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
props.onMapColourScale('building_attachment_form')
|
props.onMapColourScale('building_attachment_form')
|
||||||
}
|
}
|
||||||
|
const switchToLandUseMapStyle = (e) => {
|
||||||
|
e.preventDefault();
|
||||||
|
props.onMapColourScale('original_landuse')
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Fragment>
|
<Fragment>
|
||||||
@ -103,8 +100,8 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
</>
|
</>
|
||||||
}
|
}
|
||||||
</DataEntryGroup>
|
</DataEntryGroup>
|
||||||
<DataEntryGroup name="Architectural style/Historical period">
|
<DataEntryGroup name="Architectural style">
|
||||||
{(props.mapColourScale == "typology_style_period") ?
|
{/*(props.mapColourScale == "typology_style_period") ?
|
||||||
<button className={`map-switcher-inline enabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToClassificationMapStyle}>
|
<button className={`map-switcher-inline enabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToClassificationMapStyle}>
|
||||||
{'Click to change map to show typology classification.'}
|
{'Click to change map to show typology classification.'}
|
||||||
</button>
|
</button>
|
||||||
@ -112,7 +109,7 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
<button className={`map-switcher-inline disabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToStylePeriodMapStyle}>
|
<button className={`map-switcher-inline disabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToStylePeriodMapStyle}>
|
||||||
{"Click here to change map to show architectural style/historical period."}
|
{"Click here to change map to show architectural style/historical period."}
|
||||||
</button>
|
</button>
|
||||||
}
|
*/}
|
||||||
<SelectDataEntry
|
<SelectDataEntry
|
||||||
title={dataFields.typology_style_period.title}
|
title={dataFields.typology_style_period.title}
|
||||||
slug="typology_style_period"
|
slug="typology_style_period"
|
||||||
@ -122,7 +119,9 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
mode={props.mode}
|
mode={props.mode}
|
||||||
copy={props.copy}
|
copy={props.copy}
|
||||||
onChange={props.onChange}
|
onChange={props.onChange}
|
||||||
|
disabled={true}
|
||||||
/>
|
/>
|
||||||
|
{/*
|
||||||
<Verification
|
<Verification
|
||||||
slug="typology_style_period"
|
slug="typology_style_period"
|
||||||
allow_verify={props.user !== undefined && props.building.typology_style_period !== null && !props.edited}
|
allow_verify={props.user !== undefined && props.building.typology_style_period !== null && !props.edited}
|
||||||
@ -130,11 +129,11 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
user_verified={props.user_verified.hasOwnProperty("typology_style_period")}
|
user_verified={props.user_verified.hasOwnProperty("typology_style_period")}
|
||||||
user_verified_as={props.user_verified.typology_style_period}
|
user_verified_as={props.user_verified.typology_style_period}
|
||||||
verified_count={props.building.verified.typology_style_period}
|
verified_count={props.building.verified.typology_style_period}
|
||||||
/>
|
/> */}
|
||||||
<div className={`alert alert-dark`} role="alert" style={{ fontSize: 14, backgroundColor: "#f6f8f9" }}>
|
<div className={`alert alert-dark`} role="alert" style={{ fontSize: 14, backgroundColor: "#f6f8f9" }}>
|
||||||
<i className="source-url">For building age by year see <a href={"http://localhost:8080/edit/age/"+props.building.building_id}>Age & History</a>.</i>
|
<i className="source-url">To edit the architectural style box, and to see the data mapped, please go to <a href={"/"+props.mode+"/age/"+props.building.building_id}>Age & History</a>.</i>
|
||||||
</div>
|
</div>
|
||||||
<SelectDataEntry
|
{/* <SelectDataEntry
|
||||||
title={dataFields.typology_style_period_source_type.title}
|
title={dataFields.typology_style_period_source_type.title}
|
||||||
slug="typology_style_period_source_type"
|
slug="typology_style_period_source_type"
|
||||||
value={props.building.typology_style_period_source_type}
|
value={props.building.typology_style_period_source_type}
|
||||||
@ -162,7 +161,7 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
isUrl={true}
|
isUrl={true}
|
||||||
/>
|
/>
|
||||||
</>
|
</>
|
||||||
}
|
} */}
|
||||||
</DataEntryGroup>
|
</DataEntryGroup>
|
||||||
<DataEntryGroup name="Dynamic tissue classification">
|
<DataEntryGroup name="Dynamic tissue classification">
|
||||||
{(props.mapColourScale == "typology_dynamic_classification") ?
|
{(props.mapColourScale == "typology_dynamic_classification") ?
|
||||||
@ -223,6 +222,15 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
}
|
}
|
||||||
</DataEntryGroup>
|
</DataEntryGroup>
|
||||||
<DataEntryGroup name="Original Use">
|
<DataEntryGroup name="Original Use">
|
||||||
|
{(props.mapColourScale == "original_landuse") ?
|
||||||
|
<button className={`map-switcher-inline enabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToClassificationMapStyle}>
|
||||||
|
{'Click to change map to show typology classification.'}
|
||||||
|
</button>
|
||||||
|
:
|
||||||
|
<button className={`map-switcher-inline disabled-state btn btn-outline btn-outline-dark ${darkLightTheme}`} onClick={switchToLandUseMapStyle}>
|
||||||
|
{"Click here to change map to original land use."}
|
||||||
|
</button>
|
||||||
|
}
|
||||||
<MultiDataEntry
|
<MultiDataEntry
|
||||||
title={dataFields.typology_original_use.title}
|
title={dataFields.typology_original_use.title}
|
||||||
slug="typology_original_use"
|
slug="typology_original_use"
|
||||||
@ -274,6 +282,27 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
/>
|
/>
|
||||||
</>
|
</>
|
||||||
}
|
}
|
||||||
|
<hr/>
|
||||||
|
{
|
||||||
|
props.mode != 'view' &&
|
||||||
|
<div>
|
||||||
|
<div className={`alert alert-dark`} role="alert" style={{ fontSize: 13, backgroundColor: "#f6f8f9" }}>
|
||||||
|
<i>
|
||||||
|
Below is a more general classification for the original land use of this building, automatically derived from the information above.
|
||||||
|
</i>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
<DataEntry
|
||||||
|
title={dataFields.typology_original_use_order.title}
|
||||||
|
tooltip={dataFields.typology_original_use_order.tooltip}
|
||||||
|
slug="typology_original_use_order"
|
||||||
|
value={props.building.typology_original_use_order}
|
||||||
|
mode={props.mode}
|
||||||
|
disabled={true}
|
||||||
|
copy={props.copy}
|
||||||
|
onChange={props.onChange}
|
||||||
|
/>
|
||||||
</DataEntryGroup>
|
</DataEntryGroup>
|
||||||
<DataEntryGroup name="Attachment/Adjacency">
|
<DataEntryGroup name="Attachment/Adjacency">
|
||||||
{(props.mapColourScale == "building_attachment_form") ?
|
{(props.mapColourScale == "building_attachment_form") ?
|
||||||
@ -290,7 +319,7 @@ const TypeView: React.FunctionComponent<CategoryViewProps> = (props) => {
|
|||||||
slug="building_attachment_form"
|
slug="building_attachment_form"
|
||||||
value={props.building.building_attachment_form}
|
value={props.building.building_attachment_form}
|
||||||
tooltip={dataFields.building_attachment_form.tooltip}
|
tooltip={dataFields.building_attachment_form.tooltip}
|
||||||
options={AttachmentFormOptions}
|
options={dataFields.building_attachment_form.items}
|
||||||
mode={props.mode}
|
mode={props.mode}
|
||||||
copy={props.copy}
|
copy={props.copy}
|
||||||
onChange={props.onChange}
|
onChange={props.onChange}
|
||||||
|
@ -48,6 +48,25 @@ export const categoryMapsConfig: {[key in Category]: CategoryMapDefinition[]} =
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
mapStyle: 'typology_style_period',
|
||||||
|
legend: {
|
||||||
|
title: 'Architectural style',
|
||||||
|
elements: [
|
||||||
|
{ color: '#FFF739', text: '43AD-410 (Roman)' },
|
||||||
|
{ color: '#C5BD00', text: '410-1485 (Medieval)' },
|
||||||
|
{ color: '#FF9A39', text: '1485-1603 (Tudor)' },
|
||||||
|
{ color: '#C56000', text: '1603-1714 (Stuart)' },
|
||||||
|
{ color: '#EA8072', text: '1714-1837 (Georgian)' },
|
||||||
|
{ color: '#A71200', text: '1837-1901 (Victorian)' },
|
||||||
|
{ color: '#A272D4', text: '1901-1914 (Edwardian)' },
|
||||||
|
{ color: '#3988C5', text: '1914-1945 (WWI-WWII)' },
|
||||||
|
{ color: '#5ADFA2', text: '1946-1979 (Post war)' },
|
||||||
|
{ color: '#C2F47A', text: '1980-1999 (Late C20)' },
|
||||||
|
{ color: '#6FB40A', text: '2000-2025 (Early C21)' },
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
mapStyle: 'survival_status',
|
mapStyle: 'survival_status',
|
||||||
legend: {
|
legend: {
|
||||||
@ -317,25 +336,25 @@ export const categoryMapsConfig: {[key in Category]: CategoryMapDefinition[]} =
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
/*{
|
||||||
mapStyle: 'typology_style_period',
|
mapStyle: 'typology_style_period',
|
||||||
legend: {
|
legend: {
|
||||||
title: 'Architectural style',
|
title: 'Architectural style',
|
||||||
elements: [
|
elements: [
|
||||||
{ color: '#FFF739', text: 'Roman (43AD-410)' },
|
{ color: '#FFF739', text: '43AD-410 (Roman)' },
|
||||||
{ color: '#C5BD00', text: 'Medieval (410-1485)' },
|
{ color: '#C5BD00', text: '410-1485 (Medieval)' },
|
||||||
{ color: '#FF9A39', text: 'Tudor (1485-1603)' },
|
{ color: '#FF9A39', text: '1485-1603 (Tudor)' },
|
||||||
{ color: '#C56000', text: 'Stuart (1603 -1714)' },
|
{ color: '#C56000', text: '1603-1714 (Stuart)' },
|
||||||
{ color: '#EA8072', text: 'Georgian (1714-1837)' },
|
{ color: '#EA8072', text: '1714-1837 (Georgian)' },
|
||||||
{ color: '#A71200', text: 'Victorian (1837-1901)' },
|
{ color: '#A71200', text: '1837-1901 (Victorian)' },
|
||||||
{ color: '#A272D4', text: 'Edwardian (1901-1914)' },
|
{ color: '#A272D4', text: '1901-1914 (Edwardian)' },
|
||||||
{ color: '#3988C5', text: 'WWI - WWII (1914-45)' },
|
{ color: '#3988C5', text: '1914-1945 (WWI-WWII)' },
|
||||||
{ color: '#5ADFA2', text: 'Post war (1945-1975)' },
|
{ color: '#5ADFA2', text: '1946-1979 (Post war)' },
|
||||||
{ color: '#C2F47A', text: 'Late C20th (1975-2000)' },
|
{ color: '#C2F47A', text: '1980-1999 (Late C20)' },
|
||||||
{ color: '#6FB40A', text: 'Early C21st (2000- )' },
|
{ color: '#6FB40A', text: '2000-2025 (Early C21)' },
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},*/
|
||||||
{
|
{
|
||||||
mapStyle: 'typology_dynamic_classification',
|
mapStyle: 'typology_dynamic_classification',
|
||||||
legend: {
|
legend: {
|
||||||
@ -348,6 +367,29 @@ export const categoryMapsConfig: {[key in Category]: CategoryMapDefinition[]} =
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
mapStyle: 'original_landuse',
|
||||||
|
legend: {
|
||||||
|
title: 'Original Land Use',
|
||||||
|
elements: [
|
||||||
|
{ color: '#e5050d', text: 'Mixed Use' },
|
||||||
|
{ subtitle: 'Single use:'},
|
||||||
|
{ color: '#252aa6', text: 'Residential (unverified)' },
|
||||||
|
{ color: '#7025a6', text: 'Residential (verified)' },
|
||||||
|
{ color: '#ff8c00', text: 'Retail' },
|
||||||
|
{ color: '#f5f58f', text: 'Industry & Business' },
|
||||||
|
{ color: '#fa667d', text: 'Community Services' },
|
||||||
|
{ color: '#ffbfbf', text: 'Recreation & Leisure' },
|
||||||
|
{ color: '#b3de69', text: 'Transport' },
|
||||||
|
{ color: '#cccccc', text: 'Utilities & Infrastructure' },
|
||||||
|
{ color: '#898944', text: 'Defence' },
|
||||||
|
{ color: '#73ccd1', text: 'Agriculture' },
|
||||||
|
{ color: '#45cce3', text: 'Minerals' },
|
||||||
|
{ color: '#ffffff', text: 'Vacant & Derelict' },
|
||||||
|
{ color: '#6c6f8e', text: 'Unclassified, presumed non-residential' }
|
||||||
|
]
|
||||||
|
},
|
||||||
|
},
|
||||||
{
|
{
|
||||||
mapStyle: 'building_attachment_form',
|
mapStyle: 'building_attachment_form',
|
||||||
legend: {
|
legend: {
|
||||||
|
@ -314,6 +314,12 @@ export const dataFields = { /* eslint-disable @typescript-eslint/camelcase */
|
|||||||
title: "Which description best explains the way the building is attached to others?",
|
title: "Which description best explains the way the building is attached to others?",
|
||||||
tooltip: "We have prepopulated these based on their current attachment. A building can either be detached, semi-detached or part of a terrace (middle or end)",
|
tooltip: "We have prepopulated these based on their current attachment. A building can either be detached, semi-detached or part of a terrace (middle or end)",
|
||||||
example: "",
|
example: "",
|
||||||
|
items: [
|
||||||
|
"Detached",
|
||||||
|
"Semi-Detached",
|
||||||
|
"End-Terrace",
|
||||||
|
"Mid-Terrace"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
building_attachment_source_type: {
|
building_attachment_source_type: {
|
||||||
category: Category.Age,
|
category: Category.Age,
|
||||||
@ -1770,17 +1776,17 @@ export const dataFields = { /* eslint-disable @typescript-eslint/camelcase */
|
|||||||
tooltip: "",
|
tooltip: "",
|
||||||
example: "Georgian (1714-1837)",
|
example: "Georgian (1714-1837)",
|
||||||
items: [
|
items: [
|
||||||
'Roman (43AD-410)',
|
'43AD-410 (Roman)',
|
||||||
'Medieval (410-1485)',
|
'410-1485 (Medieval)',
|
||||||
'Tudor (1485-1603)',
|
'1485-1603 (Tudor)',
|
||||||
'Stuart (1603 -1714)',
|
'1603-1714 (Stuart)',
|
||||||
'Georgian (1714-1837)',
|
'1714-1837 (Georgian)',
|
||||||
'Victorian (1837-1901)',
|
'1837-1901 (Victorian)',
|
||||||
'Edwardian (1901-1914)',
|
'1901-1914 (Edwardian)',
|
||||||
'WWI - WWII (1914-45)',,
|
'1914-1945 (WWI-WWII)',,
|
||||||
'Post war (1945-1975)',
|
'1946-1979 (Post war)',
|
||||||
'Late 20th Century (1975-2000)',
|
'1980-1999 (Late 20th Century)',
|
||||||
'Early 21st Century (2000-Present)',
|
'2000-2025 (Early 21st Century)',
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
typology_style_period_source_type: {
|
typology_style_period_source_type: {
|
||||||
@ -1827,6 +1833,17 @@ export const dataFields = { /* eslint-disable @typescript-eslint/camelcase */
|
|||||||
tooltip: "Land use Groups as classified by [NLUD](https://www.gov.uk/government/statistics/national-land-use-database-land-use-and-land-cover-classification)",
|
tooltip: "Land use Groups as classified by [NLUD](https://www.gov.uk/government/statistics/national-land-use-database-land-use-and-land-cover-classification)",
|
||||||
example: ["", ""],
|
example: ["", ""],
|
||||||
},
|
},
|
||||||
|
typology_original_use_verified: {
|
||||||
|
category: Category.LandUse,
|
||||||
|
title: 'Has this land use been manually verified?',
|
||||||
|
example: true,
|
||||||
|
},
|
||||||
|
typology_original_use_order: {
|
||||||
|
category: Category.Typology,
|
||||||
|
title: "Original land use (order)",
|
||||||
|
tooltip: "Land use Order as classified by [NLUD](https://www.gov.uk/government/statistics/national-land-use-database-land-use-and-land-cover-classification)",
|
||||||
|
example: "",
|
||||||
|
},
|
||||||
typology_original_use_source_type: {
|
typology_original_use_source_type: {
|
||||||
category: Category.Typology,
|
category: Category.Typology,
|
||||||
title: "Source type",
|
title: "Source type",
|
||||||
|
@ -21,6 +21,7 @@ export type BuildingMapTileset =
|
|||||||
'sust_dec' |
|
'sust_dec' |
|
||||||
'building_attachment_form' |
|
'building_attachment_form' |
|
||||||
'landuse' |
|
'landuse' |
|
||||||
|
'original_landuse' |
|
||||||
'dynamics_demolished_count' |
|
'dynamics_demolished_count' |
|
||||||
'disaster_severity' |
|
'disaster_severity' |
|
||||||
'team' |
|
'team' |
|
||||||
|
@ -38,6 +38,10 @@ interface DisplayPreferencesContextState {
|
|||||||
historicDataSwitch: (e: React.FormEvent<HTMLFormElement>) => void;
|
historicDataSwitch: (e: React.FormEvent<HTMLFormElement>) => void;
|
||||||
historicDataSwitchOnClick: React.MouseEventHandler<HTMLButtonElement>;
|
historicDataSwitchOnClick: React.MouseEventHandler<HTMLButtonElement>;
|
||||||
|
|
||||||
|
historicMap: LayerEnablementState;
|
||||||
|
historicMapSwitch: (e: React.FormEvent<HTMLFormElement>) => void;
|
||||||
|
historicMapSwitchOnClick: React.MouseEventHandler<HTMLButtonElement>;
|
||||||
|
|
||||||
darkLightTheme: MapTheme;
|
darkLightTheme: MapTheme;
|
||||||
darkLightThemeSwitch: (e: React.FormEvent<HTMLFormElement>) => void;
|
darkLightThemeSwitch: (e: React.FormEvent<HTMLFormElement>) => void;
|
||||||
darkLightThemeSwitchOnClick: React.MouseEventHandler<HTMLButtonElement>;
|
darkLightThemeSwitchOnClick: React.MouseEventHandler<HTMLButtonElement>;
|
||||||
@ -87,6 +91,10 @@ export const DisplayPreferencesContext = createContext<DisplayPreferencesContext
|
|||||||
historicDataSwitch: stub,
|
historicDataSwitch: stub,
|
||||||
historicDataSwitchOnClick: undefined,
|
historicDataSwitchOnClick: undefined,
|
||||||
|
|
||||||
|
historicMap: undefined,
|
||||||
|
historicMapSwitch: stub,
|
||||||
|
historicMapSwitchOnClick: undefined,
|
||||||
|
|
||||||
darkLightTheme: undefined,
|
darkLightTheme: undefined,
|
||||||
darkLightThemeSwitch: stub,
|
darkLightThemeSwitch: stub,
|
||||||
darkLightThemeSwitchOnClick: undefined,
|
darkLightThemeSwitchOnClick: undefined,
|
||||||
@ -107,6 +115,7 @@ export const DisplayPreferencesProvider: React.FC<{}> = ({children}) => {
|
|||||||
const defaultParcel = 'disabled'
|
const defaultParcel = 'disabled'
|
||||||
const defaultConservation = 'disabled'
|
const defaultConservation = 'disabled'
|
||||||
const defaultHistoricData = 'disabled'
|
const defaultHistoricData = 'disabled'
|
||||||
|
const defaultHistoricMap = 'disabled'
|
||||||
const defaultShowLayerSelection = 'disabled'
|
const defaultShowLayerSelection = 'disabled'
|
||||||
const [vista, setVista] = useState<LayerEnablementState>(defaultVista);
|
const [vista, setVista] = useState<LayerEnablementState>(defaultVista);
|
||||||
const [flood, setFlood] = useState<LayerEnablementState>(defaultFlood);
|
const [flood, setFlood] = useState<LayerEnablementState>(defaultFlood);
|
||||||
@ -116,6 +125,7 @@ export const DisplayPreferencesProvider: React.FC<{}> = ({children}) => {
|
|||||||
const [parcel, setParcel] = useState<LayerEnablementState>(defaultParcel);
|
const [parcel, setParcel] = useState<LayerEnablementState>(defaultParcel);
|
||||||
const [conservation, setConservation] = useState<LayerEnablementState>(defaultConservation);
|
const [conservation, setConservation] = useState<LayerEnablementState>(defaultConservation);
|
||||||
const [historicData, setHistoricData] = useState<LayerEnablementState>(defaultHistoricData);
|
const [historicData, setHistoricData] = useState<LayerEnablementState>(defaultHistoricData);
|
||||||
|
const [historicMap, setHistoricMap] = useState<LayerEnablementState>(defaultHistoricMap);
|
||||||
const [darkLightTheme, setDarkLightTheme] = useState<MapTheme>('night');
|
const [darkLightTheme, setDarkLightTheme] = useState<MapTheme>('night');
|
||||||
const [showLayerSelection, setShowLayerSelection] = useState<LayerEnablementState>(defaultShowLayerSelection);
|
const [showLayerSelection, setShowLayerSelection] = useState<LayerEnablementState>(defaultShowLayerSelection);
|
||||||
|
|
||||||
@ -136,6 +146,7 @@ export const DisplayPreferencesProvider: React.FC<{}> = ({children}) => {
|
|||||||
setParcel(defaultParcel);
|
setParcel(defaultParcel);
|
||||||
setConservation(defaultConservation);
|
setConservation(defaultConservation);
|
||||||
setHistoricData(defaultHistoricData);
|
setHistoricData(defaultHistoricData);
|
||||||
|
setHistoricMap(defaultHistoricMap);
|
||||||
setShowLayerSelection(defaultShowLayerSelection); // reset layers + hiding this panel is integrated into one action
|
setShowLayerSelection(defaultShowLayerSelection); // reset layers + hiding this panel is integrated into one action
|
||||||
//setDarkLightTheme('night'); // reset only layers
|
//setDarkLightTheme('night'); // reset only layers
|
||||||
},
|
},
|
||||||
@ -167,6 +178,9 @@ export const DisplayPreferencesProvider: React.FC<{}> = ({children}) => {
|
|||||||
if(historicData != defaultHistoricData) {
|
if(historicData != defaultHistoricData) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
if(historicMap != defaultHistoricMap) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
//darkLightTheme not handled here
|
//darkLightTheme not handled here
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -278,7 +292,10 @@ export const DisplayPreferencesProvider: React.FC<{}> = ({children}) => {
|
|||||||
|
|
||||||
const historicDataSwitch = useCallback(
|
const historicDataSwitch = useCallback(
|
||||||
(e) => {
|
(e) => {
|
||||||
flipHistoricData(e)
|
if (historicMap === 'enabled') {
|
||||||
|
fliphistoricMap(e);
|
||||||
|
}
|
||||||
|
flipHistoricData(e);
|
||||||
},
|
},
|
||||||
[historicData],
|
[historicData],
|
||||||
)
|
)
|
||||||
@ -291,6 +308,24 @@ export const DisplayPreferencesProvider: React.FC<{}> = ({children}) => {
|
|||||||
setHistoricData(newHistoric);
|
setHistoricData(newHistoric);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const historicMapSwitch = useCallback(
|
||||||
|
(e) => {
|
||||||
|
if (historicData === 'enabled') {
|
||||||
|
flipHistoricData(e);
|
||||||
|
}
|
||||||
|
fliphistoricMap(e);
|
||||||
|
},
|
||||||
|
[historicMap],
|
||||||
|
)
|
||||||
|
const historicMapSwitchOnClick = (e) => {
|
||||||
|
fliphistoricMap(e)
|
||||||
|
}
|
||||||
|
function fliphistoricMap(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
const newHistoric = (historicMap === 'enabled')? 'disabled' : 'enabled';
|
||||||
|
setHistoricMap(newHistoric);
|
||||||
|
}
|
||||||
|
|
||||||
const darkLightThemeSwitch = useCallback(
|
const darkLightThemeSwitch = useCallback(
|
||||||
(e) => {
|
(e) => {
|
||||||
flipDarkLightTheme(e)
|
flipDarkLightTheme(e)
|
||||||
@ -354,6 +389,10 @@ export const DisplayPreferencesProvider: React.FC<{}> = ({children}) => {
|
|||||||
historicDataSwitch,
|
historicDataSwitch,
|
||||||
historicDataSwitchOnClick,
|
historicDataSwitchOnClick,
|
||||||
|
|
||||||
|
historicMap,
|
||||||
|
historicMapSwitch,
|
||||||
|
historicMapSwitchOnClick,
|
||||||
|
|
||||||
darkLightTheme,
|
darkLightTheme,
|
||||||
darkLightThemeSwitch,
|
darkLightThemeSwitch,
|
||||||
darkLightThemeSwitchOnClick,
|
darkLightThemeSwitchOnClick,
|
||||||
|
@ -5,11 +5,12 @@ import { useDisplayPreferences } from '../displayPreferences-context';
|
|||||||
|
|
||||||
export const HistoricDataSwitcher: React.FC<{}> = (props) => {
|
export const HistoricDataSwitcher: React.FC<{}> = (props) => {
|
||||||
const { historicData, historicDataSwitch, darkLightTheme } = useDisplayPreferences();
|
const { historicData, historicDataSwitch, darkLightTheme } = useDisplayPreferences();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<form className={`historic-data-switcher map-button ${historicData}-state ${darkLightTheme}`} onSubmit={historicDataSwitch}>
|
<form className={`historic-data-switcher map-button ${historicData}-state ${darkLightTheme}`} onSubmit={historicDataSwitch}>
|
||||||
<button className="btn btn-outline btn-outline-dark"
|
<button className="btn btn-outline btn-outline-dark"
|
||||||
type="submit">
|
type="submit">
|
||||||
{(historicData === 'enabled')? 'The OS 1890s Historical Map on' : 'The OS 1890s Historical Map off'}
|
{(historicData === 'enabled')? 'OS 1890s Historical Map + Footprints on' : 'OS 1890s Historical Map + Footprints off'}
|
||||||
</button>
|
</button>
|
||||||
</form>
|
</form>
|
||||||
);
|
);
|
||||||
|
17
app/src/frontend/map/historic-map-switcher.tsx
Normal file
17
app/src/frontend/map/historic-map-switcher.tsx
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
import './map-button.css';
|
||||||
|
import { useDisplayPreferences } from '../displayPreferences-context';
|
||||||
|
|
||||||
|
export const HistoricMapSwitcher: React.FC<{}> = (props) => {
|
||||||
|
const { historicMap, historicMapSwitch, darkLightTheme } = useDisplayPreferences();
|
||||||
|
|
||||||
|
return (
|
||||||
|
<form className={`historic-map-switcher map-button ${historicMap}-state ${darkLightTheme}`} onSubmit={historicMapSwitch}>
|
||||||
|
<button className="btn btn-outline btn-outline-dark"
|
||||||
|
type="submit">
|
||||||
|
{(historicMap === 'enabled')? 'OS 1890s Historical Map on' : 'OS 1890s Historical Map off'}
|
||||||
|
</button>
|
||||||
|
</form>
|
||||||
|
);
|
||||||
|
}
|
21
app/src/frontend/map/layers/historic-map-layer.tsx
Normal file
21
app/src/frontend/map/layers/historic-map-layer.tsx
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
import * as React from 'react';
|
||||||
|
import { TileLayer } from 'react-leaflet';
|
||||||
|
import { LayerEnablementState } from '../../config/map-config';
|
||||||
|
import { BuildingBaseLayerAllZoom } from './building-base-layer-all-zoom';
|
||||||
|
import { useDisplayPreferences } from '../../displayPreferences-context';
|
||||||
|
import { BuildingDataLayer } from './building-data-layer';
|
||||||
|
|
||||||
|
export function HistoricMapLayer({revisionId}: {revisionId: string}) {
|
||||||
|
const { historicMap } = useDisplayPreferences();
|
||||||
|
if(historicMap == "enabled") {
|
||||||
|
return <>
|
||||||
|
<TileLayer
|
||||||
|
url="https://mapseries-tilesets.s3.amazonaws.com/london_1890s/{z}/{x}/{y}.png"
|
||||||
|
attribution='© CC BY 4.0 - Reproduced with the permission of the <a href="https://maps.nls.uk/">National Library of Scotland</a>'
|
||||||
|
/>
|
||||||
|
</>
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -111,11 +111,15 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.historic-data-switcher {
|
.historic-data-switcher {
|
||||||
|
top: 437px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.historic-map-switcher {
|
||||||
top: 397px;
|
top: 397px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.parcel-switcher {
|
.parcel-switcher {
|
||||||
top: 437px;
|
top: 477px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.map-switcher-inline {
|
.map-switcher-inline {
|
||||||
|
@ -15,6 +15,7 @@ import { BoroughBoundaryLayer } from './layers/borough-boundary-layer';
|
|||||||
import { BoroughLabelLayer } from './layers/borough-label-layer';
|
import { BoroughLabelLayer } from './layers/borough-label-layer';
|
||||||
import { ParcelBoundaryLayer } from './layers/parcel-boundary-layer';
|
import { ParcelBoundaryLayer } from './layers/parcel-boundary-layer';
|
||||||
import { HistoricDataLayer } from './layers/historic-data-layer';
|
import { HistoricDataLayer } from './layers/historic-data-layer';
|
||||||
|
import { HistoricMapLayer } from './layers/historic-map-layer';
|
||||||
import { FloodBoundaryLayer } from './layers/flood-boundary-layer';
|
import { FloodBoundaryLayer } from './layers/flood-boundary-layer';
|
||||||
import { ConservationAreaBoundaryLayer } from './layers/conservation-boundary-layer';
|
import { ConservationAreaBoundaryLayer } from './layers/conservation-boundary-layer';
|
||||||
import { VistaBoundaryLayer } from './layers/vista-boundary-layer';
|
import { VistaBoundaryLayer } from './layers/vista-boundary-layer';
|
||||||
@ -34,6 +35,7 @@ import { ParcelSwitcher } from './parcel-switcher';
|
|||||||
import { FloodSwitcher } from './flood-switcher';
|
import { FloodSwitcher } from './flood-switcher';
|
||||||
import { ConservationAreaSwitcher } from './conservation-switcher';
|
import { ConservationAreaSwitcher } from './conservation-switcher';
|
||||||
import { HistoricDataSwitcher } from './historic-data-switcher';
|
import { HistoricDataSwitcher } from './historic-data-switcher';
|
||||||
|
import { HistoricMapSwitcher } from './historic-map-switcher';
|
||||||
import { VistaSwitcher } from './vista-switcher';
|
import { VistaSwitcher } from './vista-switcher';
|
||||||
import { CreativeSwitcher } from './creative-switcher';
|
import { CreativeSwitcher } from './creative-switcher';
|
||||||
import { HousingSwitcher } from './housing-switcher';
|
import { HousingSwitcher } from './housing-switcher';
|
||||||
@ -129,6 +131,7 @@ export const ColouringMap : FC<ColouringMapProps> = ({
|
|||||||
>
|
>
|
||||||
<CityBoundaryLayer/>
|
<CityBoundaryLayer/>
|
||||||
<HistoricDataLayer revisionId={revisionId} />
|
<HistoricDataLayer revisionId={revisionId} />
|
||||||
|
<HistoricMapLayer revisionId={revisionId} />
|
||||||
<BoroughBoundaryLayer/>
|
<BoroughBoundaryLayer/>
|
||||||
<ParcelBoundaryLayer/>
|
<ParcelBoundaryLayer/>
|
||||||
<FloodBoundaryLayer/>
|
<FloodBoundaryLayer/>
|
||||||
@ -167,10 +170,12 @@ export const ColouringMap : FC<ColouringMapProps> = ({
|
|||||||
<ParcelSwitcher/>
|
<ParcelSwitcher/>
|
||||||
<FloodSwitcher/>
|
<FloodSwitcher/>
|
||||||
<ConservationAreaSwitcher/>
|
<ConservationAreaSwitcher/>
|
||||||
|
<HistoricMapSwitcher/>
|
||||||
<HistoricDataSwitcher/>
|
<HistoricDataSwitcher/>
|
||||||
<VistaSwitcher />
|
<VistaSwitcher />
|
||||||
<HousingSwitcher />
|
<HousingSwitcher />
|
||||||
<CreativeSwitcher />
|
<CreativeSwitcher />
|
||||||
|
|
||||||
</>
|
</>
|
||||||
: <></>
|
: <></>
|
||||||
}
|
}
|
||||||
|
@ -266,6 +266,15 @@ const LAYER_QUERIES = {
|
|||||||
buildings
|
buildings
|
||||||
WHERE
|
WHERE
|
||||||
current_landuse_order IS NOT NULL`,
|
current_landuse_order IS NOT NULL`,
|
||||||
|
original_landuse: `
|
||||||
|
SELECT
|
||||||
|
geometry_id,
|
||||||
|
typology_original_use_order,
|
||||||
|
typology_original_use[1] as typology_original_use,
|
||||||
|
typology_original_use_verified
|
||||||
|
FROM
|
||||||
|
buildings
|
||||||
|
WHERE typology_original_use IS NOT NULL`,
|
||||||
disaster_severity: `
|
disaster_severity: `
|
||||||
SELECT
|
SELECT
|
||||||
geometry_id,
|
geometry_id,
|
||||||
|
2
migrations/045.typology_changes.down.sql
Normal file
2
migrations/045.typology_changes.down.sql
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
ALTER TABLE buildings DROP COLUMN IF EXISTS typology_original_use_order;
|
||||||
|
ALTER TABLE buildings DROP COLUMN IF NOT EXISTS typology_original_use_verified;
|
9
migrations/045.typology_changes.up.sql
Normal file
9
migrations/045.typology_changes.up.sql
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
ALTER TABLE buildings ADD COLUMN IF NOT EXISTS typology_original_use_order text;
|
||||||
|
|
||||||
|
ALTER TABLE buildings ADD COLUMN IF NOT EXISTS typology_original_use_verified BOOLEAN NOT NULL DEFAULT FALSE;
|
||||||
|
|
||||||
|
UPDATE buildings as b
|
||||||
|
SET typology_original_use_verified = TRUE
|
||||||
|
FROM building_verification as v
|
||||||
|
WHERE b.building_id = v.building_id
|
||||||
|
AND v.attribute = 'current_landuse_group';
|
Loading…
Reference in New Issue
Block a user