@hipay/hipay-material-ui 1.0.0-beta.19 → 1.0.0-beta.20
Sign up to get free protection for your applications and to get access to all the features.
- package/HiChip/HiChip.js +12 -2
- package/HiDatePicker/HiDateRangePicker.js +1 -1
- package/HiDatePicker/HiDateRangeSelector.js +5 -4
- package/HiDatePicker/stylesheet.js +4 -0
- package/HiForm/HiAddressField.js +32 -49
- package/HiForm/HiInput.js +11 -6
- package/HiForm/HiUpload.js +280 -0
- package/HiForm/HiUploadField.js +456 -0
- package/HiForm/index.js +18 -0
- package/HiMap/HiMap.js +367 -0
- package/HiMap/HiMapExpand.js +217 -0
- package/HiMap/index.js +25 -0
- package/HiSelect/HiSelect.js +1 -1
- package/HiTable/BodyCellBuilder.js +1 -1
- package/HiTable/BodyCells/CellCountry.js +1 -1
- package/HiTable/BodyCells/CellImage.js +6 -6
- package/HiTable/BodyCells/CellLayout.js +1 -1
- package/HiTable/HeaderCell.js +5 -4
- package/HiTable/HiTableFooter.js +2 -1
- package/HiTopBar/HiTopBar.js +6 -4
- package/es/HiChip/HiChip.js +11 -2
- package/es/HiDatePicker/HiDateRangePicker.js +1 -1
- package/es/HiDatePicker/HiDateRangeSelector.js +5 -4
- package/es/HiDatePicker/stylesheet.js +4 -0
- package/es/HiForm/HiAddressField.js +30 -45
- package/es/HiForm/HiInput.js +10 -5
- package/es/HiForm/HiUpload.js +194 -0
- package/es/HiForm/HiUploadField.js +368 -0
- package/es/HiForm/index.js +2 -0
- package/es/HiMap/HiMap.js +285 -0
- package/es/HiMap/HiMapExpand.js +145 -0
- package/es/HiMap/index.js +2 -0
- package/es/HiSelect/HiSelect.js +1 -1
- package/es/HiTable/BodyCellBuilder.js +1 -1
- package/es/HiTable/BodyCells/CellCountry.js +1 -1
- package/es/HiTable/BodyCells/CellImage.js +6 -6
- package/es/HiTable/BodyCells/CellLayout.js +1 -1
- package/es/HiTable/HeaderCell.js +5 -3
- package/es/HiTable/HiTableFooter.js +2 -1
- package/es/HiTopBar/HiTopBar.js +6 -4
- package/es/styles/createHiMuiTheme.js +2 -0
- package/hmu/images/map_marker.svg +8 -0
- package/index.es.js +1 -1
- package/index.js +1 -1
- package/package.json +44 -42
- package/styles/createHiMuiTheme.js +2 -0
- package/umd/hipay-material-ui.development.js +58049 -14511
- package/umd/hipay-material-ui.production.min.js +5 -5
package/HiMap/HiMap.js
ADDED
@@ -0,0 +1,367 @@
|
|
1
|
+
'use strict';
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.styles = undefined;
|
7
|
+
|
8
|
+
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
|
9
|
+
|
10
|
+
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
|
11
|
+
|
12
|
+
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
|
13
|
+
|
14
|
+
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
|
15
|
+
|
16
|
+
var _createClass2 = require('babel-runtime/helpers/createClass');
|
17
|
+
|
18
|
+
var _createClass3 = _interopRequireDefault(_createClass2);
|
19
|
+
|
20
|
+
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
|
21
|
+
|
22
|
+
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
|
23
|
+
|
24
|
+
var _inherits2 = require('babel-runtime/helpers/inherits');
|
25
|
+
|
26
|
+
var _inherits3 = _interopRequireDefault(_inherits2);
|
27
|
+
|
28
|
+
var _react = require('react');
|
29
|
+
|
30
|
+
var _react2 = _interopRequireDefault(_react);
|
31
|
+
|
32
|
+
var _propTypes = require('prop-types');
|
33
|
+
|
34
|
+
var _propTypes2 = _interopRequireDefault(_propTypes);
|
35
|
+
|
36
|
+
var _styles = require('../styles');
|
37
|
+
|
38
|
+
var _HiButton = require('../HiButton');
|
39
|
+
|
40
|
+
var _HiButton2 = _interopRequireDefault(_HiButton);
|
41
|
+
|
42
|
+
var _HiIconBuilder = require('../utils/HiIconBuilder');
|
43
|
+
|
44
|
+
var _HiIconBuilder2 = _interopRequireDefault(_HiIconBuilder);
|
45
|
+
|
46
|
+
var _HiLoader = require('../HiLoader');
|
47
|
+
|
48
|
+
var _HiLoader2 = _interopRequireDefault(_HiLoader);
|
49
|
+
|
50
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
51
|
+
|
52
|
+
// The original CSS can be found here : https://unpkg.com/leaflet@1.3.1/dist/leaflet.css
|
53
|
+
var styles = exports.styles = function styles(theme) {
|
54
|
+
return {
|
55
|
+
map: {
|
56
|
+
height: '100%',
|
57
|
+
overflow: 'hidden',
|
58
|
+
'& .leaflet-pane, & .leaflet-tile, & .leaflet-marker-icon, & .leaflet-marker-shadow, & .leaflet-tile-container, & .leaflet-pane > svg, & .leaflet-pane > canvas, & .leaflet-zoom-box, & .leaflet-image-layer, & .leaflet-layer': {
|
59
|
+
position: 'absolute',
|
60
|
+
left: 0,
|
61
|
+
top: 0
|
62
|
+
},
|
63
|
+
'& .leaflet-container': {
|
64
|
+
overflow: 'hidden',
|
65
|
+
height: '100%'
|
66
|
+
},
|
67
|
+
'& .leaflet-tile, & .leaflet-marker-icon, & .leaflet-marker-shadow': {
|
68
|
+
'-webkit-user-select': 'none',
|
69
|
+
'-moz-user-select': 'none',
|
70
|
+
userSelect: 'none',
|
71
|
+
'-webkit-user-drag': 'none'
|
72
|
+
},
|
73
|
+
'& .leaflet-control': {
|
74
|
+
display: 'none'
|
75
|
+
},
|
76
|
+
'& .map_marker': {
|
77
|
+
fill: theme.palette.business.primary.normal
|
78
|
+
}
|
79
|
+
},
|
80
|
+
controlButtons: {
|
81
|
+
position: 'absolute',
|
82
|
+
bottom: 16,
|
83
|
+
right: 16
|
84
|
+
},
|
85
|
+
centerIcon: {
|
86
|
+
fontSize: 14
|
87
|
+
},
|
88
|
+
centerButtonContainer: {
|
89
|
+
backgroundColor: theme.palette.business.primary.contrast,
|
90
|
+
borderRadius: 3,
|
91
|
+
padding: 3,
|
92
|
+
boxShadow: '1px 1px 5px rgba(0, 0, 0, .16)',
|
93
|
+
marginBottom: 4,
|
94
|
+
height: 32,
|
95
|
+
minHeight: 32,
|
96
|
+
width: 32,
|
97
|
+
minWidth: 32
|
98
|
+
},
|
99
|
+
centerButton: {
|
100
|
+
color: theme.palette.neutral.normal,
|
101
|
+
padding: '1px !important',
|
102
|
+
height: 26,
|
103
|
+
minHeight: 26,
|
104
|
+
width: 26,
|
105
|
+
minWidth: 26
|
106
|
+
},
|
107
|
+
zoomButtons: {
|
108
|
+
backgroundColor: theme.palette.global.background1,
|
109
|
+
borderRadius: 3,
|
110
|
+
padding: 3,
|
111
|
+
fontFamily: theme.typography.fontFamily,
|
112
|
+
boxShadow: '1px 1px 5px rgba(0, 0, 0, .16)',
|
113
|
+
color: theme.palette.neutral.normal,
|
114
|
+
'&>button:first-child': {
|
115
|
+
borderBottom: '1px solid ' + theme.palette.neutral.normal
|
116
|
+
}
|
117
|
+
},
|
118
|
+
zoomButton: {
|
119
|
+
paddingTop: '0px !important',
|
120
|
+
paddingBottom: 0,
|
121
|
+
paddingRight: 6,
|
122
|
+
paddingLeft: 6,
|
123
|
+
minWidth: 0,
|
124
|
+
minHeight: 0,
|
125
|
+
borderRadius: 0,
|
126
|
+
display: 'block',
|
127
|
+
fontSize: 24,
|
128
|
+
fontWeight: 'bold',
|
129
|
+
lineHeight: '26px',
|
130
|
+
'&>span': {
|
131
|
+
width: 14
|
132
|
+
}
|
133
|
+
}
|
134
|
+
};
|
135
|
+
};
|
136
|
+
|
137
|
+
var L = void 0,
|
138
|
+
Map = void 0,
|
139
|
+
TileLayer = void 0,
|
140
|
+
Marker = void 0,
|
141
|
+
Popup = void 0;
|
142
|
+
|
143
|
+
var _ref = _react2.default.createElement(TileLayer, { url: 'https://{s}.tile.openstreetmap.se/hydda/full/{z}/{x}/{y}.png' });
|
144
|
+
|
145
|
+
var _ref2 = _react2.default.createElement(_HiLoader2.default, { loading: true });
|
146
|
+
|
147
|
+
var HiMap = function (_React$PureComponent) {
|
148
|
+
(0, _inherits3.default)(HiMap, _React$PureComponent);
|
149
|
+
|
150
|
+
function HiMap(props) {
|
151
|
+
(0, _classCallCheck3.default)(this, HiMap);
|
152
|
+
|
153
|
+
var _this = (0, _possibleConstructorReturn3.default)(this, (HiMap.__proto__ || (0, _getPrototypeOf2.default)(HiMap)).call(this, props));
|
154
|
+
|
155
|
+
_this.state = {
|
156
|
+
lat: 0,
|
157
|
+
lng: 0,
|
158
|
+
notFound: false,
|
159
|
+
loaded: false,
|
160
|
+
zoom: 16
|
161
|
+
};
|
162
|
+
|
163
|
+
_this.xhr = null;
|
164
|
+
_this.handleClickZoomIn = _this.handleClickZoomIn.bind(_this);
|
165
|
+
_this.handleScrollZoom = _this.handleScrollZoom.bind(_this);
|
166
|
+
_this.handleClickZoomOut = _this.handleClickZoomOut.bind(_this);
|
167
|
+
_this.handleCenter = _this.handleCenter.bind(_this);
|
168
|
+
return _this;
|
169
|
+
}
|
170
|
+
|
171
|
+
// Loads the libraries once the component mounted to avoid error caused by server-cli rendering.
|
172
|
+
|
173
|
+
|
174
|
+
(0, _createClass3.default)(HiMap, [{
|
175
|
+
key: 'componentDidMount',
|
176
|
+
value: function componentDidMount() {
|
177
|
+
this.findCoords();
|
178
|
+
L = require('leaflet');
|
179
|
+
Map = require('react-leaflet').Map;
|
180
|
+
Popup = require('react-leaflet').Popup;
|
181
|
+
Marker = require('react-leaflet').Marker;
|
182
|
+
TileLayer = require('react-leaflet').TileLayer;
|
183
|
+
}
|
184
|
+
|
185
|
+
// Avoids a warning when cleanup() is called at the end of the test by stopping the async call.
|
186
|
+
|
187
|
+
}, {
|
188
|
+
key: 'componentWillUnmount',
|
189
|
+
value: function componentWillUnmount() {
|
190
|
+
this.xhr.abort();
|
191
|
+
}
|
192
|
+
}, {
|
193
|
+
key: 'handleScrollZoom',
|
194
|
+
value: function handleScrollZoom(event) {
|
195
|
+
this.setState({ zoom: event.zoom });
|
196
|
+
}
|
197
|
+
}, {
|
198
|
+
key: 'handleClickZoomIn',
|
199
|
+
value: function handleClickZoomIn() {
|
200
|
+
this.setState(function (prevState) {
|
201
|
+
return { zoom: prevState.zoom + 1 };
|
202
|
+
});
|
203
|
+
}
|
204
|
+
}, {
|
205
|
+
key: 'handleClickZoomOut',
|
206
|
+
value: function handleClickZoomOut() {
|
207
|
+
this.setState(function (prevState) {
|
208
|
+
return { zoom: prevState.zoom - 1 };
|
209
|
+
});
|
210
|
+
}
|
211
|
+
}, {
|
212
|
+
key: 'handleCenter',
|
213
|
+
value: function handleCenter() {
|
214
|
+
// trick to center the map.
|
215
|
+
this.setState(function (prevState) {
|
216
|
+
return { lat: prevState.lat + 0.0000000001 };
|
217
|
+
});
|
218
|
+
}
|
219
|
+
|
220
|
+
// Call to the geocoding API.
|
221
|
+
|
222
|
+
}, {
|
223
|
+
key: 'findCoords',
|
224
|
+
value: function findCoords() {
|
225
|
+
var _this2 = this;
|
226
|
+
|
227
|
+
this.xhr = new XMLHttpRequest();
|
228
|
+
this.xhr.onreadystatechange = function () {
|
229
|
+
if (_this2.xhr.readyState === XMLHttpRequest.DONE && _this2.xhr.status === 200) {
|
230
|
+
var response = JSON.parse(_this2.xhr.responseText);
|
231
|
+
if (response.length === 0) {
|
232
|
+
_this2.setState({ notFound: true });
|
233
|
+
_this2.props.onAddressNotFound();
|
234
|
+
} else {
|
235
|
+
_this2.setState({
|
236
|
+
lat: parseFloat(response[0].lat),
|
237
|
+
lng: parseFloat(response[0].lon),
|
238
|
+
notFound: false,
|
239
|
+
loaded: true
|
240
|
+
});
|
241
|
+
}
|
242
|
+
}
|
243
|
+
};
|
244
|
+
this.xhr.open('GET', 'https://nominatim.openstreetmap.org/search?q=' + this.props.address + '&format=jsonv2&limit=5&bounded=1&dedupe=1&namedetails=1', true);
|
245
|
+
this.xhr.setRequestHeader('Content-type', 'application/json');
|
246
|
+
this.xhr.send();
|
247
|
+
}
|
248
|
+
}, {
|
249
|
+
key: 'render',
|
250
|
+
value: function render() {
|
251
|
+
var _state = this.state,
|
252
|
+
zoom = _state.zoom,
|
253
|
+
lng = _state.lng,
|
254
|
+
lat = _state.lat,
|
255
|
+
notFound = _state.notFound,
|
256
|
+
loaded = _state.loaded;
|
257
|
+
var _props = this.props,
|
258
|
+
translations = _props.translations,
|
259
|
+
classes = _props.classes;
|
260
|
+
|
261
|
+
|
262
|
+
var position = [lat, lng];
|
263
|
+
|
264
|
+
var element = void 0;
|
265
|
+
|
266
|
+
var myIcon = void 0;
|
267
|
+
if (notFound) {
|
268
|
+
element = translations.notFound;
|
269
|
+
} else if (loaded) {
|
270
|
+
myIcon = L.divIcon({
|
271
|
+
html: '<svg x="0px" y="0px" viewBox="0 0 365 560" enable-background="new 0 0 365 560" xml:space="preserve">\n' + '<path class="map_marker" d="M182.9,551.7c0,0.1,0.2,0.3,0.2,0.3S358.3,283,358.3,194.6c0-130.1-88.8-186.7-175.4-186.9 C96.3,7.9,7.5,64.5,7.5,194.6c0,88.4,175.3,357.4,175.3,357.4S182.9,551.7,182.9,551.7z M122.2,187.2c0-33.6,27.2-60.8,60.8-60.8 c33.6,0,60.8,27.2,60.8,60.8S216.5,248,182.9,248C149.4,248,122.2,220.8,122.2,187.2z"/>\n' + '</svg>',
|
272
|
+
iconSize: [24, 36],
|
273
|
+
iconAnchor: [11, 36]
|
274
|
+
});
|
275
|
+
element = _react2.default.createElement(
|
276
|
+
Map,
|
277
|
+
{
|
278
|
+
zoom: zoom,
|
279
|
+
center: position,
|
280
|
+
className: classes.map,
|
281
|
+
onViewportChange: this.handleScrollZoom
|
282
|
+
},
|
283
|
+
_ref,
|
284
|
+
_react2.default.createElement(Marker, { position: position, icon: myIcon }),
|
285
|
+
_react2.default.createElement(
|
286
|
+
'div',
|
287
|
+
{ className: classes.controlButtons },
|
288
|
+
_react2.default.createElement(
|
289
|
+
'div',
|
290
|
+
{ className: classes.centerButtonContainer },
|
291
|
+
_react2.default.createElement(
|
292
|
+
_HiButton2.default,
|
293
|
+
{ className: classes.centerButton, onClick: this.handleCenter },
|
294
|
+
_react2.default.createElement(_HiIconBuilder2.default, {
|
295
|
+
className: classes.centerIcon,
|
296
|
+
icon: 'crosshairs_gps',
|
297
|
+
size: 24
|
298
|
+
})
|
299
|
+
)
|
300
|
+
),
|
301
|
+
_react2.default.createElement(
|
302
|
+
'div',
|
303
|
+
{ className: classes.zoomButtons },
|
304
|
+
_react2.default.createElement(
|
305
|
+
_HiButton2.default,
|
306
|
+
{
|
307
|
+
onClick: this.handleClickZoomIn,
|
308
|
+
className: classes.zoomButton
|
309
|
+
},
|
310
|
+
'+'
|
311
|
+
),
|
312
|
+
_react2.default.createElement(
|
313
|
+
_HiButton2.default,
|
314
|
+
{
|
315
|
+
onClick: this.handleClickZoomOut,
|
316
|
+
className: classes.zoomButton
|
317
|
+
},
|
318
|
+
'-'
|
319
|
+
)
|
320
|
+
)
|
321
|
+
)
|
322
|
+
);
|
323
|
+
} else {
|
324
|
+
element = _react2.default.createElement(
|
325
|
+
'div',
|
326
|
+
{ style: { top: '50%', left: '50%', position: 'absolute' } },
|
327
|
+
_ref2
|
328
|
+
);
|
329
|
+
}
|
330
|
+
|
331
|
+
return _react2.default.createElement(
|
332
|
+
'div',
|
333
|
+
{ style: { height: '352px', width: '100%', position: 'relative' } },
|
334
|
+
element
|
335
|
+
);
|
336
|
+
}
|
337
|
+
}]);
|
338
|
+
return HiMap;
|
339
|
+
}(_react2.default.PureComponent);
|
340
|
+
|
341
|
+
HiMap.defaultProps = {
|
342
|
+
translations: {
|
343
|
+
notFound: 'Address not found'
|
344
|
+
}
|
345
|
+
};
|
346
|
+
|
347
|
+
|
348
|
+
HiMap.propTypes = process.env.NODE_ENV !== "production" ? {
|
349
|
+
/**
|
350
|
+
* The address to see in the Map component.
|
351
|
+
*/
|
352
|
+
address: _propTypes2.default.string.isRequired,
|
353
|
+
/**
|
354
|
+
* Useful to extend the style applied to components.
|
355
|
+
*/
|
356
|
+
classes: _propTypes2.default.object.isRequired,
|
357
|
+
/**
|
358
|
+
* Function to tell the parent composant that the address was not found by the API.
|
359
|
+
*/
|
360
|
+
onAddressNotFound: _propTypes2.default.func,
|
361
|
+
/**
|
362
|
+
* Traductions
|
363
|
+
*/
|
364
|
+
translations: _propTypes2.default.object
|
365
|
+
} : {};
|
366
|
+
|
367
|
+
exports.default = (0, _styles.withStyles)(styles, { name: 'HmuiHiMap' })(HiMap);
|
@@ -0,0 +1,217 @@
|
|
1
|
+
'use strict';
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
|
7
|
+
var _defineProperty2 = require('babel-runtime/helpers/defineProperty');
|
8
|
+
|
9
|
+
var _defineProperty3 = _interopRequireDefault(_defineProperty2);
|
10
|
+
|
11
|
+
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
|
12
|
+
|
13
|
+
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
|
14
|
+
|
15
|
+
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
|
16
|
+
|
17
|
+
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
|
18
|
+
|
19
|
+
var _createClass2 = require('babel-runtime/helpers/createClass');
|
20
|
+
|
21
|
+
var _createClass3 = _interopRequireDefault(_createClass2);
|
22
|
+
|
23
|
+
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
|
24
|
+
|
25
|
+
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
|
26
|
+
|
27
|
+
var _inherits2 = require('babel-runtime/helpers/inherits');
|
28
|
+
|
29
|
+
var _inherits3 = _interopRequireDefault(_inherits2);
|
30
|
+
|
31
|
+
var _react = require('react');
|
32
|
+
|
33
|
+
var _react2 = _interopRequireDefault(_react);
|
34
|
+
|
35
|
+
var _propTypes = require('prop-types');
|
36
|
+
|
37
|
+
var _propTypes2 = _interopRequireDefault(_propTypes);
|
38
|
+
|
39
|
+
var _classnames = require('classnames');
|
40
|
+
|
41
|
+
var _classnames2 = _interopRequireDefault(_classnames);
|
42
|
+
|
43
|
+
var _ExpansionPanel = require('material-ui/ExpansionPanel');
|
44
|
+
|
45
|
+
var _ExpansionPanel2 = _interopRequireDefault(_ExpansionPanel);
|
46
|
+
|
47
|
+
var _Typography = require('material-ui/Typography');
|
48
|
+
|
49
|
+
var _Typography2 = _interopRequireDefault(_Typography);
|
50
|
+
|
51
|
+
var _styles = require('../styles');
|
52
|
+
|
53
|
+
var _HiMap = require('../HiMap');
|
54
|
+
|
55
|
+
var _HiMap2 = _interopRequireDefault(_HiMap);
|
56
|
+
|
57
|
+
var _HiIconBuilder = require('../utils/HiIconBuilder');
|
58
|
+
|
59
|
+
var _HiIconBuilder2 = _interopRequireDefault(_HiIconBuilder);
|
60
|
+
|
61
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
62
|
+
|
63
|
+
var styles = function styles(theme) {
|
64
|
+
return {
|
65
|
+
column: {
|
66
|
+
flexBasis: '33.33%'
|
67
|
+
},
|
68
|
+
root: {
|
69
|
+
flexGrow: 1,
|
70
|
+
boxShadow: 'none'
|
71
|
+
},
|
72
|
+
imgListItem: {
|
73
|
+
width: 24,
|
74
|
+
height: 'auto',
|
75
|
+
marginRight: 8,
|
76
|
+
verticalAlign: 'middle'
|
77
|
+
},
|
78
|
+
expandMoreIcon: {
|
79
|
+
margin: 0,
|
80
|
+
fontSize: 18,
|
81
|
+
width: 20
|
82
|
+
},
|
83
|
+
disabledIcon: {
|
84
|
+
color: theme.palette.action.disabled
|
85
|
+
},
|
86
|
+
panelSummaryExpanded: {
|
87
|
+
minHeight: 0
|
88
|
+
},
|
89
|
+
expandIconExpanded: {
|
90
|
+
transform: 'translateY(-50%) rotate(0)',
|
91
|
+
color: theme.palette.business.primary.light
|
92
|
+
},
|
93
|
+
panelSummary: {
|
94
|
+
'&>div:first-child': {
|
95
|
+
margin: '12px 0'
|
96
|
+
}
|
97
|
+
}
|
98
|
+
};
|
99
|
+
};
|
100
|
+
|
101
|
+
var HiMapExpand = function (_React$PureComponent) {
|
102
|
+
(0, _inherits3.default)(HiMapExpand, _React$PureComponent);
|
103
|
+
|
104
|
+
function HiMapExpand(props) {
|
105
|
+
(0, _classCallCheck3.default)(this, HiMapExpand);
|
106
|
+
|
107
|
+
var _this = (0, _possibleConstructorReturn3.default)(this, (HiMapExpand.__proto__ || (0, _getPrototypeOf2.default)(HiMapExpand)).call(this, props));
|
108
|
+
|
109
|
+
_this.state = {
|
110
|
+
addressNotFound: false,
|
111
|
+
expanded: false
|
112
|
+
};
|
113
|
+
_this.handleAddressNotFound = _this.handleAddressNotFound.bind(_this);
|
114
|
+
_this.handleExpand = _this.handleExpand.bind(_this);
|
115
|
+
return _this;
|
116
|
+
}
|
117
|
+
|
118
|
+
(0, _createClass3.default)(HiMapExpand, [{
|
119
|
+
key: 'handleExpand',
|
120
|
+
value: function handleExpand() {
|
121
|
+
this.setState({ expanded: !this.state.addressNotFound && !this.state.expanded });
|
122
|
+
}
|
123
|
+
}, {
|
124
|
+
key: 'handleAddressNotFound',
|
125
|
+
value: function handleAddressNotFound() {
|
126
|
+
this.setState({ addressNotFound: true });
|
127
|
+
}
|
128
|
+
}, {
|
129
|
+
key: 'render',
|
130
|
+
value: function render() {
|
131
|
+
var _props = this.props,
|
132
|
+
classes = _props.classes,
|
133
|
+
address = _props.address,
|
134
|
+
countryFlagPath = _props.countryFlagPath;
|
135
|
+
var _state = this.state,
|
136
|
+
addressNotFound = _state.addressNotFound,
|
137
|
+
expanded = _state.expanded;
|
138
|
+
|
139
|
+
|
140
|
+
var flag = countryFlagPath ? _react2.default.createElement('img', { src: countryFlagPath, className: classes.imgListItem, alt: 'country flag' }) : '';
|
141
|
+
|
142
|
+
return _react2.default.createElement(
|
143
|
+
_ExpansionPanel2.default,
|
144
|
+
{
|
145
|
+
className: classes.root,
|
146
|
+
defaultExpanded: false,
|
147
|
+
expanded: expanded,
|
148
|
+
onChange: this.handleExpand
|
149
|
+
},
|
150
|
+
_react2.default.createElement(
|
151
|
+
_ExpansionPanel.ExpansionPanelSummary,
|
152
|
+
{
|
153
|
+
classes: {
|
154
|
+
root: classes.panelSummary,
|
155
|
+
expanded: classes.panelSummaryExpanded,
|
156
|
+
expandIconExpanded: classes.expandIconExpanded
|
157
|
+
},
|
158
|
+
expandIcon: _react2.default.createElement(_HiIconBuilder2.default, {
|
159
|
+
icon: 'map_marker',
|
160
|
+
style: { position: 'relative', top: 2, marginRight: 5 },
|
161
|
+
className: (0, _classnames2.default)((0, _defineProperty3.default)({
|
162
|
+
root: classes.expandMoreIcon
|
163
|
+
}, classes.disabledIcon, addressNotFound))
|
164
|
+
})
|
165
|
+
},
|
166
|
+
_react2.default.createElement(
|
167
|
+
'div',
|
168
|
+
{ className: classes.column },
|
169
|
+
_react2.default.createElement(
|
170
|
+
_Typography2.default,
|
171
|
+
{ className: classes.heading },
|
172
|
+
'Adresse'
|
173
|
+
)
|
174
|
+
),
|
175
|
+
_react2.default.createElement(
|
176
|
+
'div',
|
177
|
+
null,
|
178
|
+
_react2.default.createElement(
|
179
|
+
_Typography2.default,
|
180
|
+
{ className: classes.secondaryHeading },
|
181
|
+
flag,
|
182
|
+
address
|
183
|
+
)
|
184
|
+
)
|
185
|
+
),
|
186
|
+
_react2.default.createElement(
|
187
|
+
_ExpansionPanel.ExpansionPanelDetails,
|
188
|
+
{ style: { padding: 0 } },
|
189
|
+
_react2.default.createElement(_HiMap2.default, { address: address, onAddressNotFound: this.handleAddressNotFound })
|
190
|
+
)
|
191
|
+
);
|
192
|
+
}
|
193
|
+
}]);
|
194
|
+
return HiMapExpand;
|
195
|
+
}(_react2.default.PureComponent);
|
196
|
+
|
197
|
+
HiMapExpand.defaultProps = {
|
198
|
+
countryFlagPath: ''
|
199
|
+
};
|
200
|
+
|
201
|
+
|
202
|
+
HiMapExpand.propTypes = process.env.NODE_ENV !== "production" ? {
|
203
|
+
/**
|
204
|
+
* The address to see in the Map component.
|
205
|
+
*/
|
206
|
+
address: _propTypes2.default.string.isRequired,
|
207
|
+
/**
|
208
|
+
* Useful to extend the style applied to components.
|
209
|
+
*/
|
210
|
+
classes: _propTypes2.default.object.isRequired,
|
211
|
+
/**
|
212
|
+
* The path to the country flag image.
|
213
|
+
*/
|
214
|
+
countryFlagPath: _propTypes2.default.string
|
215
|
+
} : {};
|
216
|
+
|
217
|
+
exports.default = (0, _styles.withStyles)(styles, { name: 'HmuiHiMapExpand' })(HiMapExpand);
|
package/HiMap/index.js
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
'use strict';
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
|
7
|
+
var _HiMap = require('./HiMap');
|
8
|
+
|
9
|
+
Object.defineProperty(exports, 'default', {
|
10
|
+
enumerable: true,
|
11
|
+
get: function get() {
|
12
|
+
return _interopRequireDefault(_HiMap).default;
|
13
|
+
}
|
14
|
+
});
|
15
|
+
|
16
|
+
var _HiMapExpand = require('./HiMapExpand');
|
17
|
+
|
18
|
+
Object.defineProperty(exports, 'HiMapExpand', {
|
19
|
+
enumerable: true,
|
20
|
+
get: function get() {
|
21
|
+
return _interopRequireDefault(_HiMapExpand).default;
|
22
|
+
}
|
23
|
+
});
|
24
|
+
|
25
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
package/HiSelect/HiSelect.js
CHANGED
@@ -409,5 +409,5 @@ BodyCellBuilder.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
409
409
|
/**
|
410
410
|
* Largeur de la cellule (hors padding), est déduit de view par défaut
|
411
411
|
*/
|
412
|
-
width: _propTypes2.default.number
|
412
|
+
width: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.string])
|
413
413
|
} : {};
|
@@ -59,7 +59,10 @@ var styles = exports.styles = function styles(theme) {
|
|
59
59
|
height: 'auto'
|
60
60
|
},
|
61
61
|
label: {
|
62
|
-
marginLeft: 5
|
62
|
+
marginLeft: 5,
|
63
|
+
whiteSpace: 'nowrap',
|
64
|
+
overflow: 'hidden',
|
65
|
+
textOverflow: 'ellipsis'
|
63
66
|
},
|
64
67
|
tooltipImg: {
|
65
68
|
width: 24,
|
@@ -72,10 +75,7 @@ var styles = exports.styles = function styles(theme) {
|
|
72
75
|
},
|
73
76
|
wrapper: {
|
74
77
|
display: 'flex',
|
75
|
-
alignItems: 'center'
|
76
|
-
whiteSpace: 'nowrap',
|
77
|
-
overflow: 'hidden',
|
78
|
-
textOverflow: 'ellipsis'
|
78
|
+
alignItems: 'center'
|
79
79
|
},
|
80
80
|
center: {
|
81
81
|
textAlign: 'center'
|
@@ -189,7 +189,7 @@ CellImage.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
189
189
|
/**
|
190
190
|
* Value
|
191
191
|
*/
|
192
|
-
value: _propTypes2.default.string
|
192
|
+
value: _propTypes2.default.string,
|
193
193
|
/**
|
194
194
|
* View (L/M/S)
|
195
195
|
*/
|
@@ -272,7 +272,7 @@ CellLayout.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
272
272
|
/**
|
273
273
|
* Largeur de la cellule (hors padding), est déduit de view par défaut
|
274
274
|
*/
|
275
|
-
width: _propTypes2.default.number,
|
275
|
+
width: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.string]),
|
276
276
|
/**
|
277
277
|
* Fixe la taille des colonnes selon le type de vue
|
278
278
|
* Sinon les colonnes s'adaptent à l'espace disponible
|