@colijnit/corecomponents_v12 259.1.15 → 259.1.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/colijnit-corecomponents_v12.umd.js +114 -15
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/filter-item/filter-item.component.js +4 -3
- package/esm2015/lib/components/input-date-picker/input-date-picker.component.js +5 -2
- package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.component.js +5 -2
- package/esm2015/lib/components/input-text/input-text.component.js +88 -8
- package/esm2015/lib/components/list-of-icons/list-of-icons.component.js +13 -7
- package/esm2015/lib/components/list-of-icons/list-of-icons.module.js +4 -2
- package/esm2015/lib/components/simple-grid/simple-grid.component.js +9 -1
- package/esm2015/lib/core/enum/batch-delivery-category.enum.js +13 -0
- package/fesm2015/colijnit-corecomponents_v12.js +130 -16
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/filter-item/filter-item.component.d.ts +1 -0
- package/lib/components/input-date-picker/input-date-picker.component.d.ts +1 -0
- package/lib/components/input-date-range-picker/input-date-range-picker.component.d.ts +1 -0
- package/lib/components/input-text/input-text.component.d.ts +5 -1
- package/lib/components/list-of-icons/style/_layout.scss +10 -6
- package/lib/core/enum/batch-delivery-category.enum.d.ts +10 -0
- package/package.json +1 -1
|
@@ -27,6 +27,7 @@ export class InputTextComponent extends BaseInputComponent {
|
|
|
27
27
|
this.showPlaceholderOnFocus = true;
|
|
28
28
|
this.selectOnFocus = false;
|
|
29
29
|
this.emptyPlace = false;
|
|
30
|
+
this.firstDayOfWeek = '1'; // default is sunday ioneJS
|
|
30
31
|
this.noStyle = false;
|
|
31
32
|
this.hideArrowButtons = false;
|
|
32
33
|
this.leftIconClick = new EventEmitter();
|
|
@@ -39,6 +40,8 @@ export class InputTextComponent extends BaseInputComponent {
|
|
|
39
40
|
this.isFocused = new EventEmitter();
|
|
40
41
|
this.hasOwnLabel = true;
|
|
41
42
|
this.isFocusedOnDate = false;
|
|
43
|
+
this.weekInputBuffer = '';
|
|
44
|
+
this.isWeekInputMode = false;
|
|
42
45
|
this._isLeftIconMouseDown = false;
|
|
43
46
|
this._isRightIconMouseDown = false;
|
|
44
47
|
super._markAsOnPush();
|
|
@@ -90,11 +93,6 @@ export class InputTextComponent extends BaseInputComponent {
|
|
|
90
93
|
}
|
|
91
94
|
return this.model;
|
|
92
95
|
}
|
|
93
|
-
// exclude some non-digit characters, since input type 'number' still allows the characters -, + and e
|
|
94
|
-
excludeNonDigitChars(event) {
|
|
95
|
-
const excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];
|
|
96
|
-
return !excludedKeys.includes(event.key);
|
|
97
|
-
}
|
|
98
96
|
handleLeftIconClick(event) {
|
|
99
97
|
event.preventDefault();
|
|
100
98
|
event.stopPropagation();
|
|
@@ -157,6 +155,87 @@ export class InputTextComponent extends BaseInputComponent {
|
|
|
157
155
|
this.setModel(null);
|
|
158
156
|
this.clearIconClick.emit(event);
|
|
159
157
|
}
|
|
158
|
+
handleKeyDownInput(event) {
|
|
159
|
+
const key = event.key.toLowerCase();
|
|
160
|
+
if (this.type === 'date') {
|
|
161
|
+
if (key === 'w') {
|
|
162
|
+
event.preventDefault();
|
|
163
|
+
this.isWeekInputMode = true;
|
|
164
|
+
this.weekInputBuffer = 'w';
|
|
165
|
+
this.model = 'w';
|
|
166
|
+
this.modelChange.emit(this.model);
|
|
167
|
+
return;
|
|
168
|
+
}
|
|
169
|
+
if (this.isWeekInputMode) {
|
|
170
|
+
if (/^\d$/.test(key)) {
|
|
171
|
+
event.preventDefault();
|
|
172
|
+
this.weekInputBuffer += key;
|
|
173
|
+
this.model = this.weekInputBuffer;
|
|
174
|
+
this.modelChange.emit(this.model);
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
if (key === 'enter' || key === 'tab') {
|
|
178
|
+
event.preventDefault();
|
|
179
|
+
this.convertWeekToDate(this.weekInputBuffer);
|
|
180
|
+
this.isWeekInputMode = false;
|
|
181
|
+
this.weekInputBuffer = '';
|
|
182
|
+
return;
|
|
183
|
+
}
|
|
184
|
+
if (!['backspace', 'delete'].includes(key)) {
|
|
185
|
+
this.isWeekInputMode = false;
|
|
186
|
+
this.weekInputBuffer = '';
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
/* old excludeCharacter function */
|
|
191
|
+
if (this.digitsOnly && !this.isWeekInputMode) {
|
|
192
|
+
const excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];
|
|
193
|
+
if (excludedKeys.includes(event.key)) {
|
|
194
|
+
event.preventDefault();
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
convertWeekToDate(weekStr) {
|
|
199
|
+
const match = weekStr.match(/^w0*(\d{1,2})$/i);
|
|
200
|
+
if (!match)
|
|
201
|
+
return;
|
|
202
|
+
const week = parseInt(match[1], 10);
|
|
203
|
+
if (week < 1 || week > 53)
|
|
204
|
+
return;
|
|
205
|
+
const today = new Date();
|
|
206
|
+
let year = today.getFullYear();
|
|
207
|
+
// Internal default first day of week
|
|
208
|
+
let weekdayOffset = parseInt(this.firstDayOfWeek, 10);
|
|
209
|
+
if (isNaN(weekdayOffset) || weekdayOffset < 1 || weekdayOffset > 7) {
|
|
210
|
+
weekdayOffset = 2;
|
|
211
|
+
}
|
|
212
|
+
// Convert to JS weekday index where 0 = Sunday ... 6 = Saturday
|
|
213
|
+
const jsWeekdayIndex = (weekdayOffset - 1) % 7;
|
|
214
|
+
const jan4 = new Date(year, 0, 4);
|
|
215
|
+
const jan4Day = jan4.getDay();
|
|
216
|
+
const diffToMonday = (jan4Day + 6) % 7;
|
|
217
|
+
const firstWeekMonday = new Date(jan4);
|
|
218
|
+
firstWeekMonday.setDate(jan4.getDate() - diffToMonday); // Monday of week 1
|
|
219
|
+
const baseWeekStart = new Date(firstWeekMonday);
|
|
220
|
+
baseWeekStart.setDate(baseWeekStart.getDate() + (week - 1) * 7);
|
|
221
|
+
const targetDate = new Date(baseWeekStart);
|
|
222
|
+
targetDate.setDate(baseWeekStart.getDate() + jsWeekdayIndex);
|
|
223
|
+
if (targetDate < today) {
|
|
224
|
+
year += 1;
|
|
225
|
+
const jan4Next = new Date(year, 0, 4);
|
|
226
|
+
const jan4DayNext = jan4Next.getDay();
|
|
227
|
+
const diffToMondayNext = (jan4DayNext + 6) % 7;
|
|
228
|
+
const firstWeekMondayNext = new Date(jan4Next);
|
|
229
|
+
firstWeekMondayNext.setDate(jan4Next.getDate() - diffToMondayNext);
|
|
230
|
+
const baseWeekStartNext = new Date(firstWeekMondayNext);
|
|
231
|
+
baseWeekStartNext.setDate(baseWeekStartNext.getDate() + (week - 1) * 7);
|
|
232
|
+
targetDate.setFullYear(year);
|
|
233
|
+
targetDate.setMonth(baseWeekStartNext.getMonth());
|
|
234
|
+
targetDate.setDate(baseWeekStartNext.getDate() + jsWeekdayIndex);
|
|
235
|
+
}
|
|
236
|
+
this.model = targetDate.toISOString().substring(0, 10);
|
|
237
|
+
this.modelChange.emit(this.model);
|
|
238
|
+
}
|
|
160
239
|
}
|
|
161
240
|
InputTextComponent.decorators = [
|
|
162
241
|
{ type: Component, args: [{
|
|
@@ -179,7 +258,7 @@ InputTextComponent.decorators = [
|
|
|
179
258
|
<input [class.show]="focused || !formatPipe" #input
|
|
180
259
|
[class.input-input-hidden]="useContent"
|
|
181
260
|
[ngClass]="align"
|
|
182
|
-
[type]="(isFocusedOnDate || (hasValue && emptyPlace)) ? 'date' : (digitsOnly ? 'number' : (type === 'date' ? 'text' : type))"
|
|
261
|
+
[type]="isWeekInputMode ? 'text' : (isFocusedOnDate || (hasValue && emptyPlace)) ? 'date' : (digitsOnly ? 'number' : (type === 'date' ? 'text' : type))"
|
|
183
262
|
[placeholder]="type === 'date' && !isFocusedOnDate ? '' : ''"
|
|
184
263
|
[pattern]="type === 'date' ? pattern : undefined"
|
|
185
264
|
[ngModel]="model"
|
|
@@ -188,7 +267,7 @@ InputTextComponent.decorators = [
|
|
|
188
267
|
[readonly]="readonly"
|
|
189
268
|
[required]="required"
|
|
190
269
|
(ngModelChange)="modelChange.emit($event)"
|
|
191
|
-
(keydown)="
|
|
270
|
+
(keydown)="handleKeyDownInput($event)"
|
|
192
271
|
(keyup)="keyUp.emit($event)"
|
|
193
272
|
(focusin)="handleInputFocus($event)"
|
|
194
273
|
(focusout)="handleBlur($event)"
|
|
@@ -260,6 +339,7 @@ InputTextComponent.propDecorators = {
|
|
|
260
339
|
rightIconData: [{ type: Input }],
|
|
261
340
|
selectOnFocus: [{ type: Input }],
|
|
262
341
|
emptyPlace: [{ type: Input }],
|
|
342
|
+
firstDayOfWeek: [{ type: Input }],
|
|
263
343
|
noStyle: [{ type: HostBinding, args: ['class.no-style',] }, { type: Input }],
|
|
264
344
|
hideArrowButtons: [{ type: Input }, { type: HostBinding, args: ['class.hide-arrows',] }],
|
|
265
345
|
isDate: [{ type: HostBinding, args: ["class.isDate",] }],
|
|
@@ -278,4 +358,4 @@ InputTextComponent.propDecorators = {
|
|
|
278
358
|
handleDocumentMouseUp: [{ type: HostListener, args: ['document:mouseup', ['$event'],] }],
|
|
279
359
|
model: [{ type: Input }]
|
|
280
360
|
};
|
|
281
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-text/input-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, EventEmitter, forwardRef, HostBinding, HostListener, Injector, Input, Optional, Output, ViewEncapsulation} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {KeyboardCode} from '../../core/enum/keyboard-code.enum';\r\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\r\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\r\nimport {FormComponent} from '../form/form.component';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {OverlayService} from '../../service/overlay.service';\r\n\r\n@Component({\r\n  selector: 'co-input-text',\r\n  template: `\r\n    <div class=\"input-text-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n      <co-icon *ngIf=\"leftIcon || leftIconData\" class=\"input-text-left-icon\" [icon]=\"leftIcon\" [iconData]=\"leftIconData\"\r\n               (click)=\"handleLeftIconClick($event)\" (mousedown)=\"handleLeftIconMouseDown($event)\"\r\n               (mouseup)=\"handleLeftIconMouseUp($event)\"></co-icon>\r\n      <div *ngIf=\"leftIcon || leftIconData\" class=\"spacer left-icon\"></div>\r\n      <div class=\"input-wrapper\">\r\n        <label *ngIf=\"showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)\"\r\n               [textContent]=\"placeholder\"></label>\r\n        <span class=\"input-text-formatted\" *ngIf=\"!focused && !useContent && formatPipe\"\r\n              [class.show]=\"!focused && !useContent && formatPipe\"\r\n              [ngClass]=\"align\"\r\n              [textContent]=\"pipedModel\"\r\n              (click)=\"handleDoFocus($event)\"\r\n        ></span>\r\n        <input [class.show]=\"focused || !formatPipe\" #input\r\n               [class.input-input-hidden]=\"useContent\"\r\n               [ngClass]=\"align\"\r\n               [type]=\"(isFocusedOnDate || (hasValue && emptyPlace)) ? 'date' : (digitsOnly ? 'number' : (type === 'date' ? 'text' : type))\"\r\n               [placeholder]=\"type === 'date' && !isFocusedOnDate ? '' : ''\"\r\n               [pattern]=\"type === 'date' ? pattern : undefined\"\r\n               [ngModel]=\"model\"\r\n               [min]=\"(type === 'number' || type === 'date') && this.min ? this.min : undefined\"\r\n               [max]=\"(type === 'number' || type === 'date') && this.max ? this.max : undefined\"\r\n               [readonly]=\"readonly\"\r\n               [required]=\"required\"\r\n               (ngModelChange)=\"modelChange.emit($event)\"\r\n               (keydown)=\"digitsOnly ? excludeNonDigitChars($event) : true\"\r\n               (keyup)=\"keyUp.emit($event)\"\r\n               (focusin)=\"handleInputFocus($event)\"\r\n               (focusout)=\"handleBlur($event)\"\r\n        >\r\n        <ng-container *ngIf=\"useContent\">\r\n          <div class=\"input-content-wrapper\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n        </ng-container>\r\n        <co-icon [class.show]=\"showClearButton && hasValue && !readonly\" class=\"input-text-clear-button\"\r\n                 [icon]=\"icons.CrossSkinny\" (click)=\"clearInput($event)\"></co-icon>\r\n        <div class=\"required-indicator\"></div>\r\n      </div>\r\n      <div *ngIf=\"rightIcon || rightIconData\" class=\"spacer right-icon\"></div>\r\n      <co-icon *ngIf=\"rightIcon || rightIconData\" class=\"input-text-right-icon\" [icon]=\"rightIcon\"\r\n               [iconData]=\"rightIconData\"\r\n               (click)=\"handleRightIconClick($event)\" (mousedown)=\"handleRightIconMouseDown($event)\"\r\n               (mouseup)=\"handleRightIconMouseUp($event)\"></co-icon>\r\n    </div>\r\n    <!--\r\n            <co-commit-buttons *ngIf=\"showSaveCancel && focused && canSaveOrCancel\"\r\n                               [committing]=\"committing\"\r\n                               [commitFinished]=\"commitFinished\"\r\n                               (commitClick)=\"commitClick($event)\"\r\n                               (cancelClick)=\"cancelClick($event)\"\r\n            >\r\n            </co-commit-buttons>\r\n    -->\r\n  `,\r\n  providers: [\r\n    OverlayService, {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => InputTextComponent)\r\n    }, {\r\n      provide: BaseInputComponent,\r\n      useExisting: InputTextComponent\r\n    }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputTextComponent extends BaseInputComponent<any> implements AfterViewInit {\r\n\r\n  @Input()\r\n  public useContent: boolean = false;\r\n\r\n  @Input()\r\n  public placeholder: string = '';\r\n\r\n  @Input()\r\n  public align: string = 'left';\r\n\r\n  @Input()\r\n  public type: string = 'text';\r\n\r\n  @Input()\r\n  public formatPipe: any;\r\n\r\n  @Input()\r\n  public min: number;\r\n\r\n  @Input()\r\n  public max: number;\r\n\r\n  @Input()\r\n  public pattern: string = 'dd-MM-yyyy';\r\n\r\n  @Input()\r\n  public digitsOnly: boolean = false;\r\n\r\n  @Input()\r\n  public excludePlusMinus: boolean = true;\r\n\r\n  @Input()\r\n  public showClearButton: boolean = true;\r\n\r\n  @Input()\r\n  public keyDownWhiteList: KeyboardCode[];\r\n\r\n  @Input()\r\n  public showPlaceholderOnFocus: boolean = true;\r\n\r\n  @Input()\r\n  public leftIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public rightIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public leftIconData: SafeHtml | undefined;\r\n\r\n  @Input()\r\n  public rightIconData: SafeHtml | undefined;\r\n\r\n  @Input()\r\n  public selectOnFocus: boolean = false;\r\n\r\n  @Input()\r\n  public emptyPlace: boolean = false;\r\n\r\n  @HostBinding('class.no-style')\r\n  @Input()\r\n  public noStyle: boolean = false;\r\n\r\n  @Input()\r\n  @HostBinding('class.hide-arrows')\r\n  public hideArrowButtons: boolean = false;\r\n\r\n  @HostBinding(\"class.isDate\")\r\n  public get isDate(): boolean {\r\n    return this.type === \"date\";\r\n  }\r\n\r\n  @Output()\r\n  public leftIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public leftIconMouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public leftIconMouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconMouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconMouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public clearIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public isFocused: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  @HostBinding('class.co-input-text')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @HostBinding('class.has-left-icon')\r\n  public get hasLeftIcon(): boolean {\r\n    return this.leftIcon !== undefined && this.leftIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-right-icon')\r\n  public get hasRightIcon(): boolean {\r\n    return this.rightIcon !== undefined && this.rightIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-own-label')\r\n  public hasOwnLabel: boolean = true;\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  public handleDocumentMouseUp(event: MouseEvent) {\r\n    if (this._isLeftIconMouseDown) {\r\n      this.leftIconMouseUp.next(event);\r\n    }\r\n    if (this._isRightIconMouseDown) {\r\n      this.rightIconMouseUp.next(event);\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set model(value: any) {\r\n    if (this.type === 'number' && !isNaN(value)) {\r\n      if (this.min && value < this.min || this.max && value > this.max) {\r\n        super.model = this._initialModel;\r\n      } else {\r\n        super.model = value;\r\n      }\r\n    } else {\r\n      super.model = value;\r\n    }\r\n  }\r\n\r\n  public get model() {\r\n    return super.model;\r\n  }\r\n\r\n  public get pipedModel(): any {\r\n    if (this.formatPipe) {\r\n      try {\r\n        const pipe = new this.formatPipe(this);\r\n        return pipe.transform(this.model);\r\n      } catch (e) {\r\n      }\r\n    }\r\n    return this.model;\r\n  }\r\n\r\n  public isFocusedOnDate: boolean = false;\r\n  private _isLeftIconMouseDown: boolean = false;\r\n  private _isRightIconMouseDown: boolean = false;\r\n\r\n  constructor(\r\n    @Optional() public formComponent: FormComponent,\r\n    protected injector: Injector,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    protected overlayService: OverlayService,\r\n    protected componentFactoryResolver: ComponentFactoryResolver,\r\n    protected formUserChangeListener?: FormInputUserModelChangeListenerService,\r\n    protected ngZoneWrapper?: NgZoneWrapperService,\r\n    public elementRef?: ElementRef,\r\n  ) {\r\n    super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\r\n    super._markAsOnPush();\r\n  }\r\n\r\n  // exclude some non-digit characters, since input type 'number' still allows the characters -, + and e\r\n  public excludeNonDigitChars(event): boolean {\r\n    const excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];\r\n\r\n    return !excludedKeys.includes(event.key);\r\n  }\r\n\r\n  public handleLeftIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.leftIconClick.emit(event);\r\n  }\r\n\r\n  public handleLeftIconMouseDown(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isLeftIconMouseDown = true;\r\n    this.leftIconMouseDown.emit(event);\r\n  }\r\n\r\n  public handleLeftIconMouseUp(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isLeftIconMouseDown = false;\r\n    this.leftIconMouseUp.emit(event);\r\n  }\r\n\r\n  public handleRightIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.rightIconClick.emit(event);\r\n  }\r\n\r\n  public handleRightIconMouseDown(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isRightIconMouseDown = true;\r\n    this.rightIconMouseDown.emit(event);\r\n  }\r\n\r\n  public handleRightIconMouseUp(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isRightIconMouseDown = false;\r\n    this.rightIconMouseUp.emit(event);\r\n  }\r\n\r\n  public handleInputFocus(event: FocusEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    if (this.type === 'date') {\r\n      this.isFocusedOnDate = true; // Switch to 'date' type when focused\r\n    }\r\n    if (this.selectOnFocus) {\r\n      this.input.select();\r\n    }\r\n    this.isFocused.emit(true);\r\n  }\r\n\r\n  public handleBlur(event: FocusEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    if (this.type === 'date') {\r\n      this.isFocusedOnDate = false;\r\n    }\r\n    this.isFocused.emit(false);\r\n  }\r\n\r\n  public handleDoFocus(event: MouseEvent): void {\r\n    if (!this.readonly) {\r\n      this.doFocus(event);\r\n    }\r\n  }\r\n\r\n  public clearInput(event: MouseEvent) {\r\n    this.setModel(null);\r\n    this.clearIconClick.emit(event);\r\n  }\r\n}\r\n"]}
|
|
361
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-text/input-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, EventEmitter, forwardRef, HostBinding, HostListener, Injector, Input, Optional, Output, ViewEncapsulation} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {KeyboardCode} from '../../core/enum/keyboard-code.enum';\r\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\r\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\r\nimport {FormComponent} from '../form/form.component';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {OverlayService} from '../../service/overlay.service';\r\n\r\n@Component({\r\n  selector: 'co-input-text',\r\n  template: `\r\n    <div class=\"input-text-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n      <co-icon *ngIf=\"leftIcon || leftIconData\" class=\"input-text-left-icon\" [icon]=\"leftIcon\" [iconData]=\"leftIconData\"\r\n               (click)=\"handleLeftIconClick($event)\" (mousedown)=\"handleLeftIconMouseDown($event)\"\r\n               (mouseup)=\"handleLeftIconMouseUp($event)\"></co-icon>\r\n      <div *ngIf=\"leftIcon || leftIconData\" class=\"spacer left-icon\"></div>\r\n      <div class=\"input-wrapper\">\r\n        <label *ngIf=\"showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)\"\r\n               [textContent]=\"placeholder\"></label>\r\n        <span class=\"input-text-formatted\" *ngIf=\"!focused && !useContent && formatPipe\"\r\n              [class.show]=\"!focused && !useContent && formatPipe\"\r\n              [ngClass]=\"align\"\r\n              [textContent]=\"pipedModel\"\r\n              (click)=\"handleDoFocus($event)\"\r\n        ></span>\r\n        <input [class.show]=\"focused || !formatPipe\" #input\r\n               [class.input-input-hidden]=\"useContent\"\r\n               [ngClass]=\"align\"\r\n               [type]=\"isWeekInputMode ? 'text' : (isFocusedOnDate || (hasValue && emptyPlace)) ? 'date' : (digitsOnly ? 'number' : (type === 'date' ? 'text' : type))\"\r\n               [placeholder]=\"type === 'date' && !isFocusedOnDate ? '' : ''\"\r\n               [pattern]=\"type === 'date' ? pattern : undefined\"\r\n               [ngModel]=\"model\"\r\n               [min]=\"(type === 'number' || type === 'date') && this.min ? this.min : undefined\"\r\n               [max]=\"(type === 'number' || type === 'date') && this.max ? this.max : undefined\"\r\n               [readonly]=\"readonly\"\r\n               [required]=\"required\"\r\n               (ngModelChange)=\"modelChange.emit($event)\"\r\n               (keydown)=\"handleKeyDownInput($event)\"\r\n               (keyup)=\"keyUp.emit($event)\"\r\n               (focusin)=\"handleInputFocus($event)\"\r\n               (focusout)=\"handleBlur($event)\"\r\n        >\r\n        <ng-container *ngIf=\"useContent\">\r\n          <div class=\"input-content-wrapper\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n        </ng-container>\r\n        <co-icon [class.show]=\"showClearButton && hasValue && !readonly\" class=\"input-text-clear-button\"\r\n                 [icon]=\"icons.CrossSkinny\" (click)=\"clearInput($event)\"></co-icon>\r\n        <div class=\"required-indicator\"></div>\r\n      </div>\r\n      <div *ngIf=\"rightIcon || rightIconData\" class=\"spacer right-icon\"></div>\r\n      <co-icon *ngIf=\"rightIcon || rightIconData\" class=\"input-text-right-icon\" [icon]=\"rightIcon\"\r\n               [iconData]=\"rightIconData\"\r\n               (click)=\"handleRightIconClick($event)\" (mousedown)=\"handleRightIconMouseDown($event)\"\r\n               (mouseup)=\"handleRightIconMouseUp($event)\"></co-icon>\r\n    </div>\r\n    <!--\r\n            <co-commit-buttons *ngIf=\"showSaveCancel && focused && canSaveOrCancel\"\r\n                               [committing]=\"committing\"\r\n                               [commitFinished]=\"commitFinished\"\r\n                               (commitClick)=\"commitClick($event)\"\r\n                               (cancelClick)=\"cancelClick($event)\"\r\n            >\r\n            </co-commit-buttons>\r\n    -->\r\n  `,\r\n  providers: [\r\n    OverlayService, {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => InputTextComponent)\r\n    }, {\r\n      provide: BaseInputComponent,\r\n      useExisting: InputTextComponent\r\n    }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputTextComponent extends BaseInputComponent<any> implements AfterViewInit {\r\n\r\n  @Input()\r\n  public useContent: boolean = false;\r\n\r\n  @Input()\r\n  public placeholder: string = '';\r\n\r\n  @Input()\r\n  public align: string = 'left';\r\n\r\n  @Input()\r\n  public type: string = 'text';\r\n\r\n  @Input()\r\n  public formatPipe: any;\r\n\r\n  @Input()\r\n  public min: number;\r\n\r\n  @Input()\r\n  public max: number;\r\n\r\n  @Input()\r\n  public pattern: string = 'dd-MM-yyyy';\r\n\r\n  @Input()\r\n  public digitsOnly: boolean = false;\r\n\r\n  @Input()\r\n  public excludePlusMinus: boolean = true;\r\n\r\n  @Input()\r\n  public showClearButton: boolean = true;\r\n\r\n  @Input()\r\n  public keyDownWhiteList: KeyboardCode[];\r\n\r\n  @Input()\r\n  public showPlaceholderOnFocus: boolean = true;\r\n\r\n  @Input()\r\n  public leftIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public rightIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public leftIconData: SafeHtml | undefined;\r\n\r\n  @Input()\r\n  public rightIconData: SafeHtml | undefined;\r\n\r\n  @Input()\r\n  public selectOnFocus: boolean = false;\r\n\r\n  @Input()\r\n  public emptyPlace: boolean = false;\r\n\r\n  @Input()\r\n  public firstDayOfWeek: string = '1'; // default is sunday ioneJS\r\n\r\n  @HostBinding('class.no-style')\r\n  @Input()\r\n  public noStyle: boolean = false;\r\n\r\n  @Input()\r\n  @HostBinding('class.hide-arrows')\r\n  public hideArrowButtons: boolean = false;\r\n\r\n  @HostBinding(\"class.isDate\")\r\n  public get isDate(): boolean {\r\n    return this.type === \"date\";\r\n  }\r\n\r\n  @Output()\r\n  public leftIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public leftIconMouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public leftIconMouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconMouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconMouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public clearIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public isFocused: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  @HostBinding('class.co-input-text')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @HostBinding('class.has-left-icon')\r\n  public get hasLeftIcon(): boolean {\r\n    return this.leftIcon !== undefined && this.leftIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-right-icon')\r\n  public get hasRightIcon(): boolean {\r\n    return this.rightIcon !== undefined && this.rightIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-own-label')\r\n  public hasOwnLabel: boolean = true;\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  public handleDocumentMouseUp(event: MouseEvent) {\r\n    if (this._isLeftIconMouseDown) {\r\n      this.leftIconMouseUp.next(event);\r\n    }\r\n    if (this._isRightIconMouseDown) {\r\n      this.rightIconMouseUp.next(event);\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set model(value: any) {\r\n    if (this.type === 'number' && !isNaN(value)) {\r\n      if (this.min && value < this.min || this.max && value > this.max) {\r\n        super.model = this._initialModel;\r\n      } else {\r\n        super.model = value;\r\n      }\r\n    } else {\r\n      super.model = value;\r\n    }\r\n  }\r\n\r\n  public get model() {\r\n    return super.model;\r\n  }\r\n\r\n  public get pipedModel(): any {\r\n    if (this.formatPipe) {\r\n      try {\r\n        const pipe = new this.formatPipe(this);\r\n        return pipe.transform(this.model);\r\n      } catch (e) {\r\n      }\r\n    }\r\n    return this.model;\r\n  }\r\n\r\n  public isFocusedOnDate: boolean = false;\r\n  public weekInputBuffer: string = '';\r\n  public isWeekInputMode: boolean = false;\r\n  private _isLeftIconMouseDown: boolean = false;\r\n  private _isRightIconMouseDown: boolean = false;\r\n\r\n  constructor(\r\n    @Optional() public formComponent: FormComponent,\r\n    protected injector: Injector,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    protected overlayService: OverlayService,\r\n    protected componentFactoryResolver: ComponentFactoryResolver,\r\n    protected formUserChangeListener?: FormInputUserModelChangeListenerService,\r\n    protected ngZoneWrapper?: NgZoneWrapperService,\r\n    public elementRef?: ElementRef,\r\n  ) {\r\n    super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\r\n    super._markAsOnPush();\r\n  }\r\n\r\n  public handleLeftIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.leftIconClick.emit(event);\r\n  }\r\n\r\n  public handleLeftIconMouseDown(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isLeftIconMouseDown = true;\r\n    this.leftIconMouseDown.emit(event);\r\n  }\r\n\r\n  public handleLeftIconMouseUp(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isLeftIconMouseDown = false;\r\n    this.leftIconMouseUp.emit(event);\r\n  }\r\n\r\n  public handleRightIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.rightIconClick.emit(event);\r\n  }\r\n\r\n  public handleRightIconMouseDown(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isRightIconMouseDown = true;\r\n    this.rightIconMouseDown.emit(event);\r\n  }\r\n\r\n  public handleRightIconMouseUp(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isRightIconMouseDown = false;\r\n    this.rightIconMouseUp.emit(event);\r\n  }\r\n\r\n  public handleInputFocus(event: FocusEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    if (this.type === 'date') {\r\n      this.isFocusedOnDate = true; // Switch to 'date' type when focused\r\n    }\r\n    if (this.selectOnFocus) {\r\n      this.input.select();\r\n    }\r\n    this.isFocused.emit(true);\r\n  }\r\n\r\n  public handleBlur(event: FocusEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    if (this.type === 'date') {\r\n      this.isFocusedOnDate = false;\r\n    }\r\n    this.isFocused.emit(false);\r\n  }\r\n\r\n  public handleDoFocus(event: MouseEvent): void {\r\n    if (!this.readonly) {\r\n      this.doFocus(event);\r\n    }\r\n  }\r\n\r\n  public clearInput(event: MouseEvent) {\r\n    this.setModel(null);\r\n    this.clearIconClick.emit(event);\r\n  }\r\n\r\n  public handleKeyDownInput(event: KeyboardEvent): void {\r\n    const key = event.key.toLowerCase();\r\n    if (this.type === 'date') {\r\n      if (key === 'w') {\r\n        event.preventDefault();\r\n        this.isWeekInputMode = true;\r\n        this.weekInputBuffer = 'w';\r\n        this.model = 'w';\r\n        this.modelChange.emit(this.model);\r\n        return;\r\n      }\r\n      if (this.isWeekInputMode) {\r\n        if (/^\\d$/.test(key)) {\r\n          event.preventDefault();\r\n          this.weekInputBuffer += key;\r\n          this.model = this.weekInputBuffer;\r\n          this.modelChange.emit(this.model);\r\n          return;\r\n        }\r\n        if (key === 'enter' || key === 'tab') {\r\n          event.preventDefault();\r\n          this.convertWeekToDate(this.weekInputBuffer);\r\n          this.isWeekInputMode = false;\r\n          this.weekInputBuffer = '';\r\n          return;\r\n        }\r\n        if (!['backspace', 'delete'].includes(key)) {\r\n          this.isWeekInputMode = false;\r\n          this.weekInputBuffer = '';\r\n        }\r\n      }\r\n    }\r\n    /* old excludeCharacter function */\r\n    if (this.digitsOnly && !this.isWeekInputMode) {\r\n      const excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];\r\n      if (excludedKeys.includes(event.key)) {\r\n        event.preventDefault();\r\n      }\r\n    }\r\n  }\r\n\r\n  private convertWeekToDate(weekStr: string): void {\r\n    const match = weekStr.match(/^w0*(\\d{1,2})$/i);\r\n    if (!match) return;\r\n\r\n    const week = parseInt(match[1], 10);\r\n    if (week < 1 || week > 53) return;\r\n\r\n    const today = new Date();\r\n    let year = today.getFullYear();\r\n\r\n    // Internal default first day of week\r\n    let weekdayOffset = parseInt(this.firstDayOfWeek, 10);\r\n    if (isNaN(weekdayOffset) || weekdayOffset < 1 || weekdayOffset > 7) {\r\n      weekdayOffset = 2;\r\n    }\r\n\r\n    // Convert to JS weekday index where 0 = Sunday ... 6 = Saturday\r\n    const jsWeekdayIndex = (weekdayOffset - 1) % 7;\r\n    const jan4 = new Date(year, 0, 4);\r\n    const jan4Day = jan4.getDay();\r\n    const diffToMonday = (jan4Day + 6) % 7;\r\n    const firstWeekMonday = new Date(jan4);\r\n    firstWeekMonday.setDate(jan4.getDate() - diffToMonday); // Monday of week 1\r\n    const baseWeekStart = new Date(firstWeekMonday);\r\n    baseWeekStart.setDate(baseWeekStart.getDate() + (week - 1) * 7);\r\n    const targetDate = new Date(baseWeekStart);\r\n    targetDate.setDate(baseWeekStart.getDate() + jsWeekdayIndex);\r\n    if (targetDate < today) {\r\n      year += 1;\r\n      const jan4Next = new Date(year, 0, 4);\r\n      const jan4DayNext = jan4Next.getDay();\r\n      const diffToMondayNext = (jan4DayNext + 6) % 7;\r\n      const firstWeekMondayNext = new Date(jan4Next);\r\n      firstWeekMondayNext.setDate(jan4Next.getDate() - diffToMondayNext);\r\n      const baseWeekStartNext = new Date(firstWeekMondayNext);\r\n      baseWeekStartNext.setDate(baseWeekStartNext.getDate() + (week - 1) * 7);\r\n\r\n      targetDate.setFullYear(year);\r\n      targetDate.setMonth(baseWeekStartNext.getMonth());\r\n      targetDate.setDate(baseWeekStartNext.getDate() + jsWeekdayIndex);\r\n    }\r\n\r\n    this.model = targetDate.toISOString().substring(0, 10);\r\n    this.modelChange.emit(this.model);\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
2
2
|
import { CoreComponentsIcon } from "../../core/enum/core-components-icon.enum";
|
|
3
3
|
import { IconCacheService } from "../icon/icon-cache.service";
|
|
4
|
+
import { BatchDeliveryCategory } from '../../core/enum/batch-delivery-category.enum';
|
|
4
5
|
export class ListOfIconsComponent {
|
|
5
6
|
constructor(iconCacheService, icons) {
|
|
6
7
|
this.iconCacheService = iconCacheService;
|
|
@@ -12,8 +13,8 @@ export class ListOfIconsComponent {
|
|
|
12
13
|
this.showSubCategories = false;
|
|
13
14
|
this._collection = [];
|
|
14
15
|
this.subCategories = [
|
|
15
|
-
{ icon: this.iconCacheService.getIcon(this.Icon.BoxesPackingRegular), label:
|
|
16
|
-
{ icon: this.iconCacheService.getIcon(this.Icon.RegularBoxesPackingCircleCheck), label:
|
|
16
|
+
{ icon: this.iconCacheService.getIcon(this.Icon.BoxesPackingRegular), label: BatchDeliveryCategory.ToPick },
|
|
17
|
+
{ icon: this.iconCacheService.getIcon(this.Icon.RegularBoxesPackingCircleCheck), label: BatchDeliveryCategory.Picked }
|
|
17
18
|
];
|
|
18
19
|
}
|
|
19
20
|
set collection(value) {
|
|
@@ -34,7 +35,7 @@ export class ListOfIconsComponent {
|
|
|
34
35
|
this.showMenu = !this.showMenu;
|
|
35
36
|
}
|
|
36
37
|
selectItem(item) {
|
|
37
|
-
if (item.label.toUpperCase() ===
|
|
38
|
+
if (item.label.toUpperCase() === BatchDeliveryCategory.Logistics) {
|
|
38
39
|
this.showSubCategories = !this.showSubCategories;
|
|
39
40
|
return;
|
|
40
41
|
}
|
|
@@ -65,12 +66,17 @@ ListOfIconsComponent.decorators = [
|
|
|
65
66
|
<div class="icon-item" *ngFor="let item of collection" (click)="selectItem(item)"
|
|
66
67
|
[class.active]="item === activeItem">
|
|
67
68
|
<co-icon [iconData]="item.icon" [style.width.px]="iconSize" [style.height.px]="iconSize"></co-icon>
|
|
68
|
-
|
|
69
|
+
<div class="label" [textContent]="item.label | coreLocalize"></div>
|
|
69
70
|
</div>
|
|
70
71
|
<div class="picking-type-wrapper" *ngIf="showSubCategories">
|
|
71
72
|
<div class="button-wrapper" *ngFor="let subCategory of subCategories" (click)="handlePickingCategoryClicked(subCategory)">
|
|
72
|
-
|
|
73
|
-
|
|
73
|
+
<co-icon
|
|
74
|
+
class="co-transaction-button-bar-icon"
|
|
75
|
+
[iconData]="subCategory.icon"
|
|
76
|
+
[style.width.px]="iconSize"
|
|
77
|
+
[style.height.px]="iconSize">
|
|
78
|
+
</co-icon>
|
|
79
|
+
<span class="button-title" [textContent]="subCategory.label | coreLocalize"></span>
|
|
74
80
|
</div>
|
|
75
81
|
</div>
|
|
76
82
|
</div>
|
|
@@ -89,4 +95,4 @@ ListOfIconsComponent.propDecorators = {
|
|
|
89
95
|
itemSelected: [{ type: Output }],
|
|
90
96
|
showClass: [{ type: HostBinding, args: ['class.co-list-of-icons',] }]
|
|
91
97
|
};
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-icons.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-icons/list-of-icons.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAU,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAC7G,OAAO,EAAC,kBAAkB,EAAC,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAC,gBAAgB,EAAC,MAAM,4BAA4B,CAAC;AAE5D,OAAO,EAAC,qBAAqB,EAAC,MAAM,8CAA8C,CAAC;AA+BnF,MAAM,OAAO,oBAAoB;IAkC/B,YACS,gBAAkC,EAClC,KAAuB;QADvB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,UAAK,GAAL,KAAK,CAAkB;QAzBzB,aAAQ,GAAW,EAAE,CAAC;QAMtB,iBAAY,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAOnE,SAAI,GAAQ,kBAAkB,CAAC;QACxC,aAAQ,GAAY,KAAK,CAAC;QAC1B,sBAAiB,GAAY,KAAK,CAAC;QAClC,gBAAW,GAAmB,EAAE,CAAC;QAElC,kBAAa,GAAmB;YACrC,EAAC,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,qBAAqB,CAAC,MAAM,EAAC;YACzG,EAAC,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,8BAA8B,CAAC,EAAE,KAAK,EAAE,qBAAqB,CAAC,MAAM,EAAC;SACrH,CAAC;IAMF,CAAC;IArCD,IACW,UAAU,CAAC,KAAqB;QACzC,IAAI,CAAC,WAAW,GAAG,KAAK,IAAI,EAAE,CAAC;IACjC,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAYM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAkBM,QAAQ;QACb,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YACjC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;SACtC;IACH,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;IACjC,CAAC;IAEM,UAAU,CAAC,IAAkB;QAClC,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,qBAAqB,CAAC,SAAS,EAAE;YAChE,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;YACjD,OAAO;SACR;QAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAEM,4BAA4B,CAAC,WAAyB;QAC3D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;;;YAnGF,SAAS,SAAC;gBACT,QAAQ,EAAE,kBAAkB;gBAC5B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;GAwBT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YAhCO,gBAAgB;YAAhB,gBAAgB;;;yBAkCrB,KAAK;uBASL,KAAK;yBAGL,KAAK;2BAGL,MAAM;wBAGN,WAAW,SAAC,wBAAwB","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\nimport {IconCacheService} from \"../icon/icon-cache.service\";\r\nimport {IconListItem} from \"../../model/icon-list-item\";\r\nimport {BatchDeliveryCategory} from '../../core/enum/batch-delivery-category.enum';\r\n\r\n@Component({\r\n  selector: 'co-list-of-icons',\r\n  template: `\r\n    <div class=\"icon-item active\" [class.menu-opened]=\"showMenu\" (click)=\"toggleMenu()\">\r\n      <co-icon [iconData]=\"activeItem.icon\" [style.width.px]=\"iconSize\" [style.height.px]=\"iconSize\"></co-icon>\r\n      <co-icon *ngIf=\"!showMenu\" class=\"drop-arrow\" [iconData]=\"icons.getIcon(Icon.CaretDownSolid)\"></co-icon>\r\n      <co-icon *ngIf=\"showMenu\" class=\"drop-arrow\" [iconData]=\"icons.getIcon(Icon.CaretUpSolid)\"></co-icon>\r\n    </div>\r\n    <div class=\"dropdown-menu\" *ngIf=\"showMenu\" (clickOutside)=\"onClickOutside()\">\r\n      <div class=\"icon-item\" *ngFor=\"let item of collection\" (click)=\"selectItem(item)\"\r\n           [class.active]=\"item === activeItem\">\r\n        <co-icon [iconData]=\"item.icon\" [style.width.px]=\"iconSize\" [style.height.px]=\"iconSize\"></co-icon>\r\n          <div class=\"label\" [textContent]=\"item.label | coreLocalize\"></div>\r\n      </div>\r\n      <div class=\"picking-type-wrapper\" *ngIf=\"showSubCategories\">\r\n        <div class=\"button-wrapper\" *ngFor=\"let subCategory of subCategories\" (click)=\"handlePickingCategoryClicked(subCategory)\">\r\n            <co-icon\r\n                    class=\"co-transaction-button-bar-icon\"\r\n                    [iconData]=\"subCategory.icon\"\r\n                    [style.width.px]=\"iconSize\"\r\n                    [style.height.px]=\"iconSize\">\r\n            </co-icon>\r\n            <span class=\"button-title\" [textContent]=\"subCategory.label | coreLocalize\"></span>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfIconsComponent implements OnInit {\r\n  @Input()\r\n  public set collection(value: IconListItem[]) {\r\n    this._collection = value || [];\r\n  }\r\n\r\n  public get collection(): IconListItem[] {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public iconSize: number = 25;\r\n\r\n  @Input()\r\n  public activeItem?: IconListItem;\r\n\r\n  @Output()\r\n  public itemSelected: EventEmitter<IconListItem> = new EventEmitter<IconListItem>();\r\n\r\n  @HostBinding('class.co-list-of-icons')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public readonly Icon: any = CoreComponentsIcon;\r\n  public showMenu: boolean = false;\r\n  public showSubCategories: boolean = false;\r\n  private _collection: IconListItem[] = [];\r\n\r\n  public subCategories: IconListItem[] = [\r\n    {icon: this.iconCacheService.getIcon(this.Icon.BoxesPackingRegular), label: BatchDeliveryCategory.ToPick},\r\n    {icon: this.iconCacheService.getIcon(this.Icon.RegularBoxesPackingCircleCheck), label: BatchDeliveryCategory.Picked}\r\n  ];\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    public icons: IconCacheService\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    if (this.activeItem === undefined) {\r\n      this.activeItem = this.collection[0];\r\n    }\r\n  }\r\n\r\n  public toggleMenu(): void {\r\n    this.showMenu = !this.showMenu;\r\n  }\r\n\r\n  public selectItem(item: IconListItem): void {\r\n    if (item.label.toUpperCase() === BatchDeliveryCategory.Logistics) {\r\n      this.showSubCategories = !this.showSubCategories;\r\n      return;\r\n    }\r\n\r\n    this.activeItem = item;\r\n    this.showMenu = false;\r\n    this.itemSelected.emit(this.activeItem);\r\n  }\r\n\r\n  public handlePickingCategoryClicked(subCategory: IconListItem): void {\r\n    this.itemSelected.emit(subCategory);\r\n    this.showMenu = false;\r\n    this.showSubCategories = false;\r\n  }\r\n\r\n  public onClickOutside(): void {\r\n    this.showMenu = false;\r\n    this.showSubCategories = false;\r\n  }\r\n}\r\n"]}
|
|
@@ -4,6 +4,7 @@ import { FormsModule } from "@angular/forms";
|
|
|
4
4
|
import { ListOfIconsComponent } from "./list-of-icons.component";
|
|
5
5
|
import { IconModule } from "../icon/icon.module";
|
|
6
6
|
import { ClickoutsideModule } from "../../directives/clickoutside/clickoutside.module";
|
|
7
|
+
import { CoreComponentsTranslationModule } from '../../translation/core-components-translation.module';
|
|
7
8
|
export class ListOfIconsModule {
|
|
8
9
|
}
|
|
9
10
|
ListOfIconsModule.decorators = [
|
|
@@ -12,7 +13,8 @@ ListOfIconsModule.decorators = [
|
|
|
12
13
|
CommonModule,
|
|
13
14
|
FormsModule,
|
|
14
15
|
IconModule,
|
|
15
|
-
ClickoutsideModule
|
|
16
|
+
ClickoutsideModule,
|
|
17
|
+
CoreComponentsTranslationModule
|
|
16
18
|
],
|
|
17
19
|
declarations: [
|
|
18
20
|
ListOfIconsComponent
|
|
@@ -22,4 +24,4 @@ ListOfIconsModule.decorators = [
|
|
|
22
24
|
]
|
|
23
25
|
},] }
|
|
24
26
|
];
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1vZi1pY29ucy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvbGlzdC1vZi1pY29ucy9saXN0LW9mLWljb25zLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDL0QsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQy9DLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQ3JGLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLHNEQUFzRCxDQUFDO0FBaUJyRyxNQUFNLE9BQU8saUJBQWlCOzs7WUFmN0IsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLFdBQVc7b0JBQ1gsVUFBVTtvQkFDVixrQkFBa0I7b0JBQ2xCLCtCQUErQjtpQkFDaEM7Z0JBQ0QsWUFBWSxFQUFFO29CQUNaLG9CQUFvQjtpQkFDckI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLG9CQUFvQjtpQkFDckI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7Rm9ybXNNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5pbXBvcnQge0xpc3RPZkljb25zQ29tcG9uZW50fSBmcm9tIFwiLi9saXN0LW9mLWljb25zLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0ljb25Nb2R1bGV9IGZyb20gXCIuLi9pY29uL2ljb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7Q2xpY2tvdXRzaWRlTW9kdWxlfSBmcm9tIFwiLi4vLi4vZGlyZWN0aXZlcy9jbGlja291dHNpZGUvY2xpY2tvdXRzaWRlLm1vZHVsZVwiO1xyXG5pbXBvcnQge0NvcmVDb21wb25lbnRzVHJhbnNsYXRpb25Nb2R1bGV9IGZyb20gJy4uLy4uL3RyYW5zbGF0aW9uL2NvcmUtY29tcG9uZW50cy10cmFuc2xhdGlvbi5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIEljb25Nb2R1bGUsXHJcbiAgICBDbGlja291dHNpZGVNb2R1bGUsXHJcbiAgICBDb3JlQ29tcG9uZW50c1RyYW5zbGF0aW9uTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIExpc3RPZkljb25zQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBMaXN0T2ZJY29uc0NvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIExpc3RPZkljb25zTW9kdWxlIHt9XHJcbiJdfQ==
|