장선근
6 years ago
225 changed files with 30860 additions and 23260 deletions
-
106_src/admin/js/admin.js
-
118_src/admin/js/dx.all.js
-
285_src/admin/js/dx.messages.ko.js
-
861_src/admin/js/jquery.formatter.js
-
2_src/admin/js/modules/board.js
-
212_src/admin/js/modules/datagrid.js
-
23_src/admin/js/modules/toast.js
-
18_src/admin/scss/_variables.scss
-
18_src/admin/scss/admin.scss
-
51_src/admin/scss/boot/_fonts.scss
-
30_src/admin/scss/common/_layout.scss
-
73_src/admin/scss/common/_utility.scss
-
2_src/admin/scss/components/_buttons.scss
-
92_src/admin/scss/components/_form.scss
-
18_src/admin/scss/components/_grid.scss
-
4_src/admin/scss/components/_label.scss
-
37_src/admin/scss/plugins/_plugins_custom.scss
-
769_src/admin/scss/plugins/ax5ui/_ax5grid.scss
-
256_src/admin/scss/plugins/ax5ui/_ax5toast.scss
-
7403_src/admin/scss/plugins/devextreme/dx.common.scss
-
13343_src/admin/scss/plugins/devextreme/dx.light.compact.scss
-
23_src/admin/scss/plugins/fontawesome5/_rotated-flipped.scss
-
21_src/admin/scss/plugins/fontawesome5/brands.scss
-
16_src/admin/scss/plugins/fontawesome5/fontawesome.scss
-
22_src/admin/scss/plugins/fontawesome5/light.scss
-
23_src/admin/scss/plugins/fontawesome5/solid.scss
-
569_src/admin/scss/plugins/jquery.datetimepicker.css
-
1_src/common/css/global.css
-
200_src/common/css/toastr.css
-
30_src/common/js/global.js
-
0_src/common/js/modules/board.js
-
126_src/common/js/modules/components.js
-
0_src/common/js/modules/dropdown.js
-
98_src/common/js/modules/formatter.js
-
0_src/common/js/modules/member.js
-
194_src/common/js/modules/modal.js
-
28_src/common/js/modules/popup.js
-
49_src/common/js/modules/regex.js
-
288_src/common/js/plugins/autosize.js
-
5_src/common/scss/_function.scss
-
33_src/common/scss/_mixins.scss
-
136_src/common/scss/_reset.scss
-
98_src/common/scss/_utility.scss
-
15_src/common/scss/global.scss
-
0_src/common/scss/plugins/_toastr.scss
-
0_src/common/scss/plugins/ax5ui/_ax5.scss
-
0_src/common/scss/plugins/ax5ui/_ax5mask.scss
-
0_src/common/scss/plugins/ax5ui/_ax5modal.scss
-
0_src/common/scss/plugins/ax5ui/_bourbon_support.scss
-
0_src/common/scss/plugins/ax5ui/_mixin.scss
-
0_src/common/scss/plugins/fontawesome5/_animated.scss
-
0_src/common/scss/plugins/fontawesome5/_bordered-pulled.scss
-
0_src/common/scss/plugins/fontawesome5/_core.scss
-
0_src/common/scss/plugins/fontawesome5/_fixed-width.scss
-
293_src/common/scss/plugins/fontawesome5/_icons.scss
-
0_src/common/scss/plugins/fontawesome5/_larger.scss
-
0_src/common/scss/plugins/fontawesome5/_list.scss
-
1_src/common/scss/plugins/fontawesome5/_mixins.scss
-
5_src/common/scss/plugins/fontawesome5/_rotated-flipped.scss
-
0_src/common/scss/plugins/fontawesome5/_screen-reader.scss
-
0_src/common/scss/plugins/fontawesome5/_shims.scss
-
0_src/common/scss/plugins/fontawesome5/_stacked.scss
-
296_src/common/scss/plugins/fontawesome5/_variables.scss
-
3_src/common/scss/plugins/fontawesome5/brands.scss
-
2_src/common/scss/plugins/fontawesome5/fontawesome.scss
-
3_src/common/scss/plugins/fontawesome5/light.scss
-
3_src/common/scss/plugins/fontawesome5/regular.scss
-
3_src/common/scss/plugins/fontawesome5/solid.scss
-
2_src/common/scss/plugins/fontawesome5/v4-shims.scss
-
5_src/desktop/scss/boot/_function.scss
-
56_src/desktop/scss/boot/_mixins.scss
-
74_src/desktop/scss/common/_utility.scss
-
10_src/desktop/scss/desktop.scss
-
20_src/desktop/scss/plugins/fontawesome5/_animated.scss
-
20_src/desktop/scss/plugins/fontawesome5/_bordered-pulled.scss
-
20_src/desktop/scss/plugins/fontawesome5/_core.scss
-
6_src/desktop/scss/plugins/fontawesome5/_fixed-width.scss
-
1786_src/desktop/scss/plugins/fontawesome5/_icons.scss
-
23_src/desktop/scss/plugins/fontawesome5/_larger.scss
-
18_src/desktop/scss/plugins/fontawesome5/_list.scss
-
57_src/desktop/scss/plugins/fontawesome5/_mixins.scss
-
5_src/desktop/scss/plugins/fontawesome5/_screen-reader.scss
-
2062_src/desktop/scss/plugins/fontawesome5/_shims.scss
-
31_src/desktop/scss/plugins/fontawesome5/_stacked.scss
-
1800_src/desktop/scss/plugins/fontawesome5/_variables.scss
-
16_src/desktop/scss/plugins/fontawesome5/fontawesome.scss
-
22_src/desktop/scss/plugins/fontawesome5/light.scss
-
22_src/desktop/scss/plugins/fontawesome5/regular.scss
-
6_src/desktop/scss/plugins/fontawesome5/v4-shims.scss
-
5_src/mobile/scss/boot/_function.scss
-
56_src/mobile/scss/boot/_mixins.scss
-
30_src/mobile/scss/common/_utility.scss
-
10_src/mobile/scss/mobile.scss
-
220_src/mobile/scss/plugins/_toastr.scss
-
20_src/mobile/scss/plugins/fontawesome5/_animated.scss
-
20_src/mobile/scss/plugins/fontawesome5/_bordered-pulled.scss
-
20_src/mobile/scss/plugins/fontawesome5/_core.scss
-
6_src/mobile/scss/plugins/fontawesome5/_fixed-width.scss
-
1786_src/mobile/scss/plugins/fontawesome5/_icons.scss
-
23_src/mobile/scss/plugins/fontawesome5/_larger.scss
118
_src/admin/js/dx.all.js
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -0,0 +1,285 @@ |
|||
/*! |
|||
* DevExtreme (dx.messages.en.js) |
|||
* Version: 19.1.4 |
|||
* Build date: Mon Jun 17 2019 |
|||
* |
|||
* Copyright (c) 2012 - 2019 Developer Express Inc. ALL RIGHTS RESERVED |
|||
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
|
|||
*/ |
|||
"use strict"; |
|||
|
|||
! function(root, factory) { |
|||
if ("function" === typeof define && define.amd) { |
|||
define(function(require) { |
|||
factory(require("devextreme/localization")) |
|||
}) |
|||
} else { |
|||
if ("object" === typeof module && module.exports) { |
|||
factory(require("devextreme/localization")) |
|||
} else { |
|||
factory(DevExpress.localization) |
|||
} |
|||
} |
|||
}(this, function(localization) { |
|||
localization.loadMessages({ |
|||
ko: { |
|||
Yes: "확인", |
|||
No: "아니오", |
|||
Cancel: "취소", |
|||
Clear: "초기화", |
|||
Done: "완료", |
|||
Loading: "불러오는중...", |
|||
Select: "선택...", |
|||
Search: "검색", |
|||
Back: "뒤로가기", |
|||
OK: "확인", |
|||
"dxCollectionWidget-noDataText": "No data to display", |
|||
"validation-required": "Required", |
|||
"validation-required-formatted": "{0} is required", |
|||
"validation-numeric": "Value must be a number", |
|||
"validation-numeric-formatted": "{0} must be a number", |
|||
"validation-range": "Value is out of range", |
|||
"validation-range-formatted": "{0} is out of range", |
|||
"validation-stringLength": "The length of the value is not correct", |
|||
"validation-stringLength-formatted": "The length of {0} is not correct", |
|||
"validation-custom": "Value is invalid", |
|||
"validation-custom-formatted": "{0} is invalid", |
|||
"validation-compare": "Values do not match", |
|||
"validation-compare-formatted": "{0} does not match", |
|||
"validation-pattern": "Value does not match pattern", |
|||
"validation-pattern-formatted": "{0} does not match pattern", |
|||
"validation-email": "Email is invalid", |
|||
"validation-email-formatted": "{0} is invalid", |
|||
"validation-mask": "Value is invalid", |
|||
"dxLookup-searchPlaceholder": "Minimum character number: {0}", |
|||
"dxList-pullingDownText": "Pull down to refresh...", |
|||
"dxList-pulledDownText": "Release to refresh...", |
|||
"dxList-refreshingText": "Refreshing...", |
|||
"dxList-pageLoadingText": "Loading...", |
|||
"dxList-nextButtonText": "More", |
|||
"dxList-selectAll": "Select All", |
|||
"dxListEditDecorator-delete": "Delete", |
|||
"dxListEditDecorator-more": "More", |
|||
"dxScrollView-pullingDownText": "Pull down to refresh...", |
|||
"dxScrollView-pulledDownText": "Release to refresh...", |
|||
"dxScrollView-refreshingText": "Refreshing...", |
|||
"dxScrollView-reachBottomText": "Loading...", |
|||
"dxDateBox-simulatedDataPickerTitleTime": "시간을 선택하세요", |
|||
"dxDateBox-simulatedDataPickerTitleDate": "날짜를 선택하세요", |
|||
"dxDateBox-simulatedDataPickerTitleDateTime": "날짜와 시간을 선택하세요.", |
|||
"dxDateBox-validation-datetime": "올바른 형식의 날짜나 시간 형식이 아닙니다.", |
|||
"dxFileUploader-selectFile": "Select file", |
|||
"dxFileUploader-dropFile": "or Drop file here", |
|||
"dxFileUploader-bytes": "bytes", |
|||
"dxFileUploader-kb": "kb", |
|||
"dxFileUploader-Mb": "Mb", |
|||
"dxFileUploader-Gb": "Gb", |
|||
"dxFileUploader-upload": "Upload", |
|||
"dxFileUploader-uploaded": "Uploaded", |
|||
"dxFileUploader-readyToUpload": "Ready to upload", |
|||
"dxFileUploader-uploadFailedMessage": "Upload failed", |
|||
"dxFileUploader-invalidFileExtension": "File type is not allowed", |
|||
"dxFileUploader-invalidMaxFileSize": "File is too large", |
|||
"dxFileUploader-invalidMinFileSize": "File is too small", |
|||
"dxRangeSlider-ariaFrom": "From", |
|||
"dxRangeSlider-ariaTill": "Till", |
|||
"dxSwitch-switchedOnText": "ON", |
|||
"dxSwitch-switchedOffText": "OFF", |
|||
"dxForm-optionalMark": "optional", |
|||
"dxForm-requiredMessage": "{0} is required", |
|||
"dxNumberBox-invalidValueMessage": "Value must be a number", |
|||
"dxDataGrid-columnChooserTitle": "Column Chooser", |
|||
"dxDataGrid-columnChooserEmptyText": "Drag a column here to hide it", |
|||
"dxDataGrid-groupContinuesMessage": "Continues on the next page", |
|||
"dxDataGrid-groupContinuedMessage": "Continued from the previous page", |
|||
"dxDataGrid-groupHeaderText": "Group by This Column", |
|||
"dxDataGrid-ungroupHeaderText": "Ungroup", |
|||
"dxDataGrid-ungroupAllText": "Ungroup All", |
|||
"dxDataGrid-editingEditRow": "Edit", |
|||
"dxDataGrid-editingSaveRowChanges": "Save", |
|||
"dxDataGrid-editingCancelRowChanges": "Cancel", |
|||
"dxDataGrid-editingDeleteRow": "Delete", |
|||
"dxDataGrid-editingUndeleteRow": "Undelete", |
|||
"dxDataGrid-editingConfirmDeleteMessage": "Are you sure you want to delete this record?", |
|||
"dxDataGrid-validationCancelChanges": "Cancel changes", |
|||
"dxDataGrid-groupPanelEmptyText": "Drag a column header here to group by that column", |
|||
"dxDataGrid-noDataText": "No data", |
|||
"dxDataGrid-searchPanelPlaceholder": "Search...", |
|||
"dxDataGrid-filterRowShowAllText": "(All)", |
|||
"dxDataGrid-filterRowResetOperationText": "Reset", |
|||
"dxDataGrid-filterRowOperationEquals": "Equals", |
|||
"dxDataGrid-filterRowOperationNotEquals": "Does not equal", |
|||
"dxDataGrid-filterRowOperationLess": "Less than", |
|||
"dxDataGrid-filterRowOperationLessOrEquals": "Less than or equal to", |
|||
"dxDataGrid-filterRowOperationGreater": "Greater than", |
|||
"dxDataGrid-filterRowOperationGreaterOrEquals": "Greater than or equal to", |
|||
"dxDataGrid-filterRowOperationStartsWith": "Starts with", |
|||
"dxDataGrid-filterRowOperationContains": "Contains", |
|||
"dxDataGrid-filterRowOperationNotContains": "Does not contain", |
|||
"dxDataGrid-filterRowOperationEndsWith": "Ends with", |
|||
"dxDataGrid-filterRowOperationBetween": "Between", |
|||
"dxDataGrid-filterRowOperationBetweenStartText": "Start", |
|||
"dxDataGrid-filterRowOperationBetweenEndText": "End", |
|||
"dxDataGrid-applyFilterText": "Apply filter", |
|||
"dxDataGrid-trueText": "true", |
|||
"dxDataGrid-falseText": "false", |
|||
"dxDataGrid-sortingAscendingText": "Sort Ascending", |
|||
"dxDataGrid-sortingDescendingText": "Sort Descending", |
|||
"dxDataGrid-sortingClearText": "Clear Sorting", |
|||
"dxDataGrid-editingSaveAllChanges": "Save changes", |
|||
"dxDataGrid-editingCancelAllChanges": "Discard changes", |
|||
"dxDataGrid-editingAddRow": "Add a row", |
|||
"dxDataGrid-summaryMin": "Min: {0}", |
|||
"dxDataGrid-summaryMinOtherColumn": "Min of {1} is {0}", |
|||
"dxDataGrid-summaryMax": "Max: {0}", |
|||
"dxDataGrid-summaryMaxOtherColumn": "Max of {1} is {0}", |
|||
"dxDataGrid-summaryAvg": "Avg: {0}", |
|||
"dxDataGrid-summaryAvgOtherColumn": "Avg of {1} is {0}", |
|||
"dxDataGrid-summarySum": "Sum: {0}", |
|||
"dxDataGrid-summarySumOtherColumn": "Sum of {1} is {0}", |
|||
"dxDataGrid-summaryCount": "Count: {0}", |
|||
"dxDataGrid-columnFixingFix": "Fix", |
|||
"dxDataGrid-columnFixingUnfix": "Unfix", |
|||
"dxDataGrid-columnFixingLeftPosition": "To the left", |
|||
"dxDataGrid-columnFixingRightPosition": "To the right", |
|||
"dxDataGrid-exportTo": "Export", |
|||
"dxDataGrid-exportToExcel": "Export to Excel file", |
|||
"dxDataGrid-excelFormat": "Excel file", |
|||
"dxDataGrid-selectedRows": "Selected rows", |
|||
"dxDataGrid-exportSelectedRows": "Export selected rows", |
|||
"dxDataGrid-exportAll": "Export all data", |
|||
"dxDataGrid-headerFilterEmptyValue": "(Blanks)", |
|||
"dxDataGrid-headerFilterOK": "OK", |
|||
"dxDataGrid-headerFilterCancel": "Cancel", |
|||
"dxDataGrid-ariaColumn": "Column", |
|||
"dxDataGrid-ariaValue": "Value", |
|||
"dxDataGrid-ariaFilterCell": "Filter cell", |
|||
"dxDataGrid-ariaCollapse": "Collapse", |
|||
"dxDataGrid-ariaExpand": "Expand", |
|||
"dxDataGrid-ariaDataGrid": "Data grid", |
|||
"dxDataGrid-ariaSearchInGrid": "Search in data grid", |
|||
"dxDataGrid-ariaSelectAll": "Select all", |
|||
"dxDataGrid-ariaSelectRow": "Select row", |
|||
"dxDataGrid-filterBuilderPopupTitle": "Filter Builder", |
|||
"dxDataGrid-filterPanelCreateFilter": "Create Filter", |
|||
"dxDataGrid-filterPanelClearFilter": "Clear", |
|||
"dxDataGrid-filterPanelFilterEnabledHint": "Enable the filter", |
|||
"dxTreeList-ariaTreeList": "Tree list", |
|||
"dxTreeList-editingAddRowToNode": "Add", |
|||
"dxPager-infoText": "Page {0} of {1} ({2} items)", |
|||
"dxPager-pagesCountText": "of", |
|||
"dxPivotGrid-grandTotal": "Grand Total", |
|||
"dxPivotGrid-total": "{0} Total", |
|||
"dxPivotGrid-fieldChooserTitle": "Field Chooser", |
|||
"dxPivotGrid-showFieldChooser": "Show Field Chooser", |
|||
"dxPivotGrid-expandAll": "Expand All", |
|||
"dxPivotGrid-collapseAll": "Collapse All", |
|||
"dxPivotGrid-sortColumnBySummary": 'Sort "{0}" by This Column', |
|||
"dxPivotGrid-sortRowBySummary": 'Sort "{0}" by This Row', |
|||
"dxPivotGrid-removeAllSorting": "Remove All Sorting", |
|||
"dxPivotGrid-dataNotAvailable": "N/A", |
|||
"dxPivotGrid-rowFields": "Row Fields", |
|||
"dxPivotGrid-columnFields": "Column Fields", |
|||
"dxPivotGrid-dataFields": "Data Fields", |
|||
"dxPivotGrid-filterFields": "Filter Fields", |
|||
"dxPivotGrid-allFields": "All Fields", |
|||
"dxPivotGrid-columnFieldArea": "Drop Column Fields Here", |
|||
"dxPivotGrid-dataFieldArea": "Drop Data Fields Here", |
|||
"dxPivotGrid-rowFieldArea": "Drop Row Fields Here", |
|||
"dxPivotGrid-filterFieldArea": "Drop Filter Fields Here", |
|||
"dxScheduler-editorLabelTitle": "Subject", |
|||
"dxScheduler-editorLabelStartDate": "Start Date", |
|||
"dxScheduler-editorLabelEndDate": "End Date", |
|||
"dxScheduler-editorLabelDescription": "Description", |
|||
"dxScheduler-editorLabelRecurrence": "Repeat", |
|||
"dxScheduler-openAppointment": "Open appointment", |
|||
"dxScheduler-recurrenceNever": "Never", |
|||
"dxScheduler-recurrenceDaily": "Daily", |
|||
"dxScheduler-recurrenceWeekly": "Weekly", |
|||
"dxScheduler-recurrenceMonthly": "Monthly", |
|||
"dxScheduler-recurrenceYearly": "Yearly", |
|||
"dxScheduler-recurrenceRepeatEvery": "Repeat Every", |
|||
"dxScheduler-recurrenceRepeatOn": "Repeat On", |
|||
"dxScheduler-recurrenceEnd": "End repeat", |
|||
"dxScheduler-recurrenceAfter": "After", |
|||
"dxScheduler-recurrenceOn": "On", |
|||
"dxScheduler-recurrenceRepeatDaily": "day(s)", |
|||
"dxScheduler-recurrenceRepeatWeekly": "week(s)", |
|||
"dxScheduler-recurrenceRepeatMonthly": "month(s)", |
|||
"dxScheduler-recurrenceRepeatYearly": "year(s)", |
|||
"dxScheduler-switcherDay": "Day", |
|||
"dxScheduler-switcherWeek": "Week", |
|||
"dxScheduler-switcherWorkWeek": "Work Week", |
|||
"dxScheduler-switcherMonth": "Month", |
|||
"dxScheduler-switcherAgenda": "Agenda", |
|||
"dxScheduler-switcherTimelineDay": "Timeline Day", |
|||
"dxScheduler-switcherTimelineWeek": "Timeline Week", |
|||
"dxScheduler-switcherTimelineWorkWeek": "Timeline Work Week", |
|||
"dxScheduler-switcherTimelineMonth": "Timeline Month", |
|||
"dxScheduler-recurrenceRepeatOnDate": "on date", |
|||
"dxScheduler-recurrenceRepeatCount": "occurrence(s)", |
|||
"dxScheduler-allDay": "All day", |
|||
"dxScheduler-confirmRecurrenceEditMessage": "Do you want to edit only this appointment or the whole series?", |
|||
"dxScheduler-confirmRecurrenceDeleteMessage": "Do you want to delete only this appointment or the whole series?", |
|||
"dxScheduler-confirmRecurrenceEditSeries": "Edit series", |
|||
"dxScheduler-confirmRecurrenceDeleteSeries": "Delete series", |
|||
"dxScheduler-confirmRecurrenceEditOccurrence": "Edit appointment", |
|||
"dxScheduler-confirmRecurrenceDeleteOccurrence": "Delete appointment", |
|||
"dxScheduler-noTimezoneTitle": "No timezone", |
|||
"dxScheduler-moreAppointments": "{0} more", |
|||
"dxCalendar-todayButtonText": "오늘", |
|||
"dxCalendar-ariaWidgetName": "달력", |
|||
"dxColorView-ariaRed": "Red", |
|||
"dxColorView-ariaGreen": "Green", |
|||
"dxColorView-ariaBlue": "Blue", |
|||
"dxColorView-ariaAlpha": "Transparency", |
|||
"dxColorView-ariaHex": "Color code", |
|||
"dxTagBox-selected": "{0} selected", |
|||
"dxTagBox-allSelected": "All selected ({0})", |
|||
"dxTagBox-moreSelected": "{0} more", |
|||
"vizExport-printingButtonText": "Print", |
|||
"vizExport-titleMenuText": "Exporting/Printing", |
|||
"vizExport-exportButtonText": "{0} file", |
|||
"dxFilterBuilder-and": "And", |
|||
"dxFilterBuilder-or": "Or", |
|||
"dxFilterBuilder-notAnd": "Not And", |
|||
"dxFilterBuilder-notOr": "Not Or", |
|||
"dxFilterBuilder-addCondition": "Add Condition", |
|||
"dxFilterBuilder-addGroup": "Add Group", |
|||
"dxFilterBuilder-enterValueText": "<enter a value>", |
|||
"dxFilterBuilder-filterOperationEquals": "Equals", |
|||
"dxFilterBuilder-filterOperationNotEquals": "Does not equal", |
|||
"dxFilterBuilder-filterOperationLess": "Is less than", |
|||
"dxFilterBuilder-filterOperationLessOrEquals": "Is less than or equal to", |
|||
"dxFilterBuilder-filterOperationGreater": "Is greater than", |
|||
"dxFilterBuilder-filterOperationGreaterOrEquals": "Is greater than or equal to", |
|||
"dxFilterBuilder-filterOperationStartsWith": "Starts with", |
|||
"dxFilterBuilder-filterOperationContains": "Contains", |
|||
"dxFilterBuilder-filterOperationNotContains": "Does not contain", |
|||
"dxFilterBuilder-filterOperationEndsWith": "Ends with", |
|||
"dxFilterBuilder-filterOperationIsBlank": "Is blank", |
|||
"dxFilterBuilder-filterOperationIsNotBlank": "Is not blank", |
|||
"dxFilterBuilder-filterOperationBetween": "Is between", |
|||
"dxFilterBuilder-filterOperationAnyOf": "Is any of", |
|||
"dxFilterBuilder-filterOperationNoneOf": "Is none of", |
|||
"dxHtmlEditor-dialogColorCaption": "Change Font Color", |
|||
"dxHtmlEditor-dialogBackgroundCaption": "Change Background Color", |
|||
"dxHtmlEditor-dialogLinkCaption": "Add Link", |
|||
"dxHtmlEditor-dialogLinkUrlField": "URL", |
|||
"dxHtmlEditor-dialogLinkTextField": "Text", |
|||
"dxHtmlEditor-dialogLinkTargetField": "Open link in new window", |
|||
"dxHtmlEditor-dialogImageCaption": "Add Image", |
|||
"dxHtmlEditor-dialogImageUrlField": "URL", |
|||
"dxHtmlEditor-dialogImageAltField": "Alternate text", |
|||
"dxHtmlEditor-dialogImageWidthField": "Width (px)", |
|||
"dxHtmlEditor-dialogImageHeightField": "Height (px)", |
|||
"dxHtmlEditor-heading": "Heading", |
|||
"dxHtmlEditor-normalText": "Normal text", |
|||
"dxFileManager-errorNoAccess": "Access denied. The operation cannot be completed.", |
|||
"dxFileManager-errorDirectoryExistsFormat": "Directory '{0}' already exists.", |
|||
"dxFileManager-errorFileExistsFormat": "File '{0}' already exists.", |
|||
"dxFileManager-errorFileNotFoundFormat": "File '{0}' not found", |
|||
"dxFileManager-errorDefault": "Unspecified error." |
|||
} |
|||
}) |
|||
}); |
@ -1,861 +0,0 @@ |
|||
/*! |
|||
* v0.1.5 |
|||
* Copyright (c) 2014 First Opinion |
|||
* formatter.js is open sourced under the MIT license. |
|||
* |
|||
* thanks to digitalBush/jquery.maskedinput for some of the trickier |
|||
* keycode handling |
|||
*/ |
|||
|
|||
//
|
|||
// Uses CommonJS, AMD or browser globals to create a jQuery plugin.
|
|||
//
|
|||
// Similar to jqueryPlugin.js but also tries to
|
|||
// work in a CommonJS environment.
|
|||
// It is unlikely jQuery will run in a CommonJS
|
|||
// environment. See jqueryPlugin.js if you do
|
|||
// not want to add the extra CommonJS detection.
|
|||
//
|
|||
(function (root, factory) { |
|||
if (typeof define === 'function' && define.amd) { |
|||
// AMD. Register as an anonymous module.
|
|||
define(['jQuery'], factory); |
|||
} else if (typeof exports === 'object') { |
|||
factory(require('jQuery')); |
|||
} else { |
|||
// Browser globals
|
|||
factory(root.jQuery); |
|||
} |
|||
}(this, function (jQuery) { |
|||
|
|||
|
|||
/* |
|||
* pattern.js |
|||
* |
|||
* Utilities to parse str pattern and return info |
|||
* |
|||
*/ |
|||
var pattern = function () { |
|||
// Define module
|
|||
var pattern = {}; |
|||
// Match information
|
|||
var DELIM_SIZE = 4; |
|||
// Our regex used to parse
|
|||
var regexp = new RegExp('{{([^}]+)}}', 'g'); |
|||
//
|
|||
// Helper method to parse pattern str
|
|||
//
|
|||
var getMatches = function (pattern) { |
|||
// Populate array of matches
|
|||
var matches = [], match; |
|||
while (match = regexp.exec(pattern)) { |
|||
matches.push(match); |
|||
} |
|||
return matches; |
|||
}; |
|||
//
|
|||
// Create an object holding all formatted characters
|
|||
// with corresponding positions
|
|||
//
|
|||
pattern.parse = function (pattern) { |
|||
// Our obj to populate
|
|||
var info = { |
|||
inpts: {}, |
|||
chars: {} |
|||
}; |
|||
// Pattern information
|
|||
var matches = getMatches(pattern), pLength = pattern.length; |
|||
// Counters
|
|||
var mCount = 0, iCount = 0, i = 0; |
|||
// Add inpts, move to end of match, and process
|
|||
var processMatch = function (val) { |
|||
var valLength = val.length; |
|||
for (var j = 0; j < valLength; j++) { |
|||
info.inpts[iCount] = val.charAt(j); |
|||
iCount++; |
|||
} |
|||
mCount++; |
|||
i += val.length + DELIM_SIZE - 1; |
|||
}; |
|||
// Process match or add chars
|
|||
for (i; i < pLength; i++) { |
|||
if (mCount < matches.length && i === matches[mCount].index) { |
|||
processMatch(matches[mCount][1]); |
|||
} else { |
|||
info.chars[i - mCount * DELIM_SIZE] = pattern.charAt(i); |
|||
} |
|||
} |
|||
// Set mLength and return
|
|||
info.mLength = i - mCount * DELIM_SIZE; |
|||
return info; |
|||
}; |
|||
// Expose
|
|||
return pattern; |
|||
}(); |
|||
/* |
|||
* utils.js |
|||
* |
|||
* Independent helper methods (cross browser, etc..) |
|||
* |
|||
*/ |
|||
var utils = function () { |
|||
// Define module
|
|||
var utils = {}; |
|||
// Useragent info for keycode handling
|
|||
var uAgent = typeof navigator !== 'undefined' ? navigator.userAgent : null; |
|||
//
|
|||
// Shallow copy properties from n objects to destObj
|
|||
//
|
|||
utils.extend = function (destObj) { |
|||
for (var i = 1; i < arguments.length; i++) { |
|||
for (var key in arguments[i]) { |
|||
destObj[key] = arguments[i][key]; |
|||
} |
|||
} |
|||
return destObj; |
|||
}; |
|||
//
|
|||
// Add a given character to a string at a defined pos
|
|||
//
|
|||
utils.addChars = function (str, chars, pos) { |
|||
return str.substr(0, pos) + chars + str.substr(pos, str.length); |
|||
}; |
|||
//
|
|||
// Remove a span of characters
|
|||
//
|
|||
utils.removeChars = function (str, start, end) { |
|||
return str.substr(0, start) + str.substr(end, str.length); |
|||
}; |
|||
//
|
|||
// Return true/false is num false between bounds
|
|||
//
|
|||
utils.isBetween = function (num, bounds) { |
|||
bounds.sort(function (a, b) { |
|||
return a - b; |
|||
}); |
|||
return num > bounds[0] && num < bounds[1]; |
|||
}; |
|||
//
|
|||
// Helper method for cross browser event listeners
|
|||
//
|
|||
utils.addListener = function (el, evt, handler) { |
|||
return typeof el.addEventListener !== 'undefined' ? el.addEventListener(evt, handler, false) : el.attachEvent('on' + evt, handler); |
|||
}; |
|||
//
|
|||
// Helper method for cross browser implementation of preventDefault
|
|||
//
|
|||
utils.preventDefault = function (evt) { |
|||
return evt.preventDefault ? evt.preventDefault() : evt.returnValue = false; |
|||
}; |
|||
//
|
|||
// Helper method for cross browser implementation for grabbing
|
|||
// clipboard data
|
|||
//
|
|||
utils.getClip = function (evt) { |
|||
if (evt.clipboardData) { |
|||
return evt.clipboardData.getData('Text'); |
|||
} |
|||
if (window.clipboardData) { |
|||
return window.clipboardData.getData('Text'); |
|||
} |
|||
}; |
|||
//
|
|||
// Loop over object and checking for matching properties
|
|||
//
|
|||
utils.getMatchingKey = function (which, keyCode, keys) { |
|||
// Loop over and return if matched.
|
|||
for (var k in keys) { |
|||
var key = keys[k]; |
|||
if (which === key.which && keyCode === key.keyCode) { |
|||
return k; |
|||
} |
|||
} |
|||
}; |
|||
//
|
|||
// Returns true/false if k is a del keyDown
|
|||
//
|
|||
utils.isDelKeyDown = function (which, keyCode) { |
|||
var keys = { |
|||
'backspace': { |
|||
'which': 8, |
|||
'keyCode': 8 |
|||
}, |
|||
'delete': { |
|||
'which': 46, |
|||
'keyCode': 46 |
|||
} |
|||
}; |
|||
return utils.getMatchingKey(which, keyCode, keys); |
|||
}; |
|||
//
|
|||
// Returns true/false if k is a del keyPress
|
|||
//
|
|||
utils.isDelKeyPress = function (which, keyCode) { |
|||
var keys = { |
|||
'backspace': { |
|||
'which': 8, |
|||
'keyCode': 8, |
|||
'shiftKey': false |
|||
}, |
|||
'delete': { |
|||
'which': 0, |
|||
'keyCode': 46 |
|||
} |
|||
}; |
|||
return utils.getMatchingKey(which, keyCode, keys); |
|||
}; |
|||
// //
|
|||
// // Determine if keydown relates to specialKey
|
|||
// //
|
|||
// utils.isSpecialKeyDown = function (which, keyCode) {
|
|||
// var keys = {
|
|||
// 'tab': { 'which': 9, 'keyCode': 9 },
|
|||
// 'enter': { 'which': 13, 'keyCode': 13 },
|
|||
// 'end': { 'which': 35, 'keyCode': 35 },
|
|||
// 'home': { 'which': 36, 'keyCode': 36 },
|
|||
// 'leftarrow': { 'which': 37, 'keyCode': 37 },
|
|||
// 'uparrow': { 'which': 38, 'keyCode': 38 },
|
|||
// 'rightarrow': { 'which': 39, 'keyCode': 39 },
|
|||
// 'downarrow': { 'which': 40, 'keyCode': 40 },
|
|||
// 'F5': { 'which': 116, 'keyCode': 116 }
|
|||
// };
|
|||
// return utils.getMatchingKey(which, keyCode, keys);
|
|||
// };
|
|||
//
|
|||
// Determine if keypress relates to specialKey
|
|||
//
|
|||
utils.isSpecialKeyPress = function (which, keyCode) { |
|||
var keys = { |
|||
'tab': { |
|||
'which': 0, |
|||
'keyCode': 9 |
|||
}, |
|||
'enter': { |
|||
'which': 13, |
|||
'keyCode': 13 |
|||
}, |
|||
'end': { |
|||
'which': 0, |
|||
'keyCode': 35 |
|||
}, |
|||
'home': { |
|||
'which': 0, |
|||
'keyCode': 36 |
|||
}, |
|||
'leftarrow': { |
|||
'which': 0, |
|||
'keyCode': 37 |
|||
}, |
|||
'uparrow': { |
|||
'which': 0, |
|||
'keyCode': 38 |
|||
}, |
|||
'rightarrow': { |
|||
'which': 0, |
|||
'keyCode': 39 |
|||
}, |
|||
'downarrow': { |
|||
'which': 0, |
|||
'keyCode': 40 |
|||
}, |
|||
'F5': { |
|||
'which': 116, |
|||
'keyCode': 116 |
|||
} |
|||
}; |
|||
return utils.getMatchingKey(which, keyCode, keys); |
|||
}; |
|||
//
|
|||
// Returns true/false if modifier key is held down
|
|||
//
|
|||
utils.isModifier = function (evt) { |
|||
return evt.ctrlKey || evt.altKey || evt.metaKey; |
|||
}; |
|||
//
|
|||
// Iterates over each property of object or array.
|
|||
//
|
|||
utils.forEach = function (collection, callback, thisArg) { |
|||
if (collection.hasOwnProperty('length')) { |
|||
for (var index = 0, len = collection.length; index < len; index++) { |
|||
if (callback.call(thisArg, collection[index], index, collection) === false) { |
|||
break; |
|||
} |
|||
} |
|||
} else { |
|||
for (var key in collection) { |
|||
if (collection.hasOwnProperty(key)) { |
|||
if (callback.call(thisArg, collection[key], key, collection) === false) { |
|||
break; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
}; |
|||
// Expose
|
|||
return utils; |
|||
}(); |
|||
/* |
|||
* pattern-matcher.js |
|||
* |
|||
* Parses a pattern specification and determines appropriate pattern for an |
|||
* input string |
|||
* |
|||
*/ |
|||
var patternMatcher = function (pattern, utils) { |
|||
//
|
|||
// Parse a matcher string into a RegExp. Accepts valid regular
|
|||
// expressions and the catchall '*'.
|
|||
// @private
|
|||
//
|
|||
var parseMatcher = function (matcher) { |
|||
if (matcher === '*') { |
|||
return /.*/; |
|||
} |
|||
return new RegExp(matcher); |
|||
}; |
|||
//
|
|||
// Parse a pattern spec and return a function that returns a pattern
|
|||
// based on user input. The first matching pattern will be chosen.
|
|||
// Pattern spec format:
|
|||
// Array [
|
|||
// Object: { Matcher(RegExp String) : Pattern(Pattern String) },
|
|||
// ...
|
|||
// ]
|
|||
function patternMatcher(patternSpec) { |
|||
var matchers = [], patterns = []; |
|||
// Iterate over each pattern in order.
|
|||
utils.forEach(patternSpec, function (patternMatcher) { |
|||
// Process single property object to obtain pattern and matcher.
|
|||
utils.forEach(patternMatcher, function (patternStr, matcherStr) { |
|||
var parsedPattern = pattern.parse(patternStr), regExpMatcher = parseMatcher(matcherStr); |
|||
matchers.push(regExpMatcher); |
|||
patterns.push(parsedPattern); |
|||
// Stop after one iteration.
|
|||
return false; |
|||
}); |
|||
}); |
|||
var getPattern = function (input) { |
|||
var matchedIndex; |
|||
utils.forEach(matchers, function (matcher, index) { |
|||
if (matcher.test(input)) { |
|||
matchedIndex = index; |
|||
return false; |
|||
} |
|||
}); |
|||
return matchedIndex === undefined ? null : patterns[matchedIndex]; |
|||
}; |
|||
return { |
|||
getPattern: getPattern, |
|||
patterns: patterns, |
|||
matchers: matchers |
|||
}; |
|||
} |
|||
// Expose
|
|||
return patternMatcher; |
|||
}(pattern, utils); |
|||
/* |
|||
* inpt-sel.js |
|||
* |
|||
* Cross browser implementation to get and set input selections |
|||
* |
|||
*/ |
|||
var inptSel = function () { |
|||
// Define module
|
|||
var inptSel = {}; |
|||
//
|
|||
// Get begin and end positions of selected input. Return 0's
|
|||
// if there is no selectiion data
|
|||
//
|
|||
inptSel.get = function (el) { |
|||
// If normal browser return with result
|
|||
if (typeof el.selectionStart === 'number') { |
|||
return { |
|||
begin: el.selectionStart, |
|||
end: el.selectionEnd |
|||
}; |
|||
} |
|||
// Uh-Oh. We must be IE. Fun with TextRange!!
|
|||
var range = document.selection.createRange(); |
|||
// Determine if there is a selection
|
|||
if (range && range.parentElement() === el) { |
|||
var inputRange = el.createTextRange(), endRange = el.createTextRange(), length = el.value.length; |
|||
// Create a working TextRange for the input selection
|
|||
inputRange.moveToBookmark(range.getBookmark()); |
|||
// Move endRange begin pos to end pos (hence endRange)
|
|||
endRange.collapse(false); |
|||
// If we are at the very end of the input, begin and end
|
|||
// must both be the length of the el.value
|
|||
if (inputRange.compareEndPoints('StartToEnd', endRange) > -1) { |
|||
return { |
|||
begin: length, |
|||
end: length |
|||
}; |
|||
} |
|||
// Note: moveStart usually returns the units moved, which
|
|||
// one may think is -length, however, it will stop when it
|
|||
// gets to the begin of the range, thus giving us the
|
|||
// negative value of the pos.
|
|||
return { |
|||
begin: -inputRange.moveStart('character', -length), |
|||
end: -inputRange.moveEnd('character', -length) |
|||
}; |
|||
} |
|||
//Return 0's on no selection data
|
|||
return { |
|||
begin: 0, |
|||
end: 0 |
|||
}; |
|||
}; |
|||
//
|
|||
// Set the caret position at a specified location
|
|||
//
|
|||
inptSel.set = function (el, pos) { |
|||
// Normalize pos
|
|||
if (typeof pos !== 'object') { |
|||
pos = { |
|||
begin: pos, |
|||
end: pos |
|||
}; |
|||
} |
|||
// If normal browser
|
|||
if (el.setSelectionRange) { |
|||
el.focus(); |
|||
el.setSelectionRange(pos.begin, pos.end); |
|||
} else if (el.createTextRange) { |
|||
var range = el.createTextRange(); |
|||
range.collapse(true); |
|||
range.moveEnd('character', pos.end); |
|||
range.moveStart('character', pos.begin); |
|||
range.select(); |
|||
} |
|||
}; |
|||
// Expose
|
|||
return inptSel; |
|||
}(); |
|||
/* |
|||
* formatter.js |
|||
* |
|||
* Class used to format input based on passed pattern |
|||
* |
|||
*/ |
|||
var formatter = function (patternMatcher, inptSel, utils) { |
|||
// Defaults
|
|||
var defaults = { |
|||
persistent: false, |
|||
repeat: false, |
|||
placeholder: ' ' |
|||
}; |
|||
// Regexs for input validation
|
|||
var inptRegs = { |
|||
'9': /[0-9]/, |
|||
'a': /[A-Za-z]/, |
|||
'*': /[A-Za-z0-9]/ |
|||
}; |
|||
//
|
|||
// Class Constructor - Called with new Formatter(el, opts)
|
|||
// Responsible for setting up required instance variables, and
|
|||
// attaching the event listener to the element.
|
|||
//
|
|||
function Formatter(el, opts) { |
|||
// Cache this
|
|||
var self = this; |
|||
// Make sure we have an element. Make accesible to instance
|
|||
self.el = el; |
|||
if (!self.el) { |
|||
throw new TypeError('Must provide an existing element'); |
|||
} |
|||
// Merge opts with defaults
|
|||
self.opts = utils.extend({}, defaults, opts); |
|||
// 1 pattern is special case
|
|||
if (typeof self.opts.pattern !== 'undefined') { |
|||
self.opts.patterns = self._specFromSinglePattern(self.opts.pattern); |
|||
delete self.opts.pattern; |
|||
} |
|||
// Make sure we have valid opts
|
|||
if (typeof self.opts.patterns === 'undefined') { |
|||
throw new TypeError('Must provide a pattern or array of patterns'); |
|||
} |
|||
self.patternMatcher = patternMatcher(self.opts.patterns); |
|||
// Upate pattern with initial value
|
|||
self._updatePattern(); |
|||
// Init values
|
|||
self.hldrs = {}; |
|||
self.focus = 0; |
|||
// Add Listeners
|
|||
utils.addListener(self.el, 'keydown', function (evt) { |
|||
self._keyDown(evt); |
|||
}); |
|||
utils.addListener(self.el, 'keypress', function (evt) { |
|||
self._keyPress(evt); |
|||
}); |
|||
utils.addListener(self.el, 'paste', function (evt) { |
|||
self._paste(evt); |
|||
}); |
|||
// Persistence
|
|||
if (self.opts.persistent) { |
|||
// Format on start
|
|||
self._processKey('', false); |
|||
self.el.blur(); |
|||
// Add Listeners
|
|||
utils.addListener(self.el, 'focus', function (evt) { |
|||
self._focus(evt); |
|||
}); |
|||
utils.addListener(self.el, 'click', function (evt) { |
|||
self._focus(evt); |
|||
}); |
|||
utils.addListener(self.el, 'touchstart', function (evt) { |
|||
self._focus(evt); |
|||
}); |
|||
} |
|||
} |
|||
//
|
|||
// @public
|
|||
// Add new char
|
|||
//
|
|||
Formatter.addInptType = function (chr, reg) { |
|||
inptRegs[chr] = reg; |
|||
}; |
|||
//
|
|||
// @public
|
|||
// Apply the given pattern to the current input without moving caret.
|
|||
//
|
|||
Formatter.prototype.resetPattern = function (str) { |
|||
// Update opts to hold new pattern
|
|||
this.opts.patterns = str ? this._specFromSinglePattern(str) : this.opts.patterns; |
|||
// Get current state
|
|||
this.sel = inptSel.get(this.el); |
|||
this.val = this.el.value; |
|||
// Init values
|
|||
this.delta = 0; |
|||
// Remove all formatted chars from val
|
|||
this._removeChars(); |
|||
this.patternMatcher = patternMatcher(this.opts.patterns); |
|||
// Update pattern
|
|||
var newPattern = this.patternMatcher.getPattern(this.val); |
|||
this.mLength = newPattern.mLength; |
|||
this.chars = newPattern.chars; |
|||
this.inpts = newPattern.inpts; |
|||
// Format on start
|
|||
this._processKey('', false, true); |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Determine correct format pattern based on input val
|
|||
//
|
|||
Formatter.prototype._updatePattern = function () { |
|||
// Determine appropriate pattern
|
|||
var newPattern = this.patternMatcher.getPattern(this.val); |
|||
// Only update the pattern if there is an appropriate pattern for the value.
|
|||
// Otherwise, leave the current pattern (and likely delete the latest character.)
|
|||
if (newPattern) { |
|||
// Get info about the given pattern
|
|||
this.mLength = newPattern.mLength; |
|||
this.chars = newPattern.chars; |
|||
this.inpts = newPattern.inpts; |
|||
} |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Handler called on all keyDown strokes. All keys trigger
|
|||
// this handler. Only process delete keys.
|
|||
//
|
|||
Formatter.prototype._keyDown = function (evt) { |
|||
// The first thing we need is the character code
|
|||
var k = evt.which || evt.keyCode; |
|||
// If delete key
|
|||
if (k && utils.isDelKeyDown(evt.which, evt.keyCode)) { |
|||
// Process the keyCode and prevent default
|
|||
this._processKey(null, k); |
|||
return utils.preventDefault(evt); |
|||
} |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Handler called on all keyPress strokes. Only processes
|
|||
// character keys (as long as no modifier key is in use).
|
|||
//
|
|||
Formatter.prototype._keyPress = function (evt) { |
|||
// The first thing we need is the character code
|
|||
var k, isSpecial; |
|||
// Mozilla will trigger on special keys and assign the the value 0
|
|||
// We want to use that 0 rather than the keyCode it assigns.
|
|||
k = evt.which || evt.keyCode; |
|||
isSpecial = utils.isSpecialKeyPress(evt.which, evt.keyCode); |
|||
// Process the keyCode and prevent default
|
|||
if (!utils.isDelKeyPress(evt.which, evt.keyCode) && !isSpecial && !utils.isModifier(evt)) { |
|||
this._processKey(String.fromCharCode(k), false); |
|||
return utils.preventDefault(evt); |
|||
} |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Handler called on paste event.
|
|||
//
|
|||
Formatter.prototype._paste = function (evt) { |
|||
// Process the clipboard paste and prevent default
|
|||
this._processKey(utils.getClip(evt), false); |
|||
return utils.preventDefault(evt); |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Handle called on focus event.
|
|||
//
|
|||
Formatter.prototype._focus = function () { |
|||
// Wrapped in timeout so that we can grab input selection
|
|||
var self = this; |
|||
setTimeout(function () { |
|||
// Grab selection
|
|||
var selection = inptSel.get(self.el); |
|||
// Char check
|
|||
var isAfterStart = selection.end > self.focus, isFirstChar = selection.end === 0; |
|||
// If clicked in front of start, refocus to start
|
|||
if (isAfterStart || isFirstChar) { |
|||
inptSel.set(self.el, self.focus); |
|||
} |
|||
}, 0); |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Using the provided key information, alter el value.
|
|||
//
|
|||
Formatter.prototype._processKey = function (chars, delKey, ignoreCaret) { |
|||
// Get current state
|
|||
this.sel = inptSel.get(this.el); |
|||
this.val = this.el.value; |
|||
// Init values
|
|||
this.delta = 0; |
|||
// If chars were highlighted, we need to remove them
|
|||
if (this.sel.begin !== this.sel.end) { |
|||
this.delta = -1 * Math.abs(this.sel.begin - this.sel.end); |
|||
this.val = utils.removeChars(this.val, this.sel.begin, this.sel.end); |
|||
} else if (delKey && delKey === 46) { |
|||
this._delete(); |
|||
} else if (delKey && this.sel.begin - 1 >= 0) { |
|||
// Always have a delta of at least -1 for the character being deleted.
|
|||
this.val = utils.removeChars(this.val, this.sel.end - 1, this.sel.end); |
|||
this.delta -= 1; |
|||
} else if (delKey) { |
|||
return true; |
|||
} |
|||
// If the key is not a del key, it should convert to a str
|
|||
if (!delKey) { |
|||
// Add char at position and increment delta
|
|||
this.val = utils.addChars(this.val, chars, this.sel.begin); |
|||
this.delta += chars.length; |
|||
} |
|||
// Format el.value (also handles updating caret position)
|
|||
this._formatValue(ignoreCaret); |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Deletes the character in front of it
|
|||
//
|
|||
Formatter.prototype._delete = function () { |
|||
// Adjust focus to make sure its not on a formatted char
|
|||
while (this.chars[this.sel.begin]) { |
|||
this._nextPos(); |
|||
} |
|||
// As long as we are not at the end
|
|||
if (this.sel.begin < this.val.length) { |
|||
// We will simulate a delete by moving the caret to the next char
|
|||
// and then deleting
|
|||
this._nextPos(); |
|||
this.val = utils.removeChars(this.val, this.sel.end - 1, this.sel.end); |
|||
this.delta = -1; |
|||
} |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Quick helper method to move the caret to the next pos
|
|||
//
|
|||
Formatter.prototype._nextPos = function () { |
|||
this.sel.end++; |
|||
this.sel.begin++; |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Alter element value to display characters matching the provided
|
|||
// instance pattern. Also responsible for updating
|
|||
//
|
|||
Formatter.prototype._formatValue = function (ignoreCaret) { |
|||
// Set caret pos
|
|||
this.newPos = this.sel.end + this.delta; |
|||
// Remove all formatted chars from val
|
|||
this._removeChars(); |
|||
// Switch to first matching pattern based on val
|
|||
this._updatePattern(); |
|||
// Validate inputs
|
|||
this._validateInpts(); |
|||
// Add formatted characters
|
|||
this._addChars(); |
|||
// Set value and adhere to maxLength
|
|||
this.el.value = this.val.substr(0, this.mLength); |
|||
// Set new caret position
|
|||
if (typeof ignoreCaret === 'undefined' || ignoreCaret === false) { |
|||
inptSel.set(this.el, this.newPos); |
|||
} |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Remove all formatted before and after a specified pos
|
|||
//
|
|||
Formatter.prototype._removeChars = function () { |
|||
// Delta shouldn't include placeholders
|
|||
if (this.sel.end > this.focus) { |
|||
this.delta += this.sel.end - this.focus; |
|||
} |
|||
// Account for shifts during removal
|
|||
var shift = 0; |
|||
// Loop through all possible char positions
|
|||
for (var i = 0; i <= this.mLength; i++) { |
|||
// Get transformed position
|
|||
var curChar = this.chars[i], curHldr = this.hldrs[i], pos = i + shift, val; |
|||
// If after selection we need to account for delta
|
|||
pos = i >= this.sel.begin ? pos + this.delta : pos; |
|||
val = this.val.charAt(pos); |
|||
// Remove char and account for shift
|
|||
if (curChar && curChar === val || curHldr && curHldr === val) { |
|||
this.val = utils.removeChars(this.val, pos, pos + 1); |
|||
shift--; |
|||
} |
|||
} |
|||
// All hldrs should be removed now
|
|||
this.hldrs = {}; |
|||
// Set focus to last character
|
|||
this.focus = this.val.length; |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Make sure all inpts are valid, else remove and update delta
|
|||
//
|
|||
Formatter.prototype._validateInpts = function () { |
|||
// Loop over each char and validate
|
|||
for (var i = 0; i < this.val.length; i++) { |
|||
// Get char inpt type
|
|||
var inptType = this.inpts[i]; |
|||
// Checks
|
|||
var isBadType = !inptRegs[inptType], isInvalid = !isBadType && !inptRegs[inptType].test(this.val.charAt(i)), inBounds = this.inpts[i]; |
|||
// Remove if incorrect and inbounds
|
|||
if ((isBadType || isInvalid) && inBounds) { |
|||
this.val = utils.removeChars(this.val, i, i + 1); |
|||
this.focusStart--; |
|||
this.newPos--; |
|||
this.delta--; |
|||
i--; |
|||
} |
|||
} |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Loop over val and add formatted chars as necessary
|
|||
//
|
|||
Formatter.prototype._addChars = function () { |
|||
if (this.opts.persistent) { |
|||
// Loop over all possible characters
|
|||
for (var i = 0; i <= this.mLength; i++) { |
|||
if (!this.val.charAt(i)) { |
|||
// Add placeholder at pos
|
|||
this.val = utils.addChars(this.val, this.opts.placeholder, i); |
|||
this.hldrs[i] = this.opts.placeholder; |
|||
} |
|||
this._addChar(i); |
|||
} |
|||
// Adjust focus to make sure its not on a formatted char
|
|||
while (this.chars[this.focus]) { |
|||
this.focus++; |
|||
} |
|||
} else { |
|||
// Avoid caching val.length, as they may change in _addChar.
|
|||
for (var j = 0; j <= this.val.length; j++) { |
|||
// When moving backwards there are some race conditions where we
|
|||
// dont want to add the character
|
|||
if (this.delta <= 0 && j === this.focus) { |
|||
return true; |
|||
} |
|||
// Place character in current position of the formatted string.
|
|||
this._addChar(j); |
|||
} |
|||
} |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Add formattted char at position
|
|||
//
|
|||
Formatter.prototype._addChar = function (i) { |
|||
// If char exists at position
|
|||
var chr = this.chars[i]; |
|||
if (!chr) { |
|||
return true; |
|||
} |
|||
// If chars are added in between the old pos and new pos
|
|||
// we need to increment pos and delta
|
|||
if (utils.isBetween(i, [ |
|||
this.sel.begin - 1, |
|||
this.newPos + 1 |
|||
])) { |
|||
this.newPos++; |
|||
this.delta++; |
|||
} |
|||
// If character added before focus, incr
|
|||
if (i <= this.focus) { |
|||
this.focus++; |
|||
} |
|||
// Updateholder
|
|||
if (this.hldrs[i]) { |
|||
delete this.hldrs[i]; |
|||
this.hldrs[i + 1] = this.opts.placeholder; |
|||
} |
|||
// Update value
|
|||
this.val = utils.addChars(this.val, chr, i); |
|||
}; |
|||
//
|
|||
// @private
|
|||
// Create a patternSpec for passing into patternMatcher that
|
|||
// has exactly one catch all pattern.
|
|||
//
|
|||
Formatter.prototype._specFromSinglePattern = function (patternStr) { |
|||
return [{ '*': patternStr }]; |
|||
}; |
|||
// Expose
|
|||
return Formatter; |
|||
}(patternMatcher, inptSel, utils); |
|||
|
|||
|
|||
|
|||
// A really lightweight plugin wrapper around the constructor,
|
|||
// preventing against multiple instantiations
|
|||
var pluginName = 'formatter'; |
|||
|
|||
$.fn[pluginName] = function (options) { |
|||
|
|||
// Initiate plugin if options passed
|
|||
if (typeof options == 'object') { |
|||
this.each(function () { |
|||
if (!$.data(this, 'plugin_' + pluginName)) { |
|||
$.data(this, 'plugin_' + pluginName, |
|||
new formatter(this, options)); |
|||
} |
|||
}); |
|||
} |
|||
|
|||
// Add resetPattern method to plugin
|
|||
this.resetPattern = function (str) { |
|||
this.each(function () { |
|||
var formatted = $.data(this, 'plugin_' + pluginName); |
|||
// resetPattern for instance
|
|||
if (formatted) { formatted.resetPattern(str); } |
|||
}); |
|||
// Chainable please
|
|||
return this; |
|||
}; |
|||
|
|||
// Chainable please
|
|||
return this; |
|||
}; |
|||
|
|||
$.fn[pluginName].addInptType = function (chr, regexp) { |
|||
formatter.addInptType(chr, regexp); |
|||
}; |
|||
|
|||
|
|||
})); |
@ -0,0 +1,212 @@ |
|||
/** |
|||
* GRID Element 생성자 |
|||
* @param element |
|||
* @param options |
|||
* @constructor |
|||
*/ |
|||
function GRID (element, addOptions) { |
|||
this.element = element; |
|||
var self = this; |
|||
this.defaultOptions = { |
|||
key : null, |
|||
cacheEnabled: false, |
|||
statusField : { |
|||
key : '', |
|||
values : [] |
|||
}, |
|||
colorField : [], |
|||
loadPanel: { enabled: true }, |
|||
remoteOperations: { |
|||
groupPaging: true, |
|||
sorting:true, |
|||
paging:true |
|||
}, |
|||
paging: { |
|||
pageSize: 30, |
|||
showNavigationButtons: true |
|||
}, |
|||
selection : { |
|||
mode: 'single', |
|||
selectAllMode : 'page' |
|||
}, |
|||
scrolling: { |
|||
showScrollbar: 'onHover' |
|||
}, |
|||
focusedRowEnabled: true, |
|||
columns: null, |
|||
dataSource: null, |
|||
showRowLines:true, |
|||
showColumnLines:true, |
|||
allowColumnResizing: true, |
|||
noDataText: '검색된 데이타가 없습니다.', |
|||
allowColumnReordering: true, |
|||
columnResizingMode: 'widget', |
|||
editing: { |
|||
allowUpdating: false, |
|||
allowAdding: false, |
|||
allowDeleting: false |
|||
}, |
|||
onRowClick: function(e) { |
|||
self.OnRowSingleClick(e.data); |
|||
}, |
|||
onRowDblClick: function(e) { |
|||
self.OnRowDoubleClick(e.data); |
|||
}, |
|||
onRowPrepared: function(e) { |
|||
if(e.rowType == 'data') { |
|||
var k = self.options.statusField.key, |
|||
v = self.options.statusField.values, |
|||
t = typeof v; |
|||
if( k && ( (t == 'string' && v) || (t == 'object' && v.length > 0)) ) { |
|||
if( (t == 'string' && e.data[k] == v) || (t == 'object' && $.inArray( e.data[k], v) > -1) ) { |
|||
e.rowElement.addClass('unused'); |
|||
} |
|||
} |
|||
self.OnRowPrepared(e); |
|||
} |
|||
}, |
|||
onContextMenuPreparing: function(e) { |
|||
if(e.rowType == 'data') self.OnContextMenuPreparing(e); |
|||
}, |
|||
onSelectionChanged:function(e) { |
|||
self.OnSelectionChanged(e); |
|||
}, |
|||
onCellPrepared: function(e) { |
|||
if(e.rowType == 'data') { |
|||
if(typeof self.options.colorField == 'object' && self.options.colorField.length > 0) |
|||
{ |
|||
for(var i in self.options.colorField) { |
|||
if( self.options.colorField[i].key && self.options.colorField[i].color && e.column.dataField == self.options.colorField[i].key ) { |
|||
e.cellElement.css("background-color", self.options.colorField[i].color); |
|||
} |
|||
} |
|||
} |
|||
self.OnCellPrepared(e); |
|||
} |
|||
} |
|||
}; |
|||
this.options = $.extend({}, this.defaultOptions, addOptions); |
|||
} |
|||
|
|||
GRID.prototype.instance = function() { |
|||
return $(this.element).dxDataGrid('instance'); |
|||
} |
|||
/** |
|||
* 그리드를 초기화한다. |
|||
*/ |
|||
GRID.prototype.init = function() { |
|||
// 그리드 초기화
|
|||
$(this.element).dxDataGrid(this.options); |
|||
var that = this; |
|||
if( $('[data-column]').length > 0 ) { |
|||
$('[data-column]').change(function(e) { |
|||
var field = $(this).data('column'), |
|||
visible = $(this).prop('checked'); |
|||
$(that.element).dxDataGrid('columnOption', field, 'visible', visible); |
|||
}).change(); |
|||
} |
|||
}; |
|||
|
|||
GRID.prototype.SetPage = function(pageIndex) { |
|||
$(this.element).dxDataGrid('instance').pageIndex(pageIndex - 1); |
|||
}; |
|||
|
|||
GRID.prototype.getSearchParam = function(loadOptions) { |
|||
var params = {}; |
|||
|
|||
["skip","take","requireTotalCount","requireGroupCount","sort","filter","totalSummary","group","groupSummary"].forEach(function(i) { |
|||
if(i in loadOptions && loadOptions[i] !== undefined && loadOptions[i] !== null && loadOptions[i] !== '') |
|||
params[i] = JSON.stringify(loadOptions[i]); |
|||
}); |
|||
|
|||
if( $('[data-grid-search]').length > 0 ) { |
|||
var $form = $('[data-grid-search]'); |
|||
$('input', $form).not('[type="checkbox"]').not('[type="radio"]').each(function() { |
|||
var name = $(this).attr('name'), |
|||
value = $(this).val(); |
|||
params[name] = value; |
|||
}); |
|||
$('input[type="checkbox"]', $form).each(function() { |
|||
if( $(this).prop('checked') ) { |
|||
var name = $(this).attr('name'), |
|||
value = $(this).val(); |
|||
params[name] = value; |
|||
} |
|||
}); |
|||
$('input[type="radio"]:checked', $form).each(function() { |
|||
var name = $(this).attr('name'), |
|||
value = $(this).val(); |
|||
params[name] = value; |
|||
}); |
|||
$('select', $form).each(function() { |
|||
var name = $(this).attr('name'), |
|||
value = $(this).find('option:selected').val(); |
|||
params[name] = value; |
|||
}) |
|||
} |
|||
|
|||
return params; |
|||
} |
|||
|
|||
/** |
|||
* 그리드를 새로고침한다. |
|||
*/ |
|||
GRID.prototype.refresh = function(pageIndex) { |
|||
pageIndex = typeof pageIndex == 'number' && pageIndex > 0 ? pageIndex : null; |
|||
if(pageIndex) { |
|||
$(this.element).dxDataGrid('instance').pageIndex(pageIndex - 1); |
|||
} |
|||
$(this.element).dxDataGrid('instance').refresh(); |
|||
}; |
|||
|
|||
/** |
|||
* 컬럼을 감추고 숨길수 있다 |
|||
* @param field |
|||
* @param visible |
|||
* @constructor |
|||
*/ |
|||
GRID.prototype.SetColumnVisible = function(field, visible) { |
|||
|
|||
}; |
|||
|
|||
/** |
|||
* 마우스 한번 클릭시 실행되는 이벤트 |
|||
* @param e |
|||
* @constructor |
|||
*/ |
|||
GRID.prototype.OnRowSingleClick = function(e) {}; |
|||
|
|||
/** |
|||
* 마우스 더블클릭시 실행되는 이벤트 |
|||
* @param e |
|||
* @constructor |
|||
*/ |
|||
GRID.prototype.OnRowDoubleClick = function(e) {}; |
|||
|
|||
/** |
|||
* 행이 준비되었을때 실행되는 이벤트 |
|||
* @param e |
|||
* @constructor |
|||
*/ |
|||
GRID.prototype.OnRowPrepared = function(e) {}; |
|||
|
|||
/** |
|||
* 마우스 우클릭시 나타나는 바로가기 메뉴 |
|||
* @param e |
|||
* @constructor |
|||
*/ |
|||
GRID.prototype.OnContextMenuPreparing = function(e) {}; |
|||
|
|||
/** |
|||
* 행 선택이 바뀌었을때 실행되는 이벤트 |
|||
* @param e |
|||
* @constructor |
|||
*/ |
|||
GRID.prototype.OnSelectionChanged = function(e) {}; |
|||
|
|||
/** |
|||
* 셀이 준비되었을때 실행되는 이벤트 |
|||
* @param e |
|||
* @constructor |
|||
*/ |
|||
GRID.prototype.OnCellPrepared = function(e) {}; |
@ -1,23 +0,0 @@ |
|||
APP.TOAST = { |
|||
confirm : function(msg) { |
|||
APP.toast.push({ |
|||
theme : 'default', |
|||
icon : '<i class="far fa-bell"></i>', |
|||
msg : msg |
|||
}); |
|||
}, |
|||
error : function(msg) { |
|||
APP.toast.push({ |
|||
theme : 'danger', |
|||
icon : '<i class="far fa-exclamation-circle"></i>', |
|||
msg : msg |
|||
}); |
|||
}, |
|||
success: function(msg) { |
|||
APP.toast.push({ |
|||
theme : 'success', |
|||
icon : '<i class="far fa-check-circle"></i>', |
|||
msg : msg |
|||
}) |
|||
} |
|||
}; |
@ -1,69 +1,14 @@ |
|||
.ellipsis { text-overflow:ellipsis; white-space:nowrap; word-wrap:normal; overflow:hidden; } |
|||
.admin-help-wrap { |
|||
width:700px; margin:0 auto; |
|||
li > img {width:700px;} |
|||
.point-color {color:#e60035} |
|||
} |
|||
|
|||
/* 높이/너비/마진/패딩 */ |
|||
@for $i from 1 to 100 { |
|||
.H#{$i * 5} { |
|||
height: 5px * $i !important; |
|||
} |
|||
} |
|||
@for $i from 1 to 100{ |
|||
.W#{$i * 5} { |
|||
width: 5px * $i !important; |
|||
} |
|||
} |
|||
@for $i from 1 to 10 { |
|||
.M#{$i * 5} { |
|||
margin:5px * $i; |
|||
} |
|||
.MT#{$i * 5} { |
|||
margin-top:5px * $i; |
|||
} |
|||
.MR#{$i*5} { |
|||
margin-right:5px * $i; |
|||
} |
|||
.MB#{$i * 5} { |
|||
margin-bottom:5px * $i; |
|||
} |
|||
.ML#{$i * 5} { |
|||
margin-left:5px * $i; |
|||
} |
|||
.PT#{$i * 5} { |
|||
padding-top:5px * $i; |
|||
} |
|||
.PR#{$i * 5} { |
|||
padding-right:5px * $i; |
|||
} |
|||
.PB#{$i * 5} { |
|||
padding-bottom:5px * $i; |
|||
} |
|||
.PL#{$i * 5} { |
|||
padding-left:5px * $i; |
|||
} |
|||
.P#{$i * 5} { |
|||
padding:5px * $i; |
|||
} |
|||
} |
|||
|
|||
.text-center { |
|||
text-align:center !important; |
|||
} |
|||
|
|||
.text-left { |
|||
text-align:left !important; |
|||
} |
|||
|
|||
.text-right { |
|||
text-align:right !important; |
|||
} |
|||
|
|||
|
|||
@each $color, $value in $theme-colors { |
|||
.text-#{$color} { |
|||
color:$value; |
|||
} |
|||
} |
|||
|
|||
.alert { |
|||
padding: 5px 7px; |
|||
|
|||
&.alert-danger { |
|||
border: 1px solid #e32815; |
|||
color: #e32815; |
|||
} |
|||
} |
@ -0,0 +1,4 @@ |
|||
.label { |
|||
margin-bottom:0; |
|||
font-size:12px; |
|||
} |
@ -1,769 +0,0 @@ |
|||
//== |
|||
$ax5grid-border: 1px solid #ccc !default; |
|||
$ax5grid-bg: #fff !default; |
|||
$ax5grid-font-size: 12px !default; |
|||
$ax5grid-column-border: 1px solid #ccc !default; |
|||
|
|||
//== header |
|||
$ax5grid-header-column-color: #222 !default; |
|||
$ax5grid-header-column-border: 1px solid #ccc !default; |
|||
$ax5grid-header-column-box-shadow: inset 1px 1px 0px 0px #fff !default; |
|||
$ax5grid-header-column-bg-colors: (#FFFFFF, #F0F0F0) !default; |
|||
$ax5grid-header-column-hover-bg-colors: (#eee, #eee) !default; |
|||
$ax5grid-header-column-resizer-color: #ff3300 !default; |
|||
$ax5grid-header-column-resizer-size: 4px !default; |
|||
$ax5grid-header-sorter-size: 9px !default; |
|||
$ax5grid-header-sorter-color: #000 !default; |
|||
|
|||
//== aside |
|||
$ax5grid-aside-border: 1px solid darken(#ccc, 0%) !default; |
|||
$ax5grid-aside-bg: #f2f2f2 !default; |
|||
$ax5grid-aside-column-shadow: inset 1px 1px 0px 0px #fff !default; |
|||
|
|||
$ax5grid-frozen-line-border: 1px solid darken(#ccc, 10%) !default; |
|||
|
|||
//== footsum |
|||
$ax5grid-footsum-bg: #ffe7e2 !default; |
|||
$ax5grid-footsum-line-border: 1px solid darken(#ccc, 10%) !default; |
|||
|
|||
//== page |
|||
$ax5grid-page-border: 1px solid #ccc !default; |
|||
$ax5grid-page-bg-colors: (#FFFFFF, #F0F0F0) !default; |
|||
$ax5grid-page-navigation-padding: 5px !default; |
|||
$ax5grid-page-navigation-font-size: 12px !default; |
|||
$ax5grid-page-navigation-btn-min-width: 20px !default; |
|||
$ax5grid-page-navigation-btn-border: 0px none !default; |
|||
$ax5grid-page-navigation-btn-border-radius: 5px !default; |
|||
$ax5grid-page-navigation-btn-bg: transparent !default; |
|||
$ax5grid-page-navigation-btn-font-size: 11px !default; |
|||
$ax5grid-page-navigation-btn-color: #222 !default; |
|||
$ax5grid-page-navigation-btn-hover-bg: #888 !default; |
|||
$ax5grid-page-navigation-btn-hover-color: #fff !default; |
|||
|
|||
$ax5grid-page-status-font-size: 12px !default; |
|||
$ax5grid-page-status-padding: 10px !default; |
|||
$ax5grid-page-status-color: #222 !default; |
|||
|
|||
//== scroll |
|||
$ax5grid-scroll-track-border: 1px solid #ccc !default; |
|||
$ax5grid-scroll-track-bg: #f3f3f3 !default; |
|||
$ax5grid-scroll-corner-bg: #EAEDEF !default; |
|||
|
|||
$ax5grid-scroll-bar-border-radius: 10px !default; |
|||
$ax5grid-scroll-bar-border: 0px solid #fff !default; |
|||
$ax5grid-scroll-bar-bg: #ccc !default; |
|||
$ax5grid-scroll-bar-hover-border: 0px solid #ccc !default; |
|||
$ax5grid-scroll-bar-hover-bg: #bababa !default; |
|||
|
|||
//== body.row |
|||
$ax5grid-row-bg-0: #f3f3f3 !default; |
|||
$ax5grid-row-bg-1: #fff !default; |
|||
$ax5grid-row-bg-2: #f3f3f3 !default; |
|||
$ax5grid-row-bg-3: #fff !default; |
|||
$ax5grid-row-hover-bg: lighten(#cce2f3, 5%) !default; |
|||
$ax5grid-row-grouping-bg: #ffffe7 !default; |
|||
$ax5grid-row-selected: lighten(#b1d7fe, 10%) !default; |
|||
|
|||
//== body.cell |
|||
$ax5grid-cell-padding-row-selector: 5px !default; |
|||
$ax5grid-cell-padding: 3px 5px !default; |
|||
|
|||
$ax5grid-cell-checkbox-border: 1px solid #ccc !default; |
|||
$ax5grid-cell-checkbox-border-radius: 3px !default; |
|||
$ax5grid-cell-checkbox-bg-colors: (#FFFFFF, #F0F0F0) !default; |
|||
$ax5grid-cell-disable-checkbox-bg-colors: (darken(nth($ax5grid-cell-checkbox-bg-colors, 2), 10%), darken(nth($ax5grid-cell-checkbox-bg-colors, 1), 10%)) !default; |
|||
$ax5grid-cell-checkbox-arrow-color: $brand-primary !default; |
|||
|
|||
$ax5grid-cell-focused-box-shadow: inset 0px 0px 1px 1px #0581f2 !default; |
|||
$ax5grid-cell-focused-bg: lighten(#b1d7fe, 10%) !default; |
|||
$ax5grid-cell-focused-color: #000 !default; |
|||
|
|||
$ax5grid-cell-selected-border-color: #ccc !default; |
|||
$ax5grid-cell-selected-bg: #b1d7fe !default; |
|||
$ax5grid-cell-selected-color: #000 !default; |
|||
|
|||
//== resizer |
|||
$ax5grid-resizer-color: #ff3300 !default; |
|||
$ax5grid-resizer-size: 2px !default; |
|||
|
|||
|
|||
// mixins |
|||
@mixin gridBoxModal() { |
|||
margin: 0; |
|||
padding: 0; |
|||
} |
|||
|
|||
@mixin gridColumn($container) { |
|||
|
|||
box-sizing: border-box; |
|||
overflow: hidden; |
|||
position: relative; |
|||
padding: 0; |
|||
font-size: $ax5grid-font-size; |
|||
border: 0 none; |
|||
|
|||
&.hasBorder { |
|||
border-right: $ax5grid-column-border; |
|||
border-bottom: $ax5grid-column-border; |
|||
} |
|||
&.isLastColumn { |
|||
|
|||
} |
|||
&.lineNumberColumn { |
|||
|
|||
} |
|||
&.focused { |
|||
box-shadow: $ax5grid-cell-focused-box-shadow; |
|||
} |
|||
|
|||
@if ($container == "header") { |
|||
cursor: pointer; |
|||
box-shadow: $ax5grid-header-column-box-shadow; |
|||
&:hover { |
|||
@include ax-background(top, $ax5grid-header-column-hover-bg-colors); |
|||
} |
|||
&[data-ax5grid-column-row="null"] { |
|||
box-shadow: none; |
|||
} |
|||
} |
|||
|
|||
&[data-ax5grid-column-row="null"] { |
|||
border-right: 0 none; |
|||
} |
|||
|
|||
&[data-ax5grid-column-selected] { |
|||
background: $ax5grid-cell-selected-bg; |
|||
border-color: $ax5grid-cell-selected-border-color; |
|||
color: $ax5grid-cell-selected-color; |
|||
} |
|||
|
|||
&[data-ax5grid-column-focused] { |
|||
box-shadow: $ax5grid-cell-focused-box-shadow; |
|||
background: $ax5grid-cell-focused-bg; |
|||
color: $ax5grid-cell-focused-color; |
|||
} |
|||
|
|||
&[data-ax5grid-column-attr="rowSelector"] { |
|||
cursor: pointer; |
|||
[data-ax5grid-cellHolder] { |
|||
padding: $ax5grid-cell-padding-row-selector; |
|||
} |
|||
|
|||
.checkBox { |
|||
display: inline-block; |
|||
position: relative; |
|||
border: $ax5grid-cell-checkbox-border; |
|||
border-radius: $ax5grid-cell-checkbox-border-radius; |
|||
@include ax-background(top, $ax5grid-cell-checkbox-bg-colors); |
|||
height: 100%; |
|||
width: 100%; |
|||
&:after { |
|||
content: ''; |
|||
width: 60%; |
|||
height: 40%; |
|||
position: absolute; |
|||
top: 20%; |
|||
right: 20%; |
|||
border: 0.2em solid $ax5grid-cell-checkbox-arrow-color; |
|||
border-top: none; |
|||
border-right: none; |
|||
background: transparent; |
|||
opacity: 0.0; |
|||
@include transform(rotate(-50deg)); |
|||
} |
|||
} |
|||
&[data-ax5grid-selected="true"] { |
|||
.checkBox { |
|||
&:after { |
|||
opacity: 1; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
&[data-ax5grid-column-attr="lineNumber"] { |
|||
} |
|||
|
|||
[data-ax5grid-cellHolder] { |
|||
// 그리드 셀표현 : 그리드의 컬럼텍스트가 여기에 출력됨 |
|||
display: block; |
|||
box-sizing: border-box; |
|||
padding: $ax5grid-cell-padding; |
|||
font-size: $ax5grid-font-size; |
|||
|
|||
white-space: nowrap; |
|||
overflow: hidden; |
|||
text-overflow: ellipsis; |
|||
|
|||
@if ($container == "header") { |
|||
//text-align: center; |
|||
} |
|||
|
|||
&[data-ax5grid-text-align="left"] { |
|||
text-align: left; |
|||
} |
|||
&[data-ax5grid-text-align="center"] { |
|||
text-align: center; |
|||
} |
|||
&[data-ax5grid-text-align="right"] { |
|||
text-align: right; |
|||
} |
|||
&[data-ax5grid-cellHolder="multiLine"] { |
|||
white-space: normal; |
|||
} |
|||
|
|||
[data-ax5grid-editor] { |
|||
position: absolute; |
|||
left: 0; |
|||
top: 0; |
|||
width: 100%; |
|||
height: 100%; |
|||
border: 0 none; |
|||
background: $ax5grid-bg; |
|||
&::-ms-clear { |
|||
display: none; |
|||
} |
|||
} |
|||
|
|||
[data-ax5select] { |
|||
position: absolute; |
|||
display: block; |
|||
left: 0; |
|||
top: 0; |
|||
width: 100%; |
|||
height: 100%; |
|||
border: 0px none; |
|||
background: $ax5grid-bg; |
|||
.ax5select-display { |
|||
height: 100%; |
|||
border-radius: 0; |
|||
} |
|||
} |
|||
|
|||
[data-ax5grid-editor="checkbox"] { |
|||
display: inline-block; |
|||
position: relative; |
|||
border: $ax5grid-cell-checkbox-border; |
|||
border-radius: $ax5grid-cell-checkbox-border-radius; |
|||
@include ax-background(top, $ax5grid-cell-checkbox-bg-colors); |
|||
height: 100%; |
|||
&:after { |
|||
content: ''; |
|||
width: 60%; |
|||
height: 40%; |
|||
position: absolute; |
|||
top: 20%; |
|||
right: 20%; |
|||
border: 0.2em solid $ax5grid-cell-checkbox-arrow-color; |
|||
border-top: none; |
|||
border-right: none; |
|||
background: transparent; |
|||
opacity: 0.0; |
|||
@include transform(rotate(-50deg)); |
|||
} |
|||
&[data-ax5grid-checked="true"] { |
|||
&:after { |
|||
opacity: 1.0; |
|||
} |
|||
} |
|||
} |
|||
|
|||
[data-ax5grid-tnode-arrow] { |
|||
display: inline-block; |
|||
box-sizing: content-box; |
|||
text-align: right; |
|||
text-shadow: 0 -1px #fff; |
|||
padding: 0 5px 0 0; |
|||
} |
|||
a[data-ax5grid-tnode-arrow] { |
|||
cursor: pointer; |
|||
text-decoration: none; |
|||
&:hover { |
|||
text-decoration: none; |
|||
} |
|||
} |
|||
[data-ax5grid-tnode-item="group"] { |
|||
display: inline-block; |
|||
} |
|||
[data-ax5grid-tnode-item="item"] { |
|||
display: inline-block; |
|||
} |
|||
} |
|||
} |
|||
|
|||
@mixin gridRowBackground() { |
|||
&.tr-0 { |
|||
background: $ax5grid-row-bg-0; |
|||
} |
|||
&.tr-1 { |
|||
background: $ax5grid-row-bg-1; |
|||
} |
|||
&.tr-2 { |
|||
background: $ax5grid-row-bg-2; |
|||
} |
|||
&.tr-3 { |
|||
background: $ax5grid-row-bg-3; |
|||
} |
|||
&.hover { |
|||
background: $ax5grid-row-hover-bg; |
|||
} |
|||
&[data-ax5grid-grouping-tr="true"] { |
|||
background: $ax5grid-row-grouping-bg; |
|||
} |
|||
&[data-ax5grid-selected="true"] { |
|||
background: $ax5grid-row-selected; |
|||
td { |
|||
//color: #fff; |
|||
//box-shadow: inset 1px 1px 0px 0px #fff; |
|||
&[data-ax5grid-column-attr="rowSelector"], |
|||
&[data-ax5grid-column-attr="lineNumber"] { |
|||
box-shadow: none; |
|||
} |
|||
&[data-ax5grid-column-attr="rowSelector"] { |
|||
.checkBox { |
|||
&:after { |
|||
opacity: 1; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
&[data-ax5grid-disable-selection="true"] { |
|||
// background: $ax5grid-row-selected; |
|||
td { |
|||
&[data-ax5grid-column-attr="rowSelector"] { |
|||
.checkBox { |
|||
cursor: not-allowed; |
|||
@include ax-background(top, $ax5grid-cell-disable-checkbox-bg-colors); |
|||
&:after { |
|||
opacity: 0; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
// mergeCells 대상 컬럼 배경생 통일. |
|||
td.merged { |
|||
background: $ax5grid-row-bg-1; |
|||
} |
|||
} |
|||
|
|||
@mixin gridPanel($container) { |
|||
[data-ax5grid-panel] { |
|||
@include gridBoxModal(); |
|||
position: absolute; |
|||
overflow: hidden; |
|||
/* |
|||
overflow: hidden; |
|||
-webkit-overflow-scrolling: touch; |
|||
transform: translate3d(0, 0, 0); |
|||
*/ |
|||
|
|||
table { |
|||
table-layout: fixed; |
|||
border-collapse: separate; |
|||
border-spacing: 0; |
|||
border: 0 none; |
|||
width: 100%; |
|||
@if ($container == "header") { |
|||
height: 100%; |
|||
} |
|||
tr { |
|||
border-bottom: 0 none; |
|||
@include gridRowBackground(); |
|||
td { |
|||
@include gridColumn($container); |
|||
|
|||
} |
|||
} |
|||
} |
|||
|
|||
&[data-ax5grid-panel="aside-header"] { |
|||
border-right: $ax5grid-aside-border; |
|||
table { |
|||
tr { |
|||
td { |
|||
text-align: center; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
&[data-ax5grid-panel="top-aside-body"], |
|||
&[data-ax5grid-panel="aside-body"], |
|||
&[data-ax5grid-panel="bottom-aside-body"] { |
|||
border-right: $ax5grid-aside-border; |
|||
background: $ax5grid-aside-bg; |
|||
table { |
|||
tr { |
|||
background: $ax5grid-aside-bg; |
|||
td { |
|||
text-align: center; |
|||
box-shadow: $ax5grid-aside-column-shadow; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
&[data-ax5grid-panel="left-header"], |
|||
&[data-ax5grid-panel="top-left-body"], |
|||
&[data-ax5grid-panel="left-body"], |
|||
&[data-ax5grid-panel="bottom-left-body"] { |
|||
border-right: $ax5grid-frozen-line-border; /// frozen Line color |
|||
} |
|||
|
|||
&[data-ax5grid-panel="top-aside-body"], |
|||
&[data-ax5grid-panel="top-left-body"], |
|||
&[data-ax5grid-panel="top-body"], |
|||
&[data-ax5grid-panel="top-right-body"] { |
|||
border-bottom: $ax5grid-frozen-line-border; /// frozen Line color |
|||
} |
|||
|
|||
&[data-ax5grid-panel="bottom-aside-body"], |
|||
&[data-ax5grid-panel="bottom-left-body"], |
|||
&[data-ax5grid-panel="bottom-body"], |
|||
&[data-ax5grid-panel="bottom-right-body"] { |
|||
border-top: $ax5grid-footsum-line-border; /// footSum Line color |
|||
} |
|||
|
|||
&[data-ax5grid-panel="bottom-aside-body"], |
|||
&[data-ax5grid-panel="bottom-left-body"], |
|||
&[data-ax5grid-panel="bottom-body"], |
|||
&[data-ax5grid-panel="bottom-right-body"] { |
|||
background: $ax5grid-footsum-bg; |
|||
} |
|||
|
|||
[data-ax5grid-panel-scroll] { |
|||
position: absolute; |
|||
left: 0; |
|||
top: 0; |
|||
} |
|||
} |
|||
} |
|||
|
|||
@mixin scrollBar($type) { |
|||
position: absolute; |
|||
top: 0; |
|||
left: 0; |
|||
@include border-top-radius($ax5grid-scroll-bar-border-radius); |
|||
@include border-bottom-radius($ax5grid-scroll-bar-border-radius); |
|||
box-sizing: border-box; |
|||
border: $ax5grid-scroll-bar-border; |
|||
background: $ax5grid-scroll-bar-bg; |
|||
|
|||
@if ($type == "vertical-bar") { |
|||
cursor: ns-resize; |
|||
} @else { |
|||
cursor: ew-resize; |
|||
} |
|||
|
|||
&:hover { |
|||
border: $ax5grid-scroll-bar-hover-border; |
|||
background: $ax5grid-scroll-bar-hover-bg; |
|||
} |
|||
} |
|||
|
|||
@mixin resizer($type: "horizontal") { |
|||
display: none; |
|||
&.live { |
|||
display: block; |
|||
position: absolute; |
|||
top: 0; |
|||
left: 0; |
|||
background: $ax5grid-resizer-color; |
|||
opacity: 0.5; |
|||
|
|||
@if ($type == "vertical") { |
|||
height: $ax5grid-resizer-size; |
|||
width: 100%; |
|||
cursor: row-resize; |
|||
} @else { |
|||
height: 100%; |
|||
width: $ax5grid-resizer-size; |
|||
cursor: col-resize; |
|||
} |
|||
|
|||
} |
|||
} |
|||
|
|||
// body |
|||
[data-ax5grid] { |
|||
box-sizing: border-box; |
|||
*, |
|||
*:before, |
|||
*:after { |
|||
box-sizing: border-box; |
|||
} |
|||
|
|||
[data-ax5grid-container="root"] { |
|||
@include gridBoxModal(); |
|||
position: relative; |
|||
background: $ax5grid-bg; |
|||
border: $ax5grid-border; |
|||
overflow: hidden; |
|||
|
|||
[data-ax5grid-container="hidden"] { |
|||
@include gridBoxModal(); |
|||
position: absolute; |
|||
//z-index: 100; |
|||
left: -100%; |
|||
top: -100%; |
|||
height: 100%; |
|||
width: 100%; |
|||
} |
|||
|
|||
[data-ax5grid-container="header"] { |
|||
user-select: none; |
|||
@include gridBoxModal(); |
|||
position: relative; |
|||
overflow: hidden; |
|||
@include ax-background(top, $ax5grid-header-column-bg-colors); |
|||
border: 0px none; |
|||
border-bottom: $ax5grid-header-column-border; |
|||
@include gridPanel("header"); |
|||
color: $ax5grid-header-column-color; |
|||
[data-ax5grid-column-resizer] { |
|||
position: absolute; |
|||
right: 0; |
|||
top: 0; |
|||
width: $ax5grid-header-column-resizer-size; |
|||
height: 100%; |
|||
cursor: col-resize; |
|||
&:hover { |
|||
background: $ax5grid-header-column-resizer-color; |
|||
opacity: 0.5; |
|||
} |
|||
} |
|||
[data-ax5grid-column-sort] { |
|||
position: relative; |
|||
//right: 0; |
|||
//top: 2px; |
|||
width: 10px; |
|||
height: 10px; |
|||
display: inline-block; |
|||
|
|||
@mixin sort-arrow($arrow-size, $ratio-0, $ratio-1, $arrow-color, $opacity, $direction) { |
|||
position: absolute; |
|||
content: ' '; |
|||
width: 0; |
|||
height: 0; |
|||
display: inline-block; |
|||
border-left: $arrow-size/$ratio-0 solid transparent; |
|||
border-right: $arrow-size/$ratio-0 solid transparent; |
|||
@if ($direction == "up") { |
|||
border-bottom: ($arrow-size)/$ratio-1 solid $arrow-color; |
|||
} @else { |
|||
border-top: ($arrow-size)/$ratio-1 solid $arrow-color; |
|||
} |
|||
background: transparent; |
|||
opacity: $opacity; |
|||
} |
|||
|
|||
&:before { |
|||
top: 0; |
|||
left: 0; |
|||
@include sort-arrow($ax5grid-header-sorter-size, 2.5, 2.2, $ax5grid-header-sorter-color, 0.3, "up"); |
|||
} |
|||
&:after { |
|||
bottom: 0; |
|||
left: 0; |
|||
@include sort-arrow($ax5grid-header-sorter-size, 2.5, 2.2, $ax5grid-header-sorter-color, 0.3, "down"); |
|||
} |
|||
|
|||
&[data-ax5grid-column-sort-order="asc"] { |
|||
&:before { |
|||
top: 2px; |
|||
left: 0; |
|||
@include sort-arrow($ax5grid-header-sorter-size + 1, 2.5, 2.0, $ax5grid-header-sorter-color, 0.8, "up"); |
|||
} |
|||
&:after { |
|||
display: none; |
|||
} |
|||
} |
|||
&[data-ax5grid-column-sort-order="desc"] { |
|||
&:before { |
|||
display: none; |
|||
} |
|||
&:after { |
|||
bottom: 2px; |
|||
left: 0; |
|||
@include sort-arrow($ax5grid-header-sorter-size + 1, 2.5, 2.0, $ax5grid-header-sorter-color, 0.8, "down"); |
|||
} |
|||
} |
|||
|
|||
} |
|||
[data-ax5grid-column-filter] { |
|||
// 개발중.. |
|||
$filter-size: 10px; |
|||
|
|||
position: absolute; |
|||
left: 0; |
|||
top: 0; |
|||
width: 10px; |
|||
height: 10px; |
|||
cursor: pointer; |
|||
|
|||
&:before { |
|||
content: ' '; |
|||
width: 0; |
|||
height: 0; |
|||
display: inline-block; |
|||
border-left: $filter-size/2 solid transparent; |
|||
border-right: $filter-size/2 solid transparent; |
|||
border-top: ($filter-size) solid #000; |
|||
background: transparent; |
|||
opacity: 1; |
|||
} |
|||
|
|||
} |
|||
} |
|||
|
|||
[data-ax5grid-container="body"] { |
|||
@include gridBoxModal(); |
|||
position: relative; |
|||
overflow: hidden; |
|||
@include gridPanel("body"); |
|||
|
|||
/* |
|||
@keyframes fadein { |
|||
from { opacity: 0; } |
|||
to { opacity: 1; } |
|||
} |
|||
|
|||
[data-ax5grid-panel-scroll="body"]{ |
|||
table { |
|||
@include animation(fadein 0.3s); |
|||
} |
|||
} |
|||
*/ |
|||
|
|||
} |
|||
|
|||
[data-ax5grid-container="page"] { |
|||
@include gridBoxModal(); |
|||
position: absolute; |
|||
bottom: 0; |
|||
left: 0; |
|||
width: 100%; |
|||
overflow: hidden; |
|||
@include ax-background(top, $ax5grid-page-bg-colors); |
|||
border: 0px none; |
|||
border-top: $ax5grid-page-border; |
|||
|
|||
[data-ax5grid-page="holder"] { |
|||
@include gridBoxModal(); |
|||
display: table; |
|||
//table-layout: fixed; |
|||
width: 100%; |
|||
height: 100%; |
|||
[data-ax5grid-page="navigation"] { |
|||
@include gridBoxModal(); |
|||
display: table-cell; |
|||
vertical-align: middle; |
|||
text-align: left; |
|||
padding-left: $ax5grid-page-navigation-padding; |
|||
font-size: $ax5grid-page-navigation-font-size; |
|||
|
|||
[data-ax5grid-page-navigation="holder"] { |
|||
display: table; |
|||
[data-ax5grid-page-navigation="cell"], [data-ax5grid-page-navigation="cell-paging"] { |
|||
display: table-cell; |
|||
vertical-align: middle; |
|||
} |
|||
[data-ax5grid-page-navigation="cell-paging"] { |
|||
padding: 0 $ax5grid-page-navigation-padding; |
|||
} |
|||
|
|||
[data-ax5grid-page-move] { |
|||
box-sizing: border-box; |
|||
min-width: $ax5grid-page-navigation-btn-min-width; |
|||
border-radius: $ax5grid-page-navigation-btn-border-radius; |
|||
padding: 1px; |
|||
border: $ax5grid-page-navigation-btn-border; |
|||
background: $ax5grid-page-navigation-btn-bg; |
|||
font-size: $ax5grid-page-navigation-btn-font-size; |
|||
color: $ax5grid-page-navigation-btn-color; |
|||
outline: 0; |
|||
|
|||
&[data-ax5grid-page-selected="true"], &:active { |
|||
background-color: $ax5grid-page-navigation-btn-hover-bg; |
|||
color: $ax5grid-page-navigation-btn-hover-color; |
|||
} |
|||
&:hover { |
|||
text-decoration: underline; |
|||
} |
|||
} |
|||
} |
|||
|
|||
} |
|||
[data-ax5grid-page="status"] { |
|||
@include gridBoxModal(); |
|||
display: table-cell; |
|||
text-align: right; |
|||
vertical-align: middle; |
|||
padding-right: $ax5grid-page-status-padding; |
|||
font-size: $ax5grid-page-status-font-size; |
|||
color: $ax5grid-page-status-color; |
|||
} |
|||
} |
|||
} |
|||
|
|||
[data-ax5grid-container="scroller"] { |
|||
@include gridBoxModal(); |
|||
position: absolute; |
|||
right: 0px; |
|||
bottom: 0px; |
|||
|
|||
$scroller-size: 15px; |
|||
[data-ax5grid-scroller="vertical"] { |
|||
box-sizing: border-box; |
|||
position: absolute; |
|||
display: none; |
|||
right: 0; |
|||
bottom: 0; |
|||
width: $scroller-size; |
|||
height: 100%; |
|||
background: $ax5grid-scroll-track-bg; |
|||
border-left: $ax5grid-scroll-track-border; |
|||
|
|||
[data-ax5grid-scroller="vertical-bar"] { |
|||
@include scrollBar("vertical-bar"); |
|||
} |
|||
} |
|||
[data-ax5grid-scroller="horizontal"] { |
|||
box-sizing: border-box; |
|||
position: absolute; |
|||
display: none; |
|||
right: 0; |
|||
bottom: 0; |
|||
height: $scroller-size; |
|||
width: 100%; |
|||
background: $ax5grid-scroll-track-bg; |
|||
border-top: $ax5grid-scroll-track-border; |
|||
|
|||
[data-ax5grid-scroller="horizontal-bar"] { |
|||
@include scrollBar("horizontal-bar"); |
|||
} |
|||
} |
|||
[data-ax5grid-scroller="corner"] { |
|||
position: absolute; |
|||
display: none; |
|||
right: 0px; |
|||
bottom: 0px; |
|||
width: $scroller-size; |
|||
height: $scroller-size; |
|||
|
|||
background: $ax5grid-scroll-corner-bg; |
|||
border-top: $ax5grid-scroll-track-border; |
|||
border-left: $ax5grid-scroll-track-border; |
|||
} |
|||
} |
|||
|
|||
[data-ax5grid-resizer="horizontal"] { |
|||
@include resizer("horizontal"); |
|||
} |
|||
[data-ax5grid-resizer="vertical"] { |
|||
@include resizer("vertical"); |
|||
} |
|||
} |
|||
} |
@ -1,256 +0,0 @@ |
|||
//============== toast |
|||
$ax5toast-z-index: 2000; |
|||
// 0:left,top / 1:right,top / 2:right,bottom / 3:left,bottom |
|||
$ax5toast-container-width: auto !default; |
|||
$ax5toast-container-padding: 10px !default; |
|||
$ax5toast-box-model: border-box !default; |
|||
$ax5toast-border: 1px solid rgb(255/2, 255/2, 255/2) !default; |
|||
$ax5toast-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.175) !default; |
|||
$ax5toast-body-padding: 6px !default; |
|||
$ax5toast-border-radius: 8px !default; |
|||
$ax5toast-opacity: 0.9 !default; |
|||
$ax5toast-box-margin: 5px 0px 5px 0px !default; |
|||
$ax5toast-icon-size: 24px; |
|||
$ax5toast-easing: $ease-in-out-quint; |
|||
$ax5toast-easing-time: 0.3s; |
|||
|
|||
//** Border color for elements within toast |
|||
$ax5toast-default-text: #282828 !default; |
|||
$ax5toast-default-bg: #fff !default; |
|||
$ax5toast-default-color: $body-color !default; |
|||
|
|||
$ax5toast-primary-text: $brand-primary !default; |
|||
$ax5toast-primary-bg: #fff !default; |
|||
$ax5toast-primary-color: $brand-primary !default; |
|||
|
|||
$ax5toast-success-text: $brand-success !default; |
|||
$ax5toast-success-bg: #fff !default; |
|||
$ax5toast-success-color: $brand-success !default; |
|||
|
|||
$ax5toast-info-text: $brand-info !default; |
|||
$ax5toast-info-bg: #fff !default; |
|||
$ax5toast-info-color: $brand-info !default; |
|||
|
|||
$ax5toast-warning-text: #fff !default; |
|||
$ax5toast-warning-bg: $brand-warning !default; |
|||
$ax5toast-warning-color: $brand-warning !default; |
|||
|
|||
$ax5toast-danger-text: #fff !default; |
|||
$ax5toast-danger-bg: $brand-warning !default; |
|||
$ax5toast-danger-color: $brand-danger !default; |
|||
|
|||
@mixin ax-toast() { |
|||
box-sizing: $ax5toast-box-model; |
|||
border: $ax5toast-border; |
|||
opacity: $ax5toast-opacity; |
|||
|
|||
@include ax-border-radius($ax5toast-border-radius); |
|||
box-shadow: $ax5toast-box-shadow; |
|||
position: relative; |
|||
margin: $ax5toast-box-margin; |
|||
} |
|||
|
|||
@mixin ax-toast-section() { |
|||
display: table; |
|||
padding: $ax5toast-body-padding; |
|||
.ax-toast-icon { |
|||
display: table-cell; |
|||
padding: $ax5toast-body-padding; |
|||
text-align: left; |
|||
font-size: $ax5toast-icon-size; |
|||
width: $ax5toast-icon-size; |
|||
vertical-align: middle; |
|||
} |
|||
.ax-toast-body { |
|||
display: table-cell; |
|||
padding: $ax5toast-body-padding; |
|||
text-align: left; |
|||
vertical-align: middle; |
|||
} |
|||
.ax-toast-buttons { |
|||
display: table-cell; |
|||
padding: $ax5toast-body-padding; |
|||
text-align: right; |
|||
vertical-align: middle; |
|||
button { |
|||
&:not(:last-child) { |
|||
margin-right: 3px; |
|||
} |
|||
} |
|||
} |
|||
.ax-toast-close { |
|||
display: table-cell; |
|||
padding: $ax5toast-body-padding; |
|||
text-align: right; |
|||
vertical-align: top; |
|||
text-decoration: none; |
|||
cursor: pointer; |
|||
} |
|||
} |
|||
|
|||
@mixin toast-variant($text-color, $bg-color, $color) { |
|||
background: $bg-color; |
|||
color: $text-color; |
|||
.ax-toast-icon { |
|||
color: $color; |
|||
} |
|||
.ax-toast-close { |
|||
color: $text-color; |
|||
} |
|||
} |
|||
|
|||
@include keyframes(ax-toast-bottom) { |
|||
from { |
|||
@include transform(translateY(-100px) scale(0.7)); |
|||
} |
|||
to { |
|||
//@include opacity($mask-bg-opacity); |
|||
@include transform(translateY(0px) scale(1)) |
|||
} |
|||
} |
|||
|
|||
@include keyframes(ax-toast-top) { |
|||
from { |
|||
@include transform(translateY(100px) scale(0.7)); |
|||
} |
|||
to { |
|||
//@include opacity($mask-bg-opacity); |
|||
@include transform(translateY(0px) scale(1)) |
|||
} |
|||
} |
|||
|
|||
@include keyframes(ax-toast-removed-bottom) { |
|||
from { |
|||
@include transform(translateY(0px)); |
|||
opacity: 1.0; |
|||
} |
|||
to { |
|||
@include transform(translateY(10px) scale(0.7)); |
|||
opacity: 0.0; |
|||
} |
|||
} |
|||
|
|||
@include keyframes(ax-toast-removed-top) { |
|||
from { |
|||
@include transform(translateY(0px)); |
|||
opacity: 1.0; |
|||
} |
|||
to { |
|||
@include transform(translateY(-10px) scale(0.7)); |
|||
opacity: 0.0; |
|||
} |
|||
} |
|||
|
|||
@include keyframes(ax-toast-destroy) { |
|||
from { |
|||
@include transform(scale(1)); |
|||
opacity: 1.0; |
|||
} |
|||
to { |
|||
@include transform(scale(1.5)); |
|||
opacity: 0.0; |
|||
} |
|||
} |
|||
|
|||
// mixins --------------------------------------------- end |
|||
|
|||
.ax5-ui-toast-container { |
|||
z-index: $ax5toast-z-index; |
|||
position: fixed; |
|||
width: $ax5toast-container-width; |
|||
padding: $ax5toast-container-padding; |
|||
|
|||
box-sizing: border-box; |
|||
*, |
|||
*:before, |
|||
*:after { |
|||
box-sizing: border-box; |
|||
} |
|||
|
|||
.ax5-ui-toast { |
|||
@include ax-toast(); |
|||
@include ax-toast-section(); |
|||
@include transition(all $ax5toast-easing-time ease-in-out); |
|||
|
|||
@include toast-variant($ax5toast-default-text, $ax5toast-default-bg, $ax5toast-default-color); |
|||
|
|||
&.primary { |
|||
@include toast-variant($ax5toast-primary-text, $ax5toast-primary-bg, $ax5toast-primary-color); |
|||
} |
|||
&.success { |
|||
@include toast-variant($ax5toast-success-text, $ax5toast-success-bg, $ax5toast-success-color); |
|||
} |
|||
&.info { |
|||
@include toast-variant($ax5toast-info-text, $ax5toast-info-bg, $ax5toast-info-color); |
|||
} |
|||
&.warning { |
|||
@include toast-variant($ax5toast-warning-text, $ax5toast-warning-bg, $ax5toast-warning-color); |
|||
} |
|||
&.danger { |
|||
@include toast-variant($ax5toast-danger-text, $ax5toast-danger-bg, $ax5toast-danger-color); |
|||
} |
|||
} |
|||
|
|||
&.bottom-left { |
|||
left: 0; |
|||
bottom: 0; |
|||
|
|||
.ax5-ui-toast { |
|||
@include animation(ax-toast-top $ax5toast-easing-time $ax5toast-easing); |
|||
&.removed { |
|||
@include animation(ax-toast-removed-bottom $ax5toast-easing-time ease forwards); |
|||
} |
|||
&.destroy { |
|||
@include animation(ax-toast-destroy $ax5toast-easing-time ease forwards); |
|||
} |
|||
} |
|||
} |
|||
&.bottom-right { |
|||
right: 0; |
|||
bottom: 0; |
|||
|
|||
.ax5-ui-toast { |
|||
@include animation(ax-toast-top $ax5toast-easing-time $ax5toast-easing); |
|||
&.removed { |
|||
@include animation(ax-toast-removed-bottom $ax5toast-easing-time ease forwards); |
|||
} |
|||
&.destroy { |
|||
@include animation(ax-toast-destroy $ax5toast-easing-time ease forwards); |
|||
} |
|||
} |
|||
|
|||
} |
|||
|
|||
&.top-left { |
|||
left: 0; |
|||
top: 0; |
|||
|
|||
.ax5-ui-toast { |
|||
@include animation(ax-toast-bottom $ax5toast-easing-time $ax5toast-easing); |
|||
|
|||
&.removed { |
|||
@include animation(ax-toast-removed-top $ax5toast-easing-time ease forwards); |
|||
} |
|||
&.destroy { |
|||
@include animation(ax-toast-destroy $ax5toast-easing-time ease forwards); |
|||
} |
|||
} |
|||
} |
|||
|
|||
&.top-right { |
|||
right: 0; |
|||
top: 0; |
|||
|
|||
.ax5-ui-toast { |
|||
@include animation(ax-toast-bottom $ax5toast-easing-time $ax5toast-easing); |
|||
&.removed { |
|||
@include animation(ax-toast-removed-top $ax5toast-easing-time ease forwards); |
|||
} |
|||
&.destroy { |
|||
@include animation(ax-toast-destroy $ax5toast-easing-time ease forwards); |
|||
} |
|||
} |
|||
} |
|||
|
|||
} |
|||
|
7403
_src/admin/scss/plugins/devextreme/dx.common.scss
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
13343
_src/admin/scss/plugins/devextreme/dx.light.compact.scss
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -1,23 +0,0 @@ |
|||
// Rotated & Flipped Icons |
|||
// ------------------------- |
|||
|
|||
.#{$fa-css-prefix}-rotate-90 { @include fa-icon-rotate(90deg, 1); } |
|||
.#{$fa-css-prefix}-rotate-180 { @include fa-icon-rotate(180deg, 2); } |
|||
.#{$fa-css-prefix}-rotate-270 { @include fa-icon-rotate(270deg, 3); } |
|||
|
|||
.#{$fa-css-prefix}-flip-horizontal { @include fa-icon-flip(-1, 1, 0); } |
|||
.#{$fa-css-prefix}-flip-vertical { @include fa-icon-flip(1, -1, 2); } |
|||
.#{$fa-css-prefix}-flip-horizontal.#{$fa-css-prefix}-flip-vertical { @include fa-icon-flip(-1, -1, 2); } |
|||
|
|||
// Hook for IE8-9 |
|||
// ------------------------- |
|||
|
|||
:root { |
|||
.#{$fa-css-prefix}-rotate-90, |
|||
.#{$fa-css-prefix}-rotate-180, |
|||
.#{$fa-css-prefix}-rotate-270, |
|||
.#{$fa-css-prefix}-flip-horizontal, |
|||
.#{$fa-css-prefix}-flip-vertical { |
|||
filter: none; |
|||
} |
|||
} |
@ -1,21 +0,0 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
|||
|
|||
@font-face { |
|||
font-family: 'Font Awesome 5 Brands'; |
|||
font-style: normal; |
|||
font-weight: normal; |
|||
src: url('#{$fa-font-path}/fa-brands-400.eot'); |
|||
src: url('#{$fa-font-path}/fa-brands-400.eot?#iefix') format('embedded-opentype'), |
|||
url('#{$fa-font-path}/fa-brands-400.woff2') format('woff2'), |
|||
url('#{$fa-font-path}/fa-brands-400.woff') format('woff'), |
|||
url('#{$fa-font-path}/fa-brands-400.ttf') format('truetype'), |
|||
url('#{$fa-font-path}/fa-brands-400.svg#fontawesome') format('svg'); |
|||
} |
|||
|
|||
.fab { |
|||
font-family: 'Font Awesome 5 Brands'; |
|||
} |
@ -1,16 +0,0 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
|||
@import 'mixins'; |
|||
@import 'core'; |
|||
@import 'larger'; |
|||
@import 'fixed-width'; |
|||
@import 'list'; |
|||
@import 'bordered-pulled'; |
|||
@import 'animated'; |
|||
@import 'rotated-flipped'; |
|||
@import 'stacked'; |
|||
@import 'icons'; |
|||
@import 'screen-reader'; |
@ -1,22 +0,0 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
|||
|
|||
@font-face { |
|||
font-family: 'Font Awesome 5 Pro'; |
|||
font-style: normal; |
|||
font-weight: 300; |
|||
src: url('#{$fa-font-path}/fa-light-300.eot'); |
|||
src: url('#{$fa-font-path}/fa-light-300.eot?#iefix') format('embedded-opentype'), |
|||
url('#{$fa-font-path}/fa-light-300.woff2') format('woff2'), |
|||
url('#{$fa-font-path}/fa-light-300.woff') format('woff'), |
|||
url('#{$fa-font-path}/fa-light-300.ttf') format('truetype'), |
|||
url('#{$fa-font-path}/fa-light-300.svg#fontawesome') format('svg'); |
|||
} |
|||
|
|||
.fal { |
|||
font-family: 'Font Awesome 5 Pro'; |
|||
font-weight: 300; |
|||
} |
@ -1,23 +0,0 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
|||
|
|||
@font-face { |
|||
font-family: 'Font Awesome 5 Pro'; |
|||
font-style: normal; |
|||
font-weight: 900; |
|||
src: url('#{$fa-font-path}/fa-solid-900.eot'); |
|||
src: url('#{$fa-font-path}/fa-solid-900.eot?#iefix') format('embedded-opentype'), |
|||
url('#{$fa-font-path}/fa-solid-900.woff2') format('woff2'), |
|||
url('#{$fa-font-path}/fa-solid-900.woff') format('woff'), |
|||
url('#{$fa-font-path}/fa-solid-900.ttf') format('truetype'), |
|||
url('#{$fa-font-path}/fa-solid-900.svg#fontawesome') format('svg'); |
|||
} |
|||
|
|||
.fa, |
|||
.fas { |
|||
font-family: 'Font Awesome 5 Pro'; |
|||
font-weight: 900; |
|||
} |
@ -1,569 +0,0 @@ |
|||
|
|||
.xdsoft_datetimepicker { |
|||
box-shadow: 0 5px 15px -5px rgba(0, 0, 0, 0.506); |
|||
background: #fff; |
|||
border-bottom: 1px solid #bbb; |
|||
border-left: 1px solid #ccc; |
|||
border-right: 1px solid #ccc; |
|||
border-top: 1px solid #ccc; |
|||
color: #333; |
|||
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; |
|||
padding: 8px; |
|||
padding-left: 0; |
|||
padding-top: 2px; |
|||
position: absolute; |
|||
z-index: 9999; |
|||
-moz-box-sizing: border-box; |
|||
box-sizing: border-box; |
|||
display: none; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_rtl { |
|||
padding: 8px 0 8px 8px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker iframe { |
|||
position: absolute; |
|||
left: 0; |
|||
top: 0; |
|||
width: 75px; |
|||
height: 210px; |
|||
background: transparent; |
|||
border: none; |
|||
} |
|||
|
|||
/*For IE8 or lower*/ |
|||
.xdsoft_datetimepicker button { |
|||
border: none !important; |
|||
} |
|||
|
|||
.xdsoft_noselect { |
|||
-webkit-touch-callout: none; |
|||
-webkit-user-select: none; |
|||
-khtml-user-select: none; |
|||
-moz-user-select: none; |
|||
-ms-user-select: none; |
|||
-o-user-select: none; |
|||
user-select: none; |
|||
} |
|||
|
|||
.xdsoft_noselect::selection { background: transparent } |
|||
.xdsoft_noselect::-moz-selection { background: transparent } |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_inline { |
|||
display: inline-block; |
|||
position: static; |
|||
box-shadow: none; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker * { |
|||
-moz-box-sizing: border-box; |
|||
box-sizing: border-box; |
|||
padding: 0; |
|||
margin: 0; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_datepicker, .xdsoft_datetimepicker .xdsoft_timepicker { |
|||
display: none; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_datepicker.active, .xdsoft_datetimepicker .xdsoft_timepicker.active { |
|||
display: block; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_datepicker { |
|||
width: 224px; |
|||
float: left; |
|||
margin-left: 8px; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_rtl .xdsoft_datepicker { |
|||
float: right; |
|||
margin-right: 8px; |
|||
margin-left: 0; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_datepicker { |
|||
width: 256px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_timepicker { |
|||
width: 58px; |
|||
float: left; |
|||
text-align: center; |
|||
margin-left: 8px; |
|||
margin-top: 0; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_rtl .xdsoft_timepicker { |
|||
float: right; |
|||
margin-right: 8px; |
|||
margin-left: 0; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_datepicker.active+.xdsoft_timepicker { |
|||
margin-top: 8px; |
|||
margin-bottom: 3px |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_monthpicker { |
|||
position: relative; |
|||
text-align: center; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label i, |
|||
.xdsoft_datetimepicker .xdsoft_prev, |
|||
.xdsoft_datetimepicker .xdsoft_next, |
|||
.xdsoft_datetimepicker .xdsoft_today_button { |
|||
background-image: url(); |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label i { |
|||
opacity: 0.5; |
|||
background-position: -92px -19px; |
|||
display: inline-block; |
|||
width: 9px; |
|||
height: 20px; |
|||
vertical-align: middle; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_prev { |
|||
float: left; |
|||
background-position: -20px 0; |
|||
} |
|||
.xdsoft_datetimepicker .xdsoft_today_button { |
|||
float: left; |
|||
background-position: -70px 0; |
|||
margin-left: 5px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_next { |
|||
float: right; |
|||
background-position: 0 0; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_next, |
|||
.xdsoft_datetimepicker .xdsoft_prev , |
|||
.xdsoft_datetimepicker .xdsoft_today_button { |
|||
background-color: transparent; |
|||
background-repeat: no-repeat; |
|||
border: 0 none; |
|||
cursor: pointer; |
|||
display: block; |
|||
height: 30px; |
|||
opacity: 0.5; |
|||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"; |
|||
outline: medium none; |
|||
overflow: hidden; |
|||
padding: 0; |
|||
position: relative; |
|||
text-indent: 100%; |
|||
white-space: nowrap; |
|||
width: 20px; |
|||
min-width: 0; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_prev, |
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_next { |
|||
float: none; |
|||
background-position: -40px -15px; |
|||
height: 15px; |
|||
width: 30px; |
|||
display: block; |
|||
margin-left: 14px; |
|||
margin-top: 7px; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_rtl .xdsoft_timepicker .xdsoft_prev, |
|||
.xdsoft_datetimepicker.xdsoft_rtl .xdsoft_timepicker .xdsoft_next { |
|||
float: none; |
|||
margin-left: 0; |
|||
margin-right: 14px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_prev { |
|||
background-position: -40px 0; |
|||
margin-bottom: 7px; |
|||
margin-top: 0; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box { |
|||
height: 151px; |
|||
overflow: hidden; |
|||
border-bottom: 1px solid #ddd; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div { |
|||
background: #f5f5f5; |
|||
border-top: 1px solid #ddd; |
|||
color: #666; |
|||
font-size: 12px; |
|||
text-align: center; |
|||
border-collapse: collapse; |
|||
cursor: pointer; |
|||
border-bottom-width: 0; |
|||
height: 25px; |
|||
line-height: 25px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div > div:first-child { |
|||
border-top-width: 0; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_today_button:hover, |
|||
.xdsoft_datetimepicker .xdsoft_next:hover, |
|||
.xdsoft_datetimepicker .xdsoft_prev:hover { |
|||
opacity: 1; |
|||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label { |
|||
display: inline; |
|||
position: relative; |
|||
z-index: 9999; |
|||
margin: 0; |
|||
padding: 5px 3px; |
|||
font-size: 14px; |
|||
line-height: 20px; |
|||
font-weight: bold; |
|||
background-color: #fff; |
|||
float: left; |
|||
width: 182px; |
|||
text-align: center; |
|||
cursor: pointer; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label:hover>span { |
|||
text-decoration: underline; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label:hover i { |
|||
opacity: 1.0; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select { |
|||
border: 1px solid #ccc; |
|||
position: absolute; |
|||
right: 0; |
|||
top: 30px; |
|||
z-index: 101; |
|||
display: none; |
|||
background: #fff; |
|||
max-height: 160px; |
|||
overflow-y: hidden; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_monthselect{ right: -7px } |
|||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_yearselect{ right: 2px } |
|||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover { |
|||
color: #fff; |
|||
background: #ff8000; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option { |
|||
padding: 2px 10px 2px 5px; |
|||
text-decoration: none !important; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current { |
|||
background: #33aaff; |
|||
box-shadow: #178fe5 0 1px 3px 0 inset; |
|||
color: #fff; |
|||
font-weight: 700; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_month { |
|||
width: 100px; |
|||
text-align: right; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar { |
|||
clear: both; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_year{ |
|||
width: 48px; |
|||
margin-left: 5px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar table { |
|||
border-collapse: collapse; |
|||
width: 100%; |
|||
|
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td > div { |
|||
padding-right: 5px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar th { |
|||
height: 25px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td,.xdsoft_datetimepicker .xdsoft_calendar th { |
|||
width: 14.2857142%; |
|||
background: #f5f5f5; |
|||
border: 1px solid #ddd; |
|||
color: #666; |
|||
font-size: 12px; |
|||
text-align: right; |
|||
vertical-align: middle; |
|||
padding: 0; |
|||
border-collapse: collapse; |
|||
cursor: pointer; |
|||
height: 25px; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar td,.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar th { |
|||
width: 12.5%; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar th { |
|||
background: #f1f1f1; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_today { |
|||
color: #33aaff; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_highlighted_default { |
|||
background: #ffe9d2; |
|||
box-shadow: #ffb871 0 1px 4px 0 inset; |
|||
color: #000; |
|||
} |
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_highlighted_mint { |
|||
background: #c1ffc9; |
|||
box-shadow: #00dd1c 0 1px 4px 0 inset; |
|||
color: #000; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_default, |
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_current, |
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current { |
|||
background: #33aaff; |
|||
box-shadow: #178fe5 0 1px 3px 0 inset; |
|||
color: #fff; |
|||
font-weight: 700; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month, |
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled, |
|||
.xdsoft_datetimepicker .xdsoft_time_box >div >div.xdsoft_disabled { |
|||
opacity: 0.5; |
|||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"; |
|||
cursor: default; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month.xdsoft_disabled { |
|||
opacity: 0.2; |
|||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=20)"; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td:hover, |
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div:hover { |
|||
color: #fff !important; |
|||
background: #ff8000 !important; |
|||
box-shadow: none !important; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_current.xdsoft_disabled:hover, |
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box>div>div.xdsoft_current.xdsoft_disabled:hover { |
|||
background: #33aaff !important; |
|||
box-shadow: #178fe5 0 1px 3px 0 inset !important; |
|||
color: #fff !important; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled:hover, |
|||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_disabled:hover { |
|||
color: inherit !important; |
|||
background: inherit !important; |
|||
box-shadow: inherit !important; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_calendar th { |
|||
font-weight: 700; |
|||
text-align: center; |
|||
color: #999; |
|||
cursor: default; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_copyright { |
|||
color: #ccc !important; |
|||
font-size: 10px; |
|||
clear: both; |
|||
float: none; |
|||
margin-left: 8px; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker .xdsoft_copyright a { color: #eee !important } |
|||
.xdsoft_datetimepicker .xdsoft_copyright a:hover { color: #aaa !important } |
|||
|
|||
.xdsoft_time_box { |
|||
position: relative; |
|||
border: 1px solid #ccc; |
|||
} |
|||
.xdsoft_scrollbar >.xdsoft_scroller { |
|||
background: #ccc !important; |
|||
height: 20px; |
|||
border-radius: 3px; |
|||
} |
|||
.xdsoft_scrollbar { |
|||
position: absolute; |
|||
width: 7px; |
|||
right: 0; |
|||
top: 0; |
|||
bottom: 0; |
|||
cursor: pointer; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_rtl .xdsoft_scrollbar { |
|||
left: 0; |
|||
right: auto; |
|||
} |
|||
.xdsoft_scroller_box { |
|||
position: relative; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark { |
|||
box-shadow: 0 5px 15px -5px rgba(255, 255, 255, 0.506); |
|||
background: #000; |
|||
border-bottom: 1px solid #444; |
|||
border-left: 1px solid #333; |
|||
border-right: 1px solid #333; |
|||
border-top: 1px solid #333; |
|||
color: #ccc; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box { |
|||
border-bottom: 1px solid #222; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div { |
|||
background: #0a0a0a; |
|||
border-top: 1px solid #222; |
|||
color: #999; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label { |
|||
background-color: #000; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select { |
|||
border: 1px solid #333; |
|||
background: #000; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover { |
|||
color: #000; |
|||
background: #007fff; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current { |
|||
background: #cc5500; |
|||
box-shadow: #b03e00 0 1px 3px 0 inset; |
|||
color: #000; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label i, |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_prev, |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_next, |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_today_button { |
|||
background-image: url(); |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td, |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th { |
|||
background: #0a0a0a; |
|||
border: 1px solid #222; |
|||
color: #999; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th { |
|||
background: #0e0e0e; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_today { |
|||
color: #cc5500; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_highlighted_default { |
|||
background: #ffe9d2; |
|||
box-shadow: #ffb871 0 1px 4px 0 inset; |
|||
color:#000; |
|||
} |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_highlighted_mint { |
|||
background: #c1ffc9; |
|||
box-shadow: #00dd1c 0 1px 4px 0 inset; |
|||
color:#000; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_default, |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_current, |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current { |
|||
background: #cc5500; |
|||
box-shadow: #b03e00 0 1px 3px 0 inset; |
|||
color: #000; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td:hover, |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div:hover { |
|||
color: #000 !important; |
|||
background: #007fff !important; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th { |
|||
color: #666; |
|||
} |
|||
|
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright { color: #333 !important } |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright a { color: #111 !important } |
|||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright a:hover { color: #555 !important } |
|||
|
|||
.xdsoft_dark .xdsoft_time_box { |
|||
border: 1px solid #333; |
|||
} |
|||
|
|||
.xdsoft_dark .xdsoft_scrollbar >.xdsoft_scroller { |
|||
background: #333 !important; |
|||
} |
|||
.xdsoft_datetimepicker .xdsoft_save_selected { |
|||
display: block; |
|||
border: 1px solid #dddddd !important; |
|||
margin-top: 5px; |
|||
width: 100%; |
|||
color: #454551; |
|||
font-size: 13px; |
|||
} |
|||
.xdsoft_datetimepicker .blue-gradient-button { |
|||
font-family: "museo-sans", "Book Antiqua", sans-serif; |
|||
font-size: 12px; |
|||
font-weight: 300; |
|||
color: #82878c; |
|||
height: 28px; |
|||
position: relative; |
|||
padding: 4px 17px 4px 33px; |
|||
border: 1px solid #d7d8da; |
|||
background: -moz-linear-gradient(top, #fff 0%, #f4f8fa 73%); |
|||
/* FF3.6+ */ |
|||
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #fff), color-stop(73%, #f4f8fa)); |
|||
/* Chrome,Safari4+ */ |
|||
background: -webkit-linear-gradient(top, #fff 0%, #f4f8fa 73%); |
|||
/* Chrome10+,Safari5.1+ */ |
|||
background: -o-linear-gradient(top, #fff 0%, #f4f8fa 73%); |
|||
/* Opera 11.10+ */ |
|||
background: -ms-linear-gradient(top, #fff 0%, #f4f8fa 73%); |
|||
/* IE10+ */ |
|||
background: linear-gradient(to bottom, #fff 0%, #f4f8fa 73%); |
|||
/* W3C */ |
|||
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fff', endColorstr='#f4f8fa',GradientType=0 ); |
|||
/* IE6-9 */ |
|||
} |
|||
.xdsoft_datetimepicker .blue-gradient-button:hover, .xdsoft_datetimepicker .blue-gradient-button:focus, .xdsoft_datetimepicker .blue-gradient-button:hover span, .xdsoft_datetimepicker .blue-gradient-button:focus span { |
|||
color: #454551; |
|||
background: -moz-linear-gradient(top, #f4f8fa 0%, #FFF 73%); |
|||
/* FF3.6+ */ |
|||
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f4f8fa), color-stop(73%, #FFF)); |
|||
/* Chrome,Safari4+ */ |
|||
background: -webkit-linear-gradient(top, #f4f8fa 0%, #FFF 73%); |
|||
/* Chrome10+,Safari5.1+ */ |
|||
background: -o-linear-gradient(top, #f4f8fa 0%, #FFF 73%); |
|||
/* Opera 11.10+ */ |
|||
background: -ms-linear-gradient(top, #f4f8fa 0%, #FFF 73%); |
|||
/* IE10+ */ |
|||
background: linear-gradient(to bottom, #f4f8fa 0%, #FFF 73%); |
|||
/* W3C */ |
|||
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f4f8fa', endColorstr='#FFF',GradientType=0 ); |
|||
/* IE6-9 */ |
|||
} |
@ -1 +0,0 @@ |
|||
html, body { min-height:100%; } |
@ -1,200 +0,0 @@ |
|||
.toast-title { |
|||
font-weight: bold; |
|||
} |
|||
.toast-message { |
|||
-ms-word-wrap: break-word; |
|||
word-wrap: break-word; |
|||
} |
|||
.toast-message a, |
|||
.toast-message label { |
|||
color: #ffffff; |
|||
} |
|||
.toast-message a:hover { |
|||
color: #cccccc; |
|||
text-decoration: none; |
|||
} |
|||
.toast-close-button { |
|||
position: relative; |
|||
right: -0.3em; |
|||
top: -0.3em; |
|||
float: right; |
|||
font-size: 20px; |
|||
font-weight: bold; |
|||
color: #ffffff; |
|||
-webkit-text-shadow: 0 1px 0 #ffffff; |
|||
text-shadow: 0 1px 0 #ffffff; |
|||
opacity: 0.8; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); |
|||
filter: alpha(opacity=80); |
|||
} |
|||
.toast-close-button:hover, |
|||
.toast-close-button:focus { |
|||
color: #000000; |
|||
text-decoration: none; |
|||
cursor: pointer; |
|||
opacity: 0.4; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); |
|||
filter: alpha(opacity=40); |
|||
} |
|||
/*Additional properties for button version |
|||
iOS requires the button element instead of an anchor tag. |
|||
If you want the anchor version, it requires `href="#"`.*/ |
|||
button.toast-close-button { |
|||
padding: 0; |
|||
cursor: pointer; |
|||
background: transparent; |
|||
border: 0; |
|||
-webkit-appearance: none; |
|||
} |
|||
.toast-top-center { |
|||
top: 0; |
|||
right: 0; |
|||
width: 100%; |
|||
} |
|||
.toast-bottom-center { |
|||
bottom: 0; |
|||
right: 0; |
|||
width: 100%; |
|||
} |
|||
.toast-top-full-width { |
|||
top: 0; |
|||
right: 0; |
|||
width: 100%; |
|||
} |
|||
.toast-bottom-full-width { |
|||
bottom: 0; |
|||
right: 0; |
|||
width: 100%; |
|||
} |
|||
.toast-top-left { |
|||
top: 12px; |
|||
left: 12px; |
|||
} |
|||
.toast-top-right { |
|||
top: 12px; |
|||
right: 12px; |
|||
} |
|||
.toast-bottom-right { |
|||
right: 12px; |
|||
bottom: 12px; |
|||
} |
|||
.toast-bottom-left { |
|||
bottom: 12px; |
|||
left: 12px; |
|||
} |
|||
#toast-container { |
|||
position: fixed; |
|||
z-index: 999999; |
|||
pointer-events: none; |
|||
/*overrides*/ |
|||
} |
|||
#toast-container * { |
|||
-moz-box-sizing: border-box; |
|||
-webkit-box-sizing: border-box; |
|||
box-sizing: border-box; |
|||
} |
|||
#toast-container > div { |
|||
position: relative; |
|||
pointer-events: auto; |
|||
overflow: hidden; |
|||
margin: 0 0 6px; |
|||
padding: 15px 15px 15px 50px; |
|||
width: 300px; |
|||
-moz-border-radius: 3px 3px 3px 3px; |
|||
-webkit-border-radius: 3px 3px 3px 3px; |
|||
border-radius: 3px 3px 3px 3px; |
|||
background-position: 15px center; |
|||
background-repeat: no-repeat; |
|||
-moz-box-shadow: 0 0 12px #999999; |
|||
-webkit-box-shadow: 0 0 12px #999999; |
|||
box-shadow: 0 0 12px #999999; |
|||
color: #ffffff; |
|||
opacity: 0.8; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); |
|||
filter: alpha(opacity=80); |
|||
} |
|||
#toast-container > :hover { |
|||
-moz-box-shadow: 0 0 12px #000000; |
|||
-webkit-box-shadow: 0 0 12px #000000; |
|||
box-shadow: 0 0 12px #000000; |
|||
opacity: 1; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); |
|||
filter: alpha(opacity=100); |
|||
cursor: pointer; |
|||
} |
|||
#toast-container > .toast-info { |
|||
background-image: url("") !important; |
|||
} |
|||
#toast-container > .toast-error { |
|||
background-image: url("") !important; |
|||
} |
|||
#toast-container > .toast-success { |
|||
background-image: url("") !important; |
|||
} |
|||
#toast-container > .toast-warning { |
|||
background-image: url("") !important; |
|||
} |
|||
#toast-container.toast-top-center > div, |
|||
#toast-container.toast-bottom-center > div { |
|||
width: 300px; |
|||
margin-left: auto; |
|||
margin-right: auto; |
|||
} |
|||
#toast-container.toast-top-full-width > div, |
|||
#toast-container.toast-bottom-full-width > div { |
|||
width: 96%; |
|||
margin-left: auto; |
|||
margin-right: auto; |
|||
} |
|||
.toast { |
|||
background-color: #030303; |
|||
} |
|||
.toast-success { |
|||
background-color: #51a351; |
|||
} |
|||
.toast-error { |
|||
background-color: #bd362f; |
|||
} |
|||
.toast-info { |
|||
background-color: #2f96b4; |
|||
} |
|||
.toast-warning { |
|||
background-color: #f89406; |
|||
} |
|||
.toast-progress { |
|||
position: absolute; |
|||
left: 0; |
|||
bottom: 0; |
|||
height: 4px; |
|||
background-color: #000000; |
|||
opacity: 0.4; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); |
|||
filter: alpha(opacity=40); |
|||
} |
|||
/*Responsive Design*/ |
|||
@media all and (max-width: 240px) { |
|||
#toast-container > div { |
|||
padding: 8px 8px 8px 50px; |
|||
width: 11em; |
|||
} |
|||
#toast-container .toast-close-button { |
|||
right: -0.2em; |
|||
top: -0.2em; |
|||
} |
|||
} |
|||
@media all and (min-width: 241px) and (max-width: 480px) { |
|||
#toast-container > div { |
|||
padding: 8px 8px 8px 50px; |
|||
width: 18em; |
|||
} |
|||
#toast-container .toast-close-button { |
|||
right: -0.2em; |
|||
top: -0.2em; |
|||
} |
|||
} |
|||
@media all and (min-width: 481px) and (max-width: 768px) { |
|||
#toast-container > div { |
|||
padding: 15px 15px 15px 50px; |
|||
width: 25em; |
|||
} |
|||
} |
@ -0,0 +1,126 @@ |
|||
/*********************************************************************************** |
|||
* AJAX Error 및 BlockUI 처리 |
|||
***********************************************************************************/ |
|||
$(function() { |
|||
$(document).ajaxError(function(event, request, settings){ |
|||
var message = '알수없는 오류가 발생하였습니다.'; |
|||
if( typeof request.responseJSON != 'undefined' && typeof request.responseJSON.message != 'undefined' ) { |
|||
message = request.responseJSON.message; |
|||
} |
|||
else { |
|||
if( request.status == 500 ) message = '서버 코드 오류가 발생하였습니다.\n관리자에게 문의하세요'; |
|||
else if ( request.status == 401 ) message = '해당 명령을 실행할 권한이 없습니다.'; |
|||
} |
|||
toastr.error(message, '오류 발생'); |
|||
}).ajaxStart(function(){ |
|||
$.blockUI({ |
|||
css: {width:'25px',top:'49%',left:'49%',border:'0px none',backgroundColor:'transparent',cursor:'wait'}, |
|||
message : '<img src="/assets/images/common/ajax-loader.gif" alt="로딩중">', |
|||
baseZ : 10000, |
|||
overlayCSS : {opacity : 0} |
|||
}); |
|||
}).ajaxComplete(function(){ |
|||
$.unblockUI(); |
|||
}); |
|||
}); |
|||
|
|||
/*********************************************************************************************************************** |
|||
* 전체체크박스 / 체크박스 연동 |
|||
***********************************************************************************************************************/ |
|||
$(function() { |
|||
$(document).on('change', '[data-checkbox]', function() { |
|||
var $check = $(this); |
|||
var is_all = $check.data('checkbox-all') != null ? true : false; |
|||
var name = $check.data('checkbox'); |
|||
var checked = $check.prop('checked'); |
|||
var $allCheck = is_all ? $check : $('[data-checkbox="'+name+'"][data-checkbox-all]'); |
|||
|
|||
if( is_all ) { |
|||
$('[data-checkbox="'+name+'"]').prop('checked', checked ); |
|||
} |
|||
else { |
|||
$allCheck.prop('checked', $('[data-checkbox="'+name+'"]').not('[data-checkbox-all]').length == $('[data-checkbox="'+name+'"]:checked').not('[data-checkbox-all]').length); |
|||
} |
|||
}); |
|||
}); |
|||
|
|||
/*********************************************************************************************************************** |
|||
* 숫자 3자리마다 Comma 자동 입력 |
|||
***********************************************************************************************************************/ |
|||
$(function() { |
|||
$(document).on('keypress', '[data-number-format]', function(e) { |
|||
$(this).val( $(this).val().trim().unNumberFormat().numberFormat() ); |
|||
}) |
|||
}); |
|||
|
|||
/*********************************************************************************************************************** |
|||
* 숫자만 입력가능한 Input |
|||
***********************************************************************************************************************/ |
|||
$(function() { |
|||
$(document).on('keypress', '[data-number-only]', function(e) { |
|||
if (e.which != 8 && e.which != 0 && e.which != 45 && (e.which < 48 || e.which > 57)) { |
|||
e.preventDefault(); |
|||
} |
|||
}) |
|||
}); |
|||
|
|||
/*********************************************************************************************************************** |
|||
* 높이 자동조절되는 Textarea |
|||
***********************************************************************************************************************/ |
|||
$(function() { |
|||
$(document).on('keyup','textarea[data-autosize]', function(e) { |
|||
autosize($(this)); |
|||
}); |
|||
$('textarea[data-autosize]').keyup(); |
|||
}); |
|||
|
|||
$(function() { |
|||
/*********************************************************************************************************************** |
|||
* 핸드폰 번호 Input |
|||
***********************************************************************************************************************/ |
|||
$('body').on('keypress', '[data-regex="phone-number"]', function(e){ |
|||
if (e.which != 8 && e.which != 0 && e.which != 45 && (e.which < 48 || e.which > 57)) { |
|||
e.preventDefault(); |
|||
} |
|||
}).on('blur','[data-regex="phone-number"]', function(e){ |
|||
if($(this).val() == '') return; |
|||
var transNum = $(this).val().regex('phone'); |
|||
if( transNum === false ) { |
|||
toastr.error('유효하지 않은 전화번호 입니다.'); |
|||
$(this).val(""); |
|||
$(this).focus(); |
|||
return; |
|||
} |
|||
$(this).val(transNum); |
|||
}); |
|||
|
|||
/*********************************************************************************************************************** |
|||
* 전화번호 Input |
|||
***********************************************************************************************************************/ |
|||
$('body').on('blur', '[data-regex="tel-number"]', function(e){ |
|||
if($(this).val() == '') return; |
|||
var transNum = $(this).val().regex('tel'); |
|||
if( transNum === false ) { |
|||
toastr.error('유효하지 않은 전화번호 입니다.'); |
|||
$(this).val(""); |
|||
$(this).focus(); |
|||
return; |
|||
} |
|||
$(this).val(transNum); |
|||
}); |
|||
|
|||
/*********************************************************************************************************************** |
|||
* 이메일주소 Input |
|||
***********************************************************************************************************************/ |
|||
$('body').on('blur', '[data-regex="email-address"]', function(e){ |
|||
if($(this).val() == '') return; |
|||
var trans_num = $(this).val().regex('email'); |
|||
|
|||
if(! trans_num) { |
|||
toastr.error('유효하지 않은 이메일주소 입니다.'); |
|||
$(this).val(""); |
|||
$(this).focus(); |
|||
} |
|||
}); |
|||
}); |
|||
|
@ -0,0 +1,98 @@ |
|||
/********************************************************************************************************************** |
|||
* 숫자에 컴마를 붙여서 리턴한다 |
|||
* @returns {*} |
|||
*********************************************************************************************************************/ |
|||
Number.prototype.numberFormat = function(){ |
|||
if(this==0) return 0; |
|||
|
|||
var reg = /(^[+-]?\d+)(\d{3})/; |
|||
var n = (this + ''); |
|||
|
|||
while (reg.test(n)) n = n.replace(reg, '$1' + ',' + '$2'); |
|||
|
|||
return n; |
|||
}; |
|||
String.prototype.numberFormat = function() { return isNaN( parseFloat(this) ) ? "0" : (parseFloat(this)).numberFormat(); }; |
|||
|
|||
/********************************************************************************************************************** |
|||
* 컴마가 붙어있는 숫자에서 콤마를 삭제하고 숫자로 반환한다. |
|||
* @returns {*} |
|||
*********************************************************************************************************************/ |
|||
String.prototype.unNumberFormat = function() { |
|||
var str = this; |
|||
if(typeof str == 'number') return str; |
|||
str = ("" + str).replace(/,/gi,''); // 콤마 제거
|
|||
str = str.replace(/(^\s*)|(\s*$)/g, ""); // trim
|
|||
|
|||
var returnStr = new Number(str); |
|||
return isNaN(returnStr) ? str : returnStr; |
|||
}; |
|||
Number.prototype.unNumberFormat = function() { |
|||
return this; |
|||
}; |
|||
|
|||
/********************************************************************************************************************** |
|||
* 날짜를 원하는 포맷 형식으로 출력 |
|||
* @param f |
|||
* @returns {*} |
|||
*********************************************************************************************************************/ |
|||
Date.prototype.dateFormat = function(f) { |
|||
if (!this.valueOf()) return " "; |
|||
if (!f) return this; |
|||
|
|||
var weekName = ["일요일", "월요일", "화요일", "수요일", "목요일", "금요일", "토요일"], |
|||
shortWeekName = ["일", "월", "화", "수", "목", "금", "토"], |
|||
d = this; |
|||
|
|||
return f.replace(/(yyyy|yy|MM|dd|E|hh|mm|ss|a\/p)/gi, function($1) { |
|||
switch ($1) { |
|||
case "yyyy": return d.getFullYear(); |
|||
case "yy": return (d.getFullYear() % 1000).zf(2); |
|||
case "MM": return (d.getMonth() + 1).zf(2); |
|||
case "dd": return d.getDate().zf(2); |
|||
case "E": return weekName[d.getDay()]; |
|||
case "e": return shortWeekName[d.getDay()]; |
|||
case "HH": return d.getHours().zf(2); |
|||
case "hh": return ((h = d.getHours() % 12) ? h : 12).zf(2); |
|||
case "mm": return d.getMinutes().zf(2); |
|||
case "ss": return d.getSeconds().zf(2); |
|||
case "a/p": return d.getHours() < 12 ? "오전" : "오후"; |
|||
default: return $1; |
|||
} |
|||
}); |
|||
}; |
|||
String.prototype.string = function(len){var s = '', i = 0; while (i++ < len) { s += this; } return s;}; |
|||
String.prototype.zf = function(len){return "0".string(len - this.length) + this;}; |
|||
Number.prototype.zf = function(len){return this.toString().zf(len);}; |
|||
String.prototype.dateFormat = function(f) { |
|||
var d = new Date(this); |
|||
return ( d == 'Invalid Date') ? '' : d.dateFormat(f); |
|||
} |
|||
|
|||
/********************************************************************************************************************** |
|||
* 숫자를 한글명으로 바꿔서 보여줍니다. |
|||
*********************************************************************************************************************/ |
|||
Number.prototype.toKorean = function() { |
|||
var hanA = new Array("","일","이","삼","사","오","육","칠","팔","구","십"), |
|||
danA = new Array("","십","백","천","","십","백","천","","십","백","천","","십","백","천"), |
|||
num = new String(this), |
|||
result = ''; |
|||
|
|||
for(var i=0; i<num.length; i++) { |
|||
var str = "", |
|||
han = hanA[num.charAt(num.length-(i+1))]; |
|||
|
|||
if(han != "") str += han+danA[i]; |
|||
|
|||
if(i == 4) str += "만"; |
|||
if(i == 8) str += "억"; |
|||
if(i == 12) str += "조"; |
|||
|
|||
result = str + result; |
|||
} |
|||
|
|||
return result; |
|||
} |
|||
String.prototype.toKorean = function() { |
|||
return (this.unNumberFormat()).toKorean(); |
|||
} |
@ -0,0 +1,194 @@ |
|||
APP.MODAL = function() { |
|||
var modalCallback = {}; |
|||
|
|||
var defaultCss = { |
|||
width: 400, |
|||
height: 400, |
|||
position: { |
|||
left: "center", |
|||
top: "middle" |
|||
} |
|||
}; |
|||
|
|||
var defaultOption = $.extend(true, {}, defaultCss, { |
|||
iframeLoadingMsg: "", |
|||
iframe: { |
|||
method: "get", |
|||
url: "#" |
|||
}, |
|||
closeToEsc: true, |
|||
onStateChanged: function onStateChanged() { |
|||
// mask
|
|||
if (this.state === "open") { |
|||
APP.MASK.open(); |
|||
} else if (this.state === "close") { |
|||
APP.MASK.close(); |
|||
} |
|||
}, |
|||
animateTime: 100, |
|||
zIndex: 1001, |
|||
absolute: true, |
|||
fullScreen: false, |
|||
header: { |
|||
title: "새로운 윈도우", |
|||
btns: { |
|||
close: { |
|||
label: '<i class="far fa-times"></i>', onClick: function onClick() { |
|||
APP.MODAL.callback(); |
|||
} |
|||
} |
|||
} |
|||
} |
|||
}); |
|||
|
|||
var open = function(modalConfig) { |
|||
|
|||
modalConfig = $.extend(true, {}, defaultOption, modalConfig); |
|||
$(document.body).addClass("modalOpened"); |
|||
|
|||
this.modalCallback = modalConfig.callback; |
|||
this.modalSendData = modalConfig.sendData; |
|||
|
|||
APP.modal.open(modalConfig); |
|||
}; |
|||
|
|||
var css = function css(modalCss) { |
|||
modalCss = $.extend(true, {}, defaultCss, modalCss); |
|||
APP.modal.css(modalCss); |
|||
}; |
|||
var align = function align(modalAlign) { |
|||
APP.modal.align(modalAlign); |
|||
}; |
|||
var close = function close(data) { |
|||
APP.modal.close(); |
|||
setTimeout(function () { |
|||
$(document.body).removeClass("modalOpened"); |
|||
}, 500); |
|||
}; |
|||
var minimize = function minimize() { |
|||
APP.modal.minimize(); |
|||
}; |
|||
var maximize = function maximize() { |
|||
APP.modal.maximize(); |
|||
}; |
|||
var callback = function callback(data) { |
|||
if (this.modalCallback) { |
|||
this.modalCallback(data); |
|||
} |
|||
this.close(data); |
|||
}; |
|||
var getData = function getData() { |
|||
if (this.modalSendData) { |
|||
return this.modalSendData(); |
|||
} |
|||
}; |
|||
|
|||
return { |
|||
"open": open, |
|||
"css": css, |
|||
"align": align, |
|||
"close": close, |
|||
"minimize": minimize, |
|||
"maximize": maximize, |
|||
"callback": callback, |
|||
"modalCallback": modalCallback, |
|||
"getData": getData |
|||
}; |
|||
}(); |
|||
APP.MODAL2 = function() { |
|||
var modalCallback = {}; |
|||
|
|||
var defaultCss = { |
|||
width: 400, |
|||
height: 400, |
|||
position: { |
|||
left: "center", |
|||
top: "middle" |
|||
} |
|||
}; |
|||
|
|||
var defaultOption = $.extend(true, {}, defaultCss, { |
|||
iframeLoadingMsg: "", |
|||
iframe: { |
|||
method: "get", |
|||
url: "#" |
|||
}, |
|||
closeToEsc: true, |
|||
onStateChanged: function onStateChanged() { |
|||
// mask
|
|||
if (this.state === "open") { |
|||
APP.MASK2.open(); |
|||
} else if (this.state === "close") { |
|||
APP.MASK2.close(); |
|||
} |
|||
}, |
|||
animateTime: 100, |
|||
zIndex: 2001, |
|||
absolute: true, |
|||
fullScreen: false, |
|||
header: { |
|||
title: "새로운 윈도우", |
|||
btns: { |
|||
close: { |
|||
label: '<i class="far fa-times"></i>', onClick: function onClick() { |
|||
APP.MODAL2.callback(); |
|||
} |
|||
} |
|||
} |
|||
} |
|||
}); |
|||
|
|||
var open = function(modalConfig) { |
|||
|
|||
modalConfig = $.extend(true, {}, defaultOption, modalConfig); |
|||
$(document.body).addClass("modalOpened"); |
|||
|
|||
this.modalCallback = modalConfig.callback; |
|||
this.modalSendData = modalConfig.sendData; |
|||
|
|||
APP.modal2.open(modalConfig); |
|||
}; |
|||
|
|||
var css = function css(modalCss) { |
|||
modalCss = $.extend(true, {}, defaultCss, modalCss); |
|||
APP.modal2.css(modalCss); |
|||
}; |
|||
var align = function align(modalAlign) { |
|||
APP.modal2.align(modalAlign); |
|||
}; |
|||
var close = function close(data) { |
|||
APP.modal2.close(); |
|||
setTimeout(function () { |
|||
$(document.body).removeClass("modalOpened"); |
|||
}, 500); |
|||
}; |
|||
var minimize = function minimize() { |
|||
APP.modal2.minimize(); |
|||
}; |
|||
var maximize = function maximize() { |
|||
APP.modal2.maximize(); |
|||
}; |
|||
var callback = function callback(data) { |
|||
if (this.modalCallback) { |
|||
this.modalCallback(data); |
|||
} |
|||
this.close(data); |
|||
}; |
|||
var getData = function getData() { |
|||
if (this.modalSendData) { |
|||
return this.modalSendData(); |
|||
} |
|||
}; |
|||
|
|||
return { |
|||
"open": open, |
|||
"css": css, |
|||
"align": align, |
|||
"close": close, |
|||
"minimize": minimize, |
|||
"maximize": maximize, |
|||
"callback": callback, |
|||
"modalCallback": modalCallback, |
|||
"getData": getData |
|||
}; |
|||
}(); |
@ -0,0 +1,28 @@ |
|||
APP.POPUP = null; |
|||
(function($) { |
|||
APP.POPUP = function(option) { |
|||
var defaults={ |
|||
title : '_blank', |
|||
width : 800, |
|||
height : 600, |
|||
url : '' |
|||
}; |
|||
|
|||
var options = $.extend({}, defaults, option); |
|||
|
|||
cw = screen.availWidth; |
|||
ch = screen.availHeight; |
|||
sw = options.width; |
|||
sh = options.height; |
|||
|
|||
ml = (cw - sw) / 2; |
|||
mt = (ch - sh) / 2; |
|||
var option = 'width='+sw+',height='+sh+',top='+mt+',left='+ml+',scrollbars=yes,resizable=no'; |
|||
var win = window.open(options.url, options.title, option); |
|||
if (win == null || typeof(win) == "undefined" || (win == null && win.outerWidth == 0) || (win != null && win.outerHeight == 0)) |
|||
{ |
|||
alert("팝업 차단 기능이 설정되어있습니다\n\n차단 기능을 해제(팝업허용) 한 후 다시 이용해 주십시오."); |
|||
return; |
|||
} |
|||
}; |
|||
})(jQuery); |
@ -0,0 +1,49 @@ |
|||
/************************************************************************************************************************ |
|||
* 해당 문자열의 regex 검사 |
|||
* @param regexType |
|||
*************************************************************************************************************************/ |
|||
String.prototype.regex = function(regexType) { |
|||
var phoneRegex = /^(01[016789]{1}|02|0[3-9]{1}[0-9]{1})([0-9]{3,4})([0-9]{4})$/, |
|||
phoneWithHypenRegex = /^(01[016789]{1}|02|0[3-9]{1}[0-9]{1})-?([0-9]{3,4})-?([0-9]{4})$/, |
|||
telRegex = /(^02.{0}|^01.{1}|[0-9]{3})([0-9]{3,4})([0-9]{4})/, |
|||
telCheckRegex = /^\d{2,3}-\d{3,4}-\d{4}$/, |
|||
uniqueID = /^[a-z][a-z0-9_]{2,19}$/g, |
|||
emailRegex = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/, |
|||
str = this; |
|||
|
|||
switch(regexType) { |
|||
case "phone" : |
|||
var transNum = str.replace(/\s/gi, '').replace(/-/gi,''); |
|||
if(transNum.length == 11 || transNum.length == 10) { |
|||
if( phoneRegex.test(transNum) ) { |
|||
transNum = transNum.replace(phoneWithHypenRegex, '$1-$2-$3'); |
|||
return transNum; |
|||
} |
|||
} |
|||
return false; |
|||
case "tel": |
|||
var transNum = str.replace(/\s/gi, '').replace(/-/gi,''); |
|||
transNum = transNum.replace(telRegex, '$1-$2-$3'); |
|||
if(telCheckRegex.test(transNum)) { |
|||
return transNum; |
|||
} |
|||
return false; |
|||
case "email": |
|||
return emailRegex.test(str); |
|||
case "biznum" : |
|||
var checkID = new Array(1, 3, 7, 1, 3, 7, 1, 3, 5, 1), |
|||
tmpBizID, i, chkSum=0, c2, remander, |
|||
bizID = str.replace(/-/gi,''); |
|||
|
|||
for (i=0; i<=7; i++) chkSum += checkID[i] * bizID.charAt(i); |
|||
c2 = "0" + (checkID[8] * bizID.charAt(8)); |
|||
c2 = c2.substring(c2.length - 2, c2.length); |
|||
chkSum += Math.floor(c2.charAt(0)) + Math.floor(c2.charAt(1)); |
|||
remander = (10 - (chkSum % 10)) % 10 ; |
|||
|
|||
if (Math.floor(bizID.charAt(9)) == remander) return bizID.replace(/(\d{3})(\d{2})(\d{5})/, '$1-$2-$3'); |
|||
return false; |
|||
case "uniqid" : |
|||
return uniqueID.test(str); |
|||
} |
|||
}; |
@ -0,0 +1,288 @@ |
|||
/*! |
|||
autosize 4.0.2 |
|||
license: MIT |
|||
http://www.jacklmoore.com/autosize
|
|||
*/ |
|||
(function (global, factory) { |
|||
if (typeof define === "function" && define.amd) { |
|||
define(['module', 'exports'], factory); |
|||
} else if (typeof exports !== "undefined") { |
|||
factory(module, exports); |
|||
} else { |
|||
var mod = { |
|||
exports: {} |
|||
}; |
|||
factory(mod, mod.exports); |
|||
global.autosize = mod.exports; |
|||
} |
|||
})(this, function (module, exports) { |
|||
'use strict'; |
|||
|
|||
var map = typeof Map === "function" ? new Map() : function () { |
|||
var keys = []; |
|||
var values = []; |
|||
|
|||
return { |
|||
has: function has(key) { |
|||
return keys.indexOf(key) > -1; |
|||
}, |
|||
get: function get(key) { |
|||
return values[keys.indexOf(key)]; |
|||
}, |
|||
set: function set(key, value) { |
|||
if (keys.indexOf(key) === -1) { |
|||
keys.push(key); |
|||
values.push(value); |
|||
} |
|||
}, |
|||
delete: function _delete(key) { |
|||
var index = keys.indexOf(key); |
|||
if (index > -1) { |
|||
keys.splice(index, 1); |
|||
values.splice(index, 1); |
|||
} |
|||
} |
|||
}; |
|||
}(); |
|||
|
|||
var createEvent = function createEvent(name) { |
|||
return new Event(name, { bubbles: true }); |
|||
}; |
|||
try { |
|||
new Event('test'); |
|||
} catch (e) { |
|||
// IE does not support `new Event()`
|
|||
createEvent = function createEvent(name) { |
|||
var evt = document.createEvent('Event'); |
|||
evt.initEvent(name, true, false); |
|||
return evt; |
|||
}; |
|||
} |
|||
|
|||
function assign(ta) { |
|||
if (!ta || !ta.nodeName || ta.nodeName !== 'TEXTAREA' || map.has(ta)) return; |
|||
|
|||
var heightOffset = null; |
|||
var clientWidth = null; |
|||
var cachedHeight = null; |
|||
|
|||
function init() { |
|||
var style = window.getComputedStyle(ta, null); |
|||
|
|||
if (style.resize === 'vertical') { |
|||
ta.style.resize = 'none'; |
|||
} else if (style.resize === 'both') { |
|||
ta.style.resize = 'horizontal'; |
|||
} |
|||
|
|||
if (style.boxSizing === 'content-box') { |
|||
heightOffset = -(parseFloat(style.paddingTop) + parseFloat(style.paddingBottom)); |
|||
} else { |
|||
heightOffset = parseFloat(style.borderTopWidth) + parseFloat(style.borderBottomWidth); |
|||
} |
|||
// Fix when a textarea is not on document body and heightOffset is Not a Number
|
|||
if (isNaN(heightOffset)) { |
|||
heightOffset = 0; |
|||
} |
|||
|
|||
update(); |
|||
} |
|||
|
|||
function changeOverflow(value) { |
|||
{ |
|||
// Chrome/Safari-specific fix:
|
|||
// When the textarea y-overflow is hidden, Chrome/Safari do not reflow the text to account for the space
|
|||
// made available by removing the scrollbar. The following forces the necessary text reflow.
|
|||
var width = ta.style.width; |
|||
ta.style.width = '0px'; |
|||
// Force reflow:
|
|||
/* jshint ignore:start */ |
|||
ta.offsetWidth; |
|||
/* jshint ignore:end */ |
|||
ta.style.width = width; |
|||
} |
|||
|
|||
ta.style.overflowY = value; |
|||
} |
|||
|
|||
function getParentOverflows(el) { |
|||
var arr = []; |
|||
|
|||
while (el && el.parentNode && el.parentNode instanceof Element) { |
|||
if (el.parentNode.scrollTop) { |
|||
arr.push({ |
|||
node: el.parentNode, |
|||
scrollTop: el.parentNode.scrollTop |
|||
}); |
|||
} |
|||
el = el.parentNode; |
|||
} |
|||
|
|||
return arr; |
|||
} |
|||
|
|||
function resize() { |
|||
if (ta.scrollHeight === 0) { |
|||
// If the scrollHeight is 0, then the element probably has display:none or is detached from the DOM.
|
|||
return; |
|||
} |
|||
|
|||
var overflows = getParentOverflows(ta); |
|||
var docTop = document.documentElement && document.documentElement.scrollTop; // Needed for Mobile IE (ticket #240)
|
|||
|
|||
ta.style.height = ''; |
|||
ta.style.height = ta.scrollHeight + heightOffset + 'px'; |
|||
|
|||
// used to check if an update is actually necessary on window.resize
|
|||
clientWidth = ta.clientWidth; |
|||
|
|||
// prevents scroll-position jumping
|
|||
overflows.forEach(function (el) { |
|||
el.node.scrollTop = el.scrollTop; |
|||
}); |
|||
|
|||
if (docTop) { |
|||
document.documentElement.scrollTop = docTop; |
|||
} |
|||
} |
|||
|
|||
function update() { |
|||
resize(); |
|||
|
|||
var styleHeight = Math.round(parseFloat(ta.style.height)); |
|||
var computed = window.getComputedStyle(ta, null); |
|||
|
|||
// Using offsetHeight as a replacement for computed.height in IE, because IE does not account use of border-box
|
|||
var actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(computed.height)) : ta.offsetHeight; |
|||
|
|||
// The actual height not matching the style height (set via the resize method) indicates that
|
|||
// the max-height has been exceeded, in which case the overflow should be allowed.
|
|||
if (actualHeight < styleHeight) { |
|||
if (computed.overflowY === 'hidden') { |
|||
changeOverflow('scroll'); |
|||
resize(); |
|||
actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(window.getComputedStyle(ta, null).height)) : ta.offsetHeight; |
|||
} |
|||
} else { |
|||
// Normally keep overflow set to hidden, to avoid flash of scrollbar as the textarea expands.
|
|||
if (computed.overflowY !== 'hidden') { |
|||
changeOverflow('hidden'); |
|||
resize(); |
|||
actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(window.getComputedStyle(ta, null).height)) : ta.offsetHeight; |
|||
} |
|||
} |
|||
|
|||
if (cachedHeight !== actualHeight) { |
|||
cachedHeight = actualHeight; |
|||
var evt = createEvent('autosize:resized'); |
|||
try { |
|||
ta.dispatchEvent(evt); |
|||
} catch (err) { |
|||
// Firefox will throw an error on dispatchEvent for a detached element
|
|||
// https://bugzilla.mozilla.org/show_bug.cgi?id=889376
|
|||
} |
|||
} |
|||
} |
|||
|
|||
var pageResize = function pageResize() { |
|||
if (ta.clientWidth !== clientWidth) { |
|||
update(); |
|||
} |
|||
}; |
|||
|
|||
var destroy = function (style) { |
|||
window.removeEventListener('resize', pageResize, false); |
|||
ta.removeEventListener('input', update, false); |
|||
ta.removeEventListener('keyup', update, false); |
|||
ta.removeEventListener('autosize:destroy', destroy, false); |
|||
ta.removeEventListener('autosize:update', update, false); |
|||
|
|||
Object.keys(style).forEach(function (key) { |
|||
ta.style[key] = style[key]; |
|||
}); |
|||
|
|||
map.delete(ta); |
|||
}.bind(ta, { |
|||
height: ta.style.height, |
|||
resize: ta.style.resize, |
|||
overflowY: ta.style.overflowY, |
|||
overflowX: ta.style.overflowX, |
|||
wordWrap: ta.style.wordWrap |
|||
}); |
|||
|
|||
ta.addEventListener('autosize:destroy', destroy, false); |
|||
|
|||
// IE9 does not fire onpropertychange or oninput for deletions,
|
|||
// so binding to onkeyup to catch most of those events.
|
|||
// There is no way that I know of to detect something like 'cut' in IE9.
|
|||
if ('onpropertychange' in ta && 'oninput' in ta) { |
|||
ta.addEventListener('keyup', update, false); |
|||
} |
|||
|
|||
window.addEventListener('resize', pageResize, false); |
|||
ta.addEventListener('input', update, false); |
|||
ta.addEventListener('autosize:update', update, false); |
|||
ta.style.overflowX = 'hidden'; |
|||
ta.style.wordWrap = 'break-word'; |
|||
|
|||
map.set(ta, { |
|||
destroy: destroy, |
|||
update: update |
|||
}); |
|||
|
|||
init(); |
|||
} |
|||
|
|||
function destroy(ta) { |
|||
var methods = map.get(ta); |
|||
if (methods) { |
|||
methods.destroy(); |
|||
} |
|||
} |
|||
|
|||
function update(ta) { |
|||
var methods = map.get(ta); |
|||
if (methods) { |
|||
methods.update(); |
|||
} |
|||
} |
|||
|
|||
var autosize = null; |
|||
|
|||
// Do nothing in Node.js environment and IE8 (or lower)
|
|||
if (typeof window === 'undefined' || typeof window.getComputedStyle !== 'function') { |
|||
autosize = function autosize(el) { |
|||
return el; |
|||
}; |
|||
autosize.destroy = function (el) { |
|||
return el; |
|||
}; |
|||
autosize.update = function (el) { |
|||
return el; |
|||
}; |
|||
} else { |
|||
autosize = function autosize(el, options) { |
|||
if (el) { |
|||
Array.prototype.forEach.call(el.length ? el : [el], function (x) { |
|||
return assign(x, options); |
|||
}); |
|||
} |
|||
return el; |
|||
}; |
|||
autosize.destroy = function (el) { |
|||
if (el) { |
|||
Array.prototype.forEach.call(el.length ? el : [el], destroy); |
|||
} |
|||
return el; |
|||
}; |
|||
autosize.update = function (el) { |
|||
if (el) { |
|||
Array.prototype.forEach.call(el.length ? el : [el], update); |
|||
} |
|||
return el; |
|||
}; |
|||
} |
|||
|
|||
exports.default = autosize; |
|||
module.exports = exports['default']; |
|||
}); |
@ -0,0 +1,98 @@ |
|||
.ellipsis { text-overflow:ellipsis; white-space:nowrap; word-wrap:normal; overflow:hidden; } |
|||
.admin-help-wrap { |
|||
width:700px; margin:0 auto; |
|||
li > img {width:700px;} |
|||
.point-color {color:#e60035} |
|||
} |
|||
.sr-only { |
|||
position: absolute; |
|||
width: 1px; |
|||
height: 1px; |
|||
padding: 0; |
|||
overflow: hidden; |
|||
clip: rect(0, 0, 0, 0); |
|||
white-space: nowrap; |
|||
border: 0; |
|||
|
|||
&.sr-only-focusable { |
|||
&:active, |
|||
&:focus { |
|||
position: static; |
|||
width: auto; |
|||
height: auto; |
|||
overflow: visible; |
|||
clip: auto; |
|||
white-space: normal; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.clearfix { |
|||
&, |
|||
&:before, |
|||
&:after { |
|||
@include clear-fix(); |
|||
} |
|||
} |
|||
|
|||
|
|||
/* 높이/너비/마진/패딩 */ |
|||
@for $i from 1 to 201 { |
|||
.H#{$i * 5} { |
|||
height: 5px * $i !important; |
|||
} |
|||
} |
|||
@for $i from 1 to 201{ |
|||
.W#{$i * 5} { |
|||
width: 5px * $i !important; |
|||
} |
|||
} |
|||
@for $i from 1 to 10 { |
|||
.M#{$i * 5} { |
|||
margin:5px * $i; |
|||
} |
|||
.MT#{$i * 5} { |
|||
margin-top:5px * $i; |
|||
} |
|||
.MR#{$i*5} { |
|||
margin-right:5px * $i; |
|||
} |
|||
.MB#{$i * 5} { |
|||
margin-bottom:5px * $i; |
|||
} |
|||
.ML#{$i * 5} { |
|||
margin-left:5px * $i; |
|||
} |
|||
.PT#{$i * 5} { |
|||
padding-top:5px * $i; |
|||
} |
|||
.PR#{$i * 5} { |
|||
padding-right:5px * $i; |
|||
} |
|||
.PB#{$i * 5} { |
|||
padding-bottom:5px * $i; |
|||
} |
|||
.PL#{$i * 5} { |
|||
padding-left:5px * $i; |
|||
} |
|||
.P#{$i * 5} { |
|||
padding:5px * $i; |
|||
} |
|||
} |
|||
|
|||
.text-center { |
|||
text-align:center !important; |
|||
} |
|||
|
|||
.text-left { |
|||
text-align:left !important; |
|||
} |
|||
|
|||
.text-right { |
|||
text-align:right !important; |
|||
} |
|||
|
|||
.margin-auto { |
|||
margin-left:auto; |
|||
margin-right:auto; |
|||
} |
@ -0,0 +1,15 @@ |
|||
@import "reset"; |
|||
@import "mixins"; |
|||
@import "function"; |
|||
|
|||
@import "plugins/fontawesome5/fontawesome"; |
|||
@import "plugins/fontawesome5/regular"; |
|||
@import "plugins/fontawesome5/light"; |
|||
@import "plugins/fontawesome5/solid"; |
|||
@import "plugins/fontawesome5/brands"; |
|||
@import "plugins/toastr"; |
|||
@import "plugins/ax5ui/ax5"; |
|||
@import "plugins/ax5ui/ax5mask"; |
|||
@import "plugins/ax5ui/ax5modal"; |
|||
|
|||
@import "utility"; |
293
_src/common/scss/plugins/fontawesome5/_icons.scss
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
296
_src/common/scss/plugins/fontawesome5/_variables.scss
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -1,5 +1,5 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* Font Awesome Pro 5.9.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
@ -1,5 +1,5 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* Font Awesome Pro 5.9.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
@ -1,5 +0,0 @@ |
|||
// 기본 픽셀 사이즈를 rem 단위 사이즈로 변환 |
|||
@function REM($pxSize:16px){ |
|||
$remSize : $pxSize / $font-size-base !global; |
|||
@return #{$remSize}rem; |
|||
} |
@ -1,56 +0,0 @@ |
|||
// Clear FIX |
|||
@mixin clear-fix() { |
|||
display:block; |
|||
clear:both; |
|||
content:""; |
|||
} |
|||
|
|||
// Button Default Style |
|||
@mixin button-default() { |
|||
display: inline-block; |
|||
margin:0; |
|||
font-weight: normal; |
|||
text-align: center; |
|||
white-space: nowrap; |
|||
user-select: none; |
|||
text-decoration: none; |
|||
outline:0; |
|||
vertical-align:middle; |
|||
|
|||
&:disabled, |
|||
&.disabled { |
|||
opacity:0.65; |
|||
} |
|||
|
|||
&:not([disabled]):not(.disabled) { |
|||
cursor: pointer; |
|||
} |
|||
} |
|||
|
|||
// background Image |
|||
@mixin background-image( $image_url, $bg_color:transparent, $background-repeat:no-repeat, $background-position-x:center, $background-position-y:center ) |
|||
{ |
|||
background-color:$bg_color; |
|||
background-image:url($image_url); |
|||
background-repeat: $background-repeat; |
|||
background-position-x:$background-position-x; |
|||
background-position-y:$background-position-y; |
|||
} |
|||
|
|||
// Global Transition |
|||
@mixin transition($second:.3s, $target:all, $animation:$default-animation) |
|||
{ |
|||
-webkit-transition: $target $second $animation; |
|||
-moz-transition: $target $second $animation; |
|||
-ms-transition: $target $second $animation; |
|||
-o-transition: $target $second $animation; |
|||
transition: $target $second $animation; |
|||
} |
|||
|
|||
// Display flex & Prefix |
|||
@mixin display-flex() |
|||
{ |
|||
-webkit-display:flex; |
|||
display:-ms-flex; |
|||
display:flex; |
|||
} |
@ -1,77 +1,3 @@ |
|||
/*************************************************************************************** |
|||
* 유틸리티 |
|||
****************************************************************************************/ |
|||
.sr-only { |
|||
position: absolute; |
|||
width: 1px; |
|||
height: 1px; |
|||
padding: 0; |
|||
overflow: hidden; |
|||
clip: rect(0, 0, 0, 0); |
|||
white-space: nowrap; |
|||
border: 0; |
|||
|
|||
&.sr-only-focusable { |
|||
&:active, |
|||
&:focus { |
|||
position: static; |
|||
width: auto; |
|||
height: auto; |
|||
overflow: visible; |
|||
clip: auto; |
|||
white-space: normal; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.clearfix { |
|||
&, |
|||
&:before, |
|||
&:after { |
|||
@include clear-fix(); |
|||
} |
|||
} |
|||
|
|||
/* 높이/너비/마진/패딩 */ |
|||
@for $i from 2 to 10 { |
|||
.H#{$i * 5} { |
|||
height: 5px * $i !important; |
|||
} |
|||
} |
|||
@for $i from 2 to 20 { |
|||
.W#{$i * 25} { |
|||
width: 25px * $i !important; |
|||
} |
|||
} |
|||
@for $i from 1 to 10 { |
|||
.M#{$i * 5} { |
|||
margin:5px * $i; |
|||
} |
|||
.MT#{$i * 5} { |
|||
margin-top:5px * $i; |
|||
} |
|||
.MR#{$i*5} { |
|||
margin-right:5px * $i; |
|||
} |
|||
.MB#{$i * 5} { |
|||
margin-bottom:5px * $i; |
|||
} |
|||
.ML#{$i * 5} { |
|||
margin-left:5px * $i; |
|||
} |
|||
.PT#{$i * 5} { |
|||
padding-top:5px * $i; |
|||
} |
|||
.PR#{$i * 5} { |
|||
padding-right:5px * $i; |
|||
} |
|||
.PB#{$i * 5} { |
|||
padding-bottom:5px * $i; |
|||
} |
|||
.PL#{$i * 5} { |
|||
padding-left:5px * $i; |
|||
} |
|||
.P#{$i * 5} { |
|||
padding:5px * $i; |
|||
} |
|||
} |
@ -1,20 +0,0 @@ |
|||
// Animated Icons |
|||
// -------------------------- |
|||
|
|||
.#{$fa-css-prefix}-spin { |
|||
animation: fa-spin 2s infinite linear; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-pulse { |
|||
animation: fa-spin 1s infinite steps(8); |
|||
} |
|||
|
|||
@keyframes fa-spin { |
|||
0% { |
|||
transform: rotate(0deg); |
|||
} |
|||
|
|||
100% { |
|||
transform: rotate(360deg); |
|||
} |
|||
} |
@ -1,20 +0,0 @@ |
|||
// Bordered & Pulled |
|||
// ------------------------- |
|||
|
|||
.#{$fa-css-prefix}-border { |
|||
border: solid .08em $fa-border-color; |
|||
border-radius: .1em; |
|||
padding: .2em .25em .15em; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-pull-left { float: left; } |
|||
.#{$fa-css-prefix}-pull-right { float: right; } |
|||
|
|||
.#{$fa-css-prefix}, |
|||
.fas, |
|||
.far, |
|||
.fal, |
|||
.fab { |
|||
&.#{$fa-css-prefix}-pull-left { margin-right: .3em; } |
|||
&.#{$fa-css-prefix}-pull-right { margin-left: .3em; } |
|||
} |
@ -1,20 +0,0 @@ |
|||
// Base Class Definition |
|||
// ------------------------- |
|||
|
|||
.#{$fa-css-prefix}, |
|||
.fas, |
|||
.far, |
|||
.fal, |
|||
.fab { |
|||
-moz-osx-font-smoothing: grayscale; |
|||
-webkit-font-smoothing: antialiased; |
|||
display: inline-block; |
|||
font-style: normal; |
|||
font-variant: normal; |
|||
text-rendering: auto; |
|||
line-height: 1; |
|||
} |
|||
|
|||
%fa-icon { |
|||
@include fa-icon; |
|||
} |
@ -1,6 +0,0 @@ |
|||
// Fixed Width Icons |
|||
// ------------------------- |
|||
.#{$fa-css-prefix}-fw { |
|||
text-align: center; |
|||
width: $fa-fw-width; |
|||
} |
1786
_src/desktop/scss/plugins/fontawesome5/_icons.scss
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -1,23 +0,0 @@ |
|||
// Icon Sizes |
|||
// ------------------------- |
|||
|
|||
// makes the font 33% larger relative to the icon container |
|||
.#{$fa-css-prefix}-lg { |
|||
font-size: (4em / 3); |
|||
line-height: (3em / 4); |
|||
vertical-align: -.0667em; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-xs { |
|||
font-size: .75em; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-sm { |
|||
font-size: .875em; |
|||
} |
|||
|
|||
@for $i from 1 through 10 { |
|||
.#{$fa-css-prefix}-#{$i}x { |
|||
font-size: $i * 1em; |
|||
} |
|||
} |
@ -1,18 +0,0 @@ |
|||
// List Icons |
|||
// ------------------------- |
|||
|
|||
.#{$fa-css-prefix}-ul { |
|||
list-style-type: none; |
|||
margin-left: $fa-li-width * 5/4; |
|||
padding-left: 0; |
|||
|
|||
> li { position: relative; } |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-li { |
|||
left: -$fa-li-width; |
|||
position: absolute; |
|||
text-align: center; |
|||
width: $fa-li-width; |
|||
line-height: inherit; |
|||
} |
@ -1,57 +0,0 @@ |
|||
// Mixins |
|||
// -------------------------- |
|||
|
|||
@mixin fa-icon { |
|||
-webkit-font-smoothing: antialiased; |
|||
-moz-osx-font-smoothing: grayscale; |
|||
display: inline-block; |
|||
font-style: normal; |
|||
font-variant: normal; |
|||
font-weight: normal; |
|||
line-height: 1; |
|||
vertical-align: -.125em; |
|||
} |
|||
|
|||
@mixin fa-icon-rotate($degrees, $rotation) { |
|||
-ms-filter: "progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation})"; |
|||
transform: rotate($degrees); |
|||
} |
|||
|
|||
@mixin fa-icon-flip($horiz, $vert, $rotation) { |
|||
-ms-filter: "progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation}, mirror=1)"; |
|||
transform: scale($horiz, $vert); |
|||
} |
|||
|
|||
|
|||
// Only display content to screen readers. A la Bootstrap 4. |
|||
// |
|||
// See: http://a11yproject.com/posts/how-to-hide-content/ |
|||
|
|||
@mixin sr-only { |
|||
border: 0; |
|||
clip: rect(0, 0, 0, 0); |
|||
height: 1px; |
|||
margin: -1px; |
|||
overflow: hidden; |
|||
padding: 0; |
|||
position: absolute; |
|||
width: 1px; |
|||
} |
|||
|
|||
// Use in conjunction with .sr-only to only display content when it's focused. |
|||
// |
|||
// Useful for "Skip to main content" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1 |
|||
// |
|||
// Credit: HTML5 Boilerplate |
|||
|
|||
@mixin sr-only-focusable { |
|||
&:active, |
|||
&:focus { |
|||
clip: auto; |
|||
height: auto; |
|||
margin: 0; |
|||
overflow: visible; |
|||
position: static; |
|||
width: auto; |
|||
} |
|||
} |
@ -1,5 +0,0 @@ |
|||
// Screen Readers |
|||
// ------------------------- |
|||
|
|||
.sr-only { @include sr-only; } |
|||
.sr-only-focusable { @include sr-only-focusable; } |
2062
_src/desktop/scss/plugins/fontawesome5/_shims.scss
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -1,31 +0,0 @@ |
|||
// Stacked Icons |
|||
// ------------------------- |
|||
|
|||
.#{$fa-css-prefix}-stack { |
|||
display: inline-block; |
|||
height: 2em; |
|||
line-height: 2em; |
|||
position: relative; |
|||
vertical-align: middle; |
|||
width: ($fa-fw-width*2); |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-stack-1x, |
|||
.#{$fa-css-prefix}-stack-2x { |
|||
left: 0; |
|||
position: absolute; |
|||
text-align: center; |
|||
width: 100%; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-stack-1x { |
|||
line-height: inherit; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-stack-2x { |
|||
font-size: 2em; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-inverse { |
|||
color: $fa-inverse; |
|||
} |
1800
_src/desktop/scss/plugins/fontawesome5/_variables.scss
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -1,16 +0,0 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
|||
@import 'mixins'; |
|||
@import 'core'; |
|||
@import 'larger'; |
|||
@import 'fixed-width'; |
|||
@import 'list'; |
|||
@import 'bordered-pulled'; |
|||
@import 'animated'; |
|||
@import 'rotated-flipped'; |
|||
@import 'stacked'; |
|||
@import 'icons'; |
|||
@import 'screen-reader'; |
@ -1,22 +0,0 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
|||
|
|||
@font-face { |
|||
font-family: 'Font Awesome 5 Pro'; |
|||
font-style: normal; |
|||
font-weight: 300; |
|||
src: url('#{$fa-font-path}/fa-light-300.eot'); |
|||
src: url('#{$fa-font-path}/fa-light-300.eot?#iefix') format('embedded-opentype'), |
|||
url('#{$fa-font-path}/fa-light-300.woff2') format('woff2'), |
|||
url('#{$fa-font-path}/fa-light-300.woff') format('woff'), |
|||
url('#{$fa-font-path}/fa-light-300.ttf') format('truetype'), |
|||
url('#{$fa-font-path}/fa-light-300.svg#fontawesome') format('svg'); |
|||
} |
|||
|
|||
.fal { |
|||
font-family: 'Font Awesome 5 Pro'; |
|||
font-weight: 300; |
|||
} |
@ -1,22 +0,0 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
|||
|
|||
@font-face { |
|||
font-family: 'Font Awesome 5 Pro'; |
|||
font-style: normal; |
|||
font-weight: 400; |
|||
src: url('#{$fa-font-path}/fa-regular-400.eot'); |
|||
src: url('#{$fa-font-path}/fa-regular-400.eot?#iefix') format('embedded-opentype'), |
|||
url('#{$fa-font-path}/fa-regular-400.woff2') format('woff2'), |
|||
url('#{$fa-font-path}/fa-regular-400.woff') format('woff'), |
|||
url('#{$fa-font-path}/fa-regular-400.ttf') format('truetype'), |
|||
url('#{$fa-font-path}/fa-regular-400.svg#fontawesome') format('svg'); |
|||
} |
|||
|
|||
.far { |
|||
font-family: 'Font Awesome 5 Pro'; |
|||
font-weight: 400; |
|||
} |
@ -1,6 +0,0 @@ |
|||
/*! |
|||
* Font Awesome Pro 5.5.0 by @fontawesome - https://fontawesome.com |
|||
* License - https://fontawesome.com/license (Commercial License) |
|||
*/ |
|||
@import 'variables'; |
|||
@import 'shims'; |
@ -1,5 +0,0 @@ |
|||
// 기본 픽셀 사이즈를 rem 단위 사이즈로 변환 |
|||
@function REM($pxSize:16px){ |
|||
$remSize : $pxSize / $font-size-base !global; |
|||
@return #{$remSize}rem; |
|||
} |
@ -1,56 +0,0 @@ |
|||
// Clear FIX |
|||
@mixin clear-fix() { |
|||
display:block; |
|||
clear:both; |
|||
content:""; |
|||
} |
|||
|
|||
// Button Default Style |
|||
@mixin button-default() { |
|||
display: inline-block; |
|||
margin:0; |
|||
font-weight: normal; |
|||
text-align: center; |
|||
white-space: nowrap; |
|||
user-select: none; |
|||
text-decoration: none; |
|||
outline:0; |
|||
vertical-align:middle; |
|||
|
|||
&:disabled, |
|||
&.disabled { |
|||
opacity:0.65; |
|||
} |
|||
|
|||
&:not([disabled]):not(.disabled) { |
|||
cursor: pointer; |
|||
} |
|||
} |
|||
|
|||
// background Image |
|||
@mixin background-image( $image_url, $bg_color:transparent, $background-repeat:no-repat, $background-position-x:center, $background-position-y:center ) |
|||
{ |
|||
background-color:$bg_color; |
|||
background-image:url($image_url); |
|||
background-repeat: $background-repeat; |
|||
background-position-x:$background-position-x; |
|||
background-position-y:$background-position-y; |
|||
} |
|||
|
|||
// Global Transition |
|||
@mixin transition($second:.3s, $target:all, $animation:$default-animation) |
|||
{ |
|||
-webkit-transition: $target $second $animation; |
|||
-moz-transition: $target $second $animation; |
|||
-ms-transition: $target $second $animation; |
|||
-o-transition: $target $second $animation; |
|||
transition: $target $second $animation; |
|||
} |
|||
|
|||
// Display flex & Prefix |
|||
@mixin display-flex() |
|||
{ |
|||
-webkit-display:flex; |
|||
display:-ms-flex; |
|||
display:flex; |
|||
} |
@ -1,33 +1,3 @@ |
|||
/*************************************************************************************** |
|||
* 유틸리티 |
|||
****************************************************************************************/ |
|||
.sr-only { |
|||
position: absolute; |
|||
width: 1px; |
|||
height: 1px; |
|||
padding: 0; |
|||
overflow: hidden; |
|||
clip: rect(0, 0, 0, 0); |
|||
white-space: nowrap; |
|||
border: 0; |
|||
|
|||
&.sr-only-focusable { |
|||
&:active, |
|||
&:focus { |
|||
position: static; |
|||
width: auto; |
|||
height: auto; |
|||
overflow: visible; |
|||
clip: auto; |
|||
white-space: normal; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.clearfix { |
|||
&, |
|||
&:before, |
|||
&:after { |
|||
@include clear-fix(); |
|||
} |
|||
} |
@ -1,220 +0,0 @@ |
|||
.toast-title { |
|||
font-weight: bold; |
|||
} |
|||
.toast-message { |
|||
-ms-word-wrap: break-word; |
|||
word-wrap: break-word; |
|||
a, |
|||
label { |
|||
color: #ffffff; |
|||
} |
|||
a { |
|||
&:hover { |
|||
color: #cccccc; |
|||
text-decoration: none; |
|||
} |
|||
} |
|||
} |
|||
.toast-close-button { |
|||
position: relative; |
|||
right: -0.3em; |
|||
top: -0.3em; |
|||
float: right; |
|||
font-size: 20px; |
|||
font-weight: bold; |
|||
color: #ffffff; |
|||
-webkit-text-shadow: 0 1px 0 #ffffff; |
|||
text-shadow: 0 1px 0 #ffffff; |
|||
opacity: 0.8; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); |
|||
filter: alpha(opacity=80); |
|||
|
|||
&:hover, |
|||
&:focus { |
|||
color: #000000; |
|||
text-decoration: none; |
|||
cursor: pointer; |
|||
opacity: 0.4; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); |
|||
filter: alpha(opacity=40); |
|||
} |
|||
} |
|||
|
|||
button.toast-close-button { |
|||
|
|||
padding: 0; |
|||
cursor: pointer; |
|||
background: transparent; |
|||
border: 0; |
|||
-webkit-appearance: none; |
|||
} |
|||
|
|||
#toast-container { |
|||
position: fixed; |
|||
z-index: 999999; |
|||
pointer-events: none; |
|||
|
|||
* { |
|||
-moz-box-sizing: border-box; |
|||
-webkit-box-sizing: border-box; |
|||
box-sizing: border-box; |
|||
} |
|||
|
|||
> div { |
|||
position: relative; |
|||
pointer-events: auto; |
|||
overflow: hidden; |
|||
margin: 0 0 6px; |
|||
padding: 15px 15px 15px 50px; |
|||
width: 300px; |
|||
-moz-border-radius: 3px 3px 3px 3px; |
|||
-webkit-border-radius: 3px 3px 3px 3px; |
|||
border-radius: 3px 3px 3px 3px; |
|||
background-position: 15px center; |
|||
background-repeat: no-repeat; |
|||
-moz-box-shadow: 0 0 12px #999999; |
|||
-webkit-box-shadow: 0 0 12px #999999; |
|||
box-shadow: 0 0 12px #999999; |
|||
color: #ffffff; |
|||
opacity: 0.8; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); |
|||
filter: alpha(opacity=80); |
|||
} |
|||
|
|||
> :hover { |
|||
-moz-box-shadow: 0 0 12px #000000; |
|||
-webkit-box-shadow: 0 0 12px #000000; |
|||
box-shadow: 0 0 12px #000000; |
|||
opacity: 1; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); |
|||
filter: alpha(opacity=100); |
|||
cursor: pointer; |
|||
} |
|||
|
|||
> .toast-info { |
|||
background-image: url("") !important; |
|||
} |
|||
|
|||
> .toast-error { |
|||
background-image: url("") !important; |
|||
} |
|||
|
|||
> .toast-success { |
|||
background-image: url("") !important; |
|||
} |
|||
|
|||
> .toast-warning { |
|||
background-image: url("") !important; |
|||
} |
|||
|
|||
&.toast-top-center { |
|||
top: 0; |
|||
right: 0; |
|||
width: 100%; |
|||
} |
|||
|
|||
&.toast-bottom-center { |
|||
bottom: 0; |
|||
right: 0; |
|||
width: 100%; |
|||
} |
|||
|
|||
&.toast-top-full-width { |
|||
top: 0; |
|||
right: 0; |
|||
width: 100%; |
|||
} |
|||
|
|||
&.toast-bottom-full-width { |
|||
bottom: 0; |
|||
right: 0; |
|||
width: 100%; |
|||
} |
|||
|
|||
&.toast-top-left { |
|||
top: 12px; |
|||
left: 12px; |
|||
} |
|||
|
|||
&.toast-top-right { |
|||
top: 12px; |
|||
right: 12px; |
|||
} |
|||
|
|||
&.toast-bottom-right { |
|||
right: 12px; |
|||
bottom: 12px; |
|||
} |
|||
|
|||
&.toast-bottom-left { |
|||
bottom: 12px; |
|||
left: 12px; |
|||
} |
|||
|
|||
&.toast-top-center > div, |
|||
&.toast-bottom-center > div { |
|||
width: 300px; |
|||
margin-left: auto; |
|||
margin-right: auto; |
|||
} |
|||
|
|||
&.toast-top-full-width > div, |
|||
&.toast-bottom-full-width > div { |
|||
width: 96%; |
|||
margin-left: auto; |
|||
margin-right: auto; |
|||
} |
|||
} |
|||
|
|||
.toast { |
|||
background-color: #030303; |
|||
} |
|||
.toast-success { |
|||
background-color: #51a351; |
|||
} |
|||
.toast-error { |
|||
background-color: #bd362f; |
|||
} |
|||
.toast-info { |
|||
background-color: #2f96b4; |
|||
} |
|||
.toast-warning { |
|||
background-color: #f89406; |
|||
} |
|||
.toast-progress { |
|||
position: absolute; |
|||
left: 0; |
|||
bottom: 0; |
|||
height: 4px; |
|||
background-color: #000000; |
|||
opacity: 0.4; |
|||
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); |
|||
filter: alpha(opacity=40); |
|||
} |
|||
/*Responsive Design*/ |
|||
@media all and (max-width: 240px) { |
|||
#toast-container > div { |
|||
padding: 8px 8px 8px 50px; |
|||
width: 11em; |
|||
} |
|||
#toast-container .toast-close-button { |
|||
right: -0.2em; |
|||
top: -0.2em; |
|||
} |
|||
} |
|||
@media all and (min-width: 241px) and (max-width: 480px) { |
|||
#toast-container > div { |
|||
padding: 8px 8px 8px 50px; |
|||
width: 18em; |
|||
} |
|||
#toast-container .toast-close-button { |
|||
right: -0.2em; |
|||
top: -0.2em; |
|||
} |
|||
} |
|||
@media all and (min-width: 481px) and (max-width: 768px) { |
|||
#toast-container > div { |
|||
padding: 15px 15px 15px 50px; |
|||
width: 25em; |
|||
} |
|||
} |
@ -1,20 +0,0 @@ |
|||
// Animated Icons |
|||
// -------------------------- |
|||
|
|||
.#{$fa-css-prefix}-spin { |
|||
animation: fa-spin 2s infinite linear; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-pulse { |
|||
animation: fa-spin 1s infinite steps(8); |
|||
} |
|||
|
|||
@keyframes fa-spin { |
|||
0% { |
|||
transform: rotate(0deg); |
|||
} |
|||
|
|||
100% { |
|||
transform: rotate(360deg); |
|||
} |
|||
} |
@ -1,20 +0,0 @@ |
|||
// Bordered & Pulled |
|||
// ------------------------- |
|||
|
|||
.#{$fa-css-prefix}-border { |
|||
border: solid .08em $fa-border-color; |
|||
border-radius: .1em; |
|||
padding: .2em .25em .15em; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-pull-left { float: left; } |
|||
.#{$fa-css-prefix}-pull-right { float: right; } |
|||
|
|||
.#{$fa-css-prefix}, |
|||
.fas, |
|||
.far, |
|||
.fal, |
|||
.fab { |
|||
&.#{$fa-css-prefix}-pull-left { margin-right: .3em; } |
|||
&.#{$fa-css-prefix}-pull-right { margin-left: .3em; } |
|||
} |
@ -1,20 +0,0 @@ |
|||
// Base Class Definition |
|||
// ------------------------- |
|||
|
|||
.#{$fa-css-prefix}, |
|||
.fas, |
|||
.far, |
|||
.fal, |
|||
.fab { |
|||
-moz-osx-font-smoothing: grayscale; |
|||
-webkit-font-smoothing: antialiased; |
|||
display: inline-block; |
|||
font-style: normal; |
|||
font-variant: normal; |
|||
text-rendering: auto; |
|||
line-height: 1; |
|||
} |
|||
|
|||
%fa-icon { |
|||
@include fa-icon; |
|||
} |
@ -1,6 +0,0 @@ |
|||
// Fixed Width Icons |
|||
// ------------------------- |
|||
.#{$fa-css-prefix}-fw { |
|||
text-align: center; |
|||
width: $fa-fw-width; |
|||
} |
1786
_src/mobile/scss/plugins/fontawesome5/_icons.scss
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -1,23 +0,0 @@ |
|||
// Icon Sizes |
|||
// ------------------------- |
|||
|
|||
// makes the font 33% larger relative to the icon container |
|||
.#{$fa-css-prefix}-lg { |
|||
font-size: (4em / 3); |
|||
line-height: (3em / 4); |
|||
vertical-align: -.0667em; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-xs { |
|||
font-size: .75em; |
|||
} |
|||
|
|||
.#{$fa-css-prefix}-sm { |
|||
font-size: .875em; |
|||
} |
|||
|
|||
@for $i from 1 through 10 { |
|||
.#{$fa-css-prefix}-#{$i}x { |
|||
font-size: $i * 1em; |
|||
} |
|||
} |
Some files were not shown because too many files changed in this diff
Write
Preview
Loading…
Cancel
Save
Reference in new issue