├── .gitignore ├── GruntFile.js ├── LICENSE ├── README.md ├── bower.json ├── img ├── screen1.png └── screen2.png ├── index.html ├── jquery.businessHours.css ├── jquery.businessHours.js ├── jquery.businessHours.min.js ├── libs └── page.css └── package.json /.gitignore: -------------------------------------------------------------------------------- 1 | .settings 2 | .project 3 | *.bak 4 | *.idea 5 | *.swp 6 | *~ 7 | *.orig 8 | build 9 | *.iml 10 | .coverage 11 | 12 | node_modules 13 | bower_components 14 | -------------------------------------------------------------------------------- /GruntFile.js: -------------------------------------------------------------------------------- 1 | module.exports = function(grunt) { 2 | grunt.initConfig({ 3 | pkg: grunt.file.readJSON('package.json'), 4 | meta: { 5 | banner: '/*!\n' + 6 | ' * <%= pkg.title %> v<%= pkg.version %> - <%= pkg.description %>\n' + 7 | ' * Copyright (c) <%= grunt.template.today("yyyy") %> <%= pkg.author.name %> - <%= pkg.homepage %>\n' + 8 | ' * License: <%= pkg.license %>\n' + 9 | ' */\n\n' 10 | }, 11 | uglify: { 12 | options: { 13 | banner: '<%= meta.banner %>', 14 | report: 'gzip' 15 | }, 16 | dist: { 17 | files: { 18 | 'jquery.businessHours.min.js': ['jquery.businessHours.js'] 19 | } 20 | } 21 | } 22 | }); 23 | grunt.loadNpmTasks('grunt-contrib-uglify'); 24 | grunt.registerTask('default', ['uglify']); 25 | }; -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Apache License 2 | Version 2.0, January 2004 3 | http://www.apache.org/licenses/ 4 | 5 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 6 | 7 | 1. Definitions. 8 | 9 | "License" shall mean the terms and conditions for use, reproduction, 10 | and distribution as defined by Sections 1 through 9 of this document. 11 | 12 | "Licensor" shall mean the copyright owner or entity authorized by 13 | the copyright owner that is granting the License. 14 | 15 | "Legal Entity" shall mean the union of the acting entity and all 16 | other entities that control, are controlled by, or are under common 17 | control with that entity. For the purposes of this definition, 18 | "control" means (i) the power, direct or indirect, to cause the 19 | direction or management of such entity, whether by contract or 20 | otherwise, or (ii) ownership of fifty percent (50%) or more of the 21 | outstanding shares, or (iii) beneficial ownership of such entity. 22 | 23 | "You" (or "Your") shall mean an individual or Legal Entity 24 | exercising permissions granted by this License. 25 | 26 | "Source" form shall mean the preferred form for making modifications, 27 | including but not limited to software source code, documentation 28 | source, and configuration files. 29 | 30 | "Object" form shall mean any form resulting from mechanical 31 | transformation or translation of a Source form, including but 32 | not limited to compiled object code, generated documentation, 33 | and conversions to other media types. 34 | 35 | "Work" shall mean the work of authorship, whether in Source or 36 | Object form, made available under the License, as indicated by a 37 | copyright notice that is included in or attached to the work 38 | (an example is provided in the Appendix below). 39 | 40 | "Derivative Works" shall mean any work, whether in Source or Object 41 | form, that is based on (or derived from) the Work and for which the 42 | editorial revisions, annotations, elaborations, or other modifications 43 | represent, as a whole, an original work of authorship. For the purposes 44 | of this License, Derivative Works shall not include works that remain 45 | separable from, or merely link (or bind by name) to the interfaces of, 46 | the Work and Derivative Works thereof. 47 | 48 | "Contribution" shall mean any work of authorship, including 49 | the original version of the Work and any modifications or additions 50 | to that Work or Derivative Works thereof, that is intentionally 51 | submitted to Licensor for inclusion in the Work by the copyright owner 52 | or by an individual or Legal Entity authorized to submit on behalf of 53 | the copyright owner. For the purposes of this definition, "submitted" 54 | means any form of electronic, verbal, or written communication sent 55 | to the Licensor or its representatives, including but not limited to 56 | communication on electronic mailing lists, source code control systems, 57 | and issue tracking systems that are managed by, or on behalf of, the 58 | Licensor for the purpose of discussing and improving the Work, but 59 | excluding communication that is conspicuously marked or otherwise 60 | designated in writing by the copyright owner as "Not a Contribution." 61 | 62 | "Contributor" shall mean Licensor and any individual or Legal Entity 63 | on behalf of whom a Contribution has been received by Licensor and 64 | subsequently incorporated within the Work. 65 | 66 | 2. Grant of Copyright License. Subject to the terms and conditions of 67 | this License, each Contributor hereby grants to You a perpetual, 68 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 69 | copyright license to reproduce, prepare Derivative Works of, 70 | publicly display, publicly perform, sublicense, and distribute the 71 | Work and such Derivative Works in Source or Object form. 72 | 73 | 3. Grant of Patent License. Subject to the terms and conditions of 74 | this License, each Contributor hereby grants to You a perpetual, 75 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 76 | (except as stated in this section) patent license to make, have made, 77 | use, offer to sell, sell, import, and otherwise transfer the Work, 78 | where such license applies only to those patent claims licensable 79 | by such Contributor that are necessarily infringed by their 80 | Contribution(s) alone or by combination of their Contribution(s) 81 | with the Work to which such Contribution(s) was submitted. If You 82 | institute patent litigation against any entity (including a 83 | cross-claim or counterclaim in a lawsuit) alleging that the Work 84 | or a Contribution incorporated within the Work constitutes direct 85 | or contributory patent infringement, then any patent licenses 86 | granted to You under this License for that Work shall terminate 87 | as of the date such litigation is filed. 88 | 89 | 4. Redistribution. You may reproduce and distribute copies of the 90 | Work or Derivative Works thereof in any medium, with or without 91 | modifications, and in Source or Object form, provided that You 92 | meet the following conditions: 93 | 94 | (a) You must give any other recipients of the Work or 95 | Derivative Works a copy of this License; and 96 | 97 | (b) You must cause any modified files to carry prominent notices 98 | stating that You changed the files; and 99 | 100 | (c) You must retain, in the Source form of any Derivative Works 101 | that You distribute, all copyright, patent, trademark, and 102 | attribution notices from the Source form of the Work, 103 | excluding those notices that do not pertain to any part of 104 | the Derivative Works; and 105 | 106 | (d) If the Work includes a "NOTICE" text file as part of its 107 | distribution, then any Derivative Works that You distribute must 108 | include a readable copy of the attribution notices contained 109 | within such NOTICE file, excluding those notices that do not 110 | pertain to any part of the Derivative Works, in at least one 111 | of the following places: within a NOTICE text file distributed 112 | as part of the Derivative Works; within the Source form or 113 | documentation, if provided along with the Derivative Works; or, 114 | within a display generated by the Derivative Works, if and 115 | wherever such third-party notices normally appear. The contents 116 | of the NOTICE file are for informational purposes only and 117 | do not modify the License. You may add Your own attribution 118 | notices within Derivative Works that You distribute, alongside 119 | or as an addendum to the NOTICE text from the Work, provided 120 | that such additional attribution notices cannot be construed 121 | as modifying the License. 122 | 123 | You may add Your own copyright statement to Your modifications and 124 | may provide additional or different license terms and conditions 125 | for use, reproduction, or distribution of Your modifications, or 126 | for any such Derivative Works as a whole, provided Your use, 127 | reproduction, and distribution of the Work otherwise complies with 128 | the conditions stated in this License. 129 | 130 | 5. Submission of Contributions. Unless You explicitly state otherwise, 131 | any Contribution intentionally submitted for inclusion in the Work 132 | by You to the Licensor shall be under the terms and conditions of 133 | this License, without any additional terms or conditions. 134 | Notwithstanding the above, nothing herein shall supersede or modify 135 | the terms of any separate license agreement you may have executed 136 | with Licensor regarding such Contributions. 137 | 138 | 6. Trademarks. This License does not grant permission to use the trade 139 | names, trademarks, service marks, or product names of the Licensor, 140 | except as required for reasonable and customary use in describing the 141 | origin of the Work and reproducing the content of the NOTICE file. 142 | 143 | 7. Disclaimer of Warranty. Unless required by applicable law or 144 | agreed to in writing, Licensor provides the Work (and each 145 | Contributor provides its Contributions) on an "AS IS" BASIS, 146 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 147 | implied, including, without limitation, any warranties or conditions 148 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A 149 | PARTICULAR PURPOSE. You are solely responsible for determining the 150 | appropriateness of using or redistributing the Work and assume any 151 | risks associated with Your exercise of permissions under this License. 152 | 153 | 8. Limitation of Liability. In no event and under no legal theory, 154 | whether in tort (including negligence), contract, or otherwise, 155 | unless required by applicable law (such as deliberate and grossly 156 | negligent acts) or agreed to in writing, shall any Contributor be 157 | liable to You for damages, including any direct, indirect, special, 158 | incidental, or consequential damages of any character arising as a 159 | result of this License or out of the use or inability to use the 160 | Work (including but not limited to damages for loss of goodwill, 161 | work stoppage, computer failure or malfunction, or any and all 162 | other commercial damages or losses), even if such Contributor 163 | has been advised of the possibility of such damages. 164 | 165 | 9. Accepting Warranty or Additional Liability. While redistributing 166 | the Work or Derivative Works thereof, You may choose to offer, 167 | and charge a fee for, acceptance of support, warranty, indemnity, 168 | or other liability obligations and/or rights consistent with this 169 | License. However, in accepting such obligations, You may act only 170 | on Your own behalf and on Your sole responsibility, not on behalf 171 | of any other Contributor, and only if You agree to indemnify, 172 | defend, and hold each Contributor harmless for any liability 173 | incurred by, or claims asserted against, such Contributor by reason 174 | of your accepting any such warranty or additional liability. 175 | 176 | END OF TERMS AND CONDITIONS 177 | 178 | APPENDIX: How to apply the Apache License to your work. 179 | 180 | To apply the Apache License to your work, attach the following 181 | boilerplate notice, with the fields enclosed by brackets "{}" 182 | replaced with your own identifying information. (Don't include 183 | the brackets!) The text should be enclosed in the appropriate 184 | comment syntax for the file format. We also recommend that a 185 | file or class name and description of purpose be included on the 186 | same "printed page" as the copyright notice for easier 187 | identification within third-party archives. 188 | 189 | Copyright {yyyy} {name of copyright owner} 190 | 191 | Licensed under the Apache License, Version 2.0 (the "License"); 192 | you may not use this file except in compliance with the License. 193 | You may obtain a copy of the License at 194 | 195 | http://www.apache.org/licenses/LICENSE-2.0 196 | 197 | Unless required by applicable law or agreed to in writing, software 198 | distributed under the License is distributed on an "AS IS" BASIS, 199 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 200 | See the License for the specific language governing permissions and 201 | limitations under the License. 202 | 203 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Business Hours plugin for jQuery 2 | 3 | [business hours screenshot](http://gendelf.github.io/jquery.businessHours/) 4 | 5 | [Demo](http://gendelf.github.io/jquery.businessHours/) 6 | 7 | ## Requirements 8 | 9 | * [jQuery](http://jquery.com/) (>= 1.7) 10 | * [jQuery timepicker](https://github.com/jonthornton/jquery-timepicker) (1.4.13) 11 | 12 | ## Bower 13 | 14 | ``` 15 | bower install -S jquery.business-hours 16 | ``` 17 | 18 | ## Usage: 19 | 20 | ```JavaScript 21 | 22 | /* initial data */ 23 | var operationTime = [ 24 | {"isActive":false,"timeFrom":null,"timeTill":null}, 25 | {"isActive":false,"timeFrom":null,"timeTill":null}, 26 | {"isActive":false,"timeFrom":null,"timeTill":null}, 27 | {"isActive":true,"timeFrom":"7:15","timeTill":"18:00"}, 28 | {"isActive":true,"timeFrom":"9:00","timeTill":"18:00"}, 29 | {"isActive":false,"timeFrom":null,"timeTill":null}, 30 | {"isActive":false,"timeFrom":null,"timeTill":null} 31 | ]; 32 | 33 | $(selector).businessHours({ 34 | operationTime: operationTime, // list of JSON objects 35 | postInit:function() { // optional 36 | // post-init handler 37 | }, 38 | checkedColorClass: "workingBusinssDay", // optional 39 | uncheckedColorClass: "dayOff", // optional 40 | dayTmpl: " ... template content ..." // optional 41 | }); 42 | ``` 43 | 44 | **Sponsored by**: [MVP engine](http://mvpngn.com) 45 | -------------------------------------------------------------------------------- /bower.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "jquery.business-hours", 3 | "main": [ "./jquery.businessHours.min.js", "./jquery.businessHours.js", "./jquery.businessHours.css" ], 4 | "version": "1.0.1", 5 | "homepage": "http://gendelf.github.io/jquery.businessHours/", 6 | "author": { 7 | "name": "Alex Padalka", 8 | "web": "https://github.com/gEndelf" 9 | }, 10 | "description": "jQuery plugin allows you to easy show & manage business hours", 11 | "keywords": ["jQuery", "plugin", "business hours"], 12 | "dependencies": { 13 | "jquery": ">= 1.7", 14 | "jt.timepicker": "~1.4.13" 15 | }, 16 | "license": "Apache License", 17 | "ignore": [ 18 | "**/.*", 19 | "node_modules", 20 | "bower_components", 21 | "test", 22 | "tests" 23 | ] 24 | } 25 | -------------------------------------------------------------------------------- /img/screen1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/gEndelf/jquery.businessHours/0e1a10abacd878f6a2fa42da84bbb3ecb4b68f14/img/screen1.png -------------------------------------------------------------------------------- /img/screen2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/gEndelf/jquery.businessHours/0e1a10abacd878f6a2fa42da84bbb3ecb4b68f14/img/screen2.png -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Business Hours plugin for jQuery – Demos and Documentation 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 32 | 33 | 34 | 35 |
36 |
37 | Fork me on GitHub 38 |
39 |
40 |
41 |

Plugin jquery.businessHours

42 |

43 | This plugin can be useful to show and manage business working days & hours. 44 |

45 |
46 |

By default

47 |
48 |

 49 |                 var businessHoursManager = $("#businessHoursContainer").businessHours();
 50 | 
 51 |                 $("#btnSerialize").click(function() {
 52 |                     // use: businessHoursManager.serialize() to get serialized business hours in JSON
 53 |                     $("textarea#businessHoursOutput").val(JSON.stringify(businessHoursManager.serialize()));
 54 |                 });
 55 |             
56 |
57 | 58 |
59 |
 
60 |
61 | 62 | 63 |
64 |
65 |
66 |

Init widget from JSON object

67 |

68 |
69 |

 70 |                 $("#businessHoursWidget").businessHours({
 71 |                     operationTime: /* array of JSON objects */
 72 |                 });
 73 |             
74 |
75 | 76 |
77 |
 
78 |
79 | 80 | 89 |
90 |
91 |
92 |

Template customization

93 | 97 |
98 |

 99 |             $("#businessHoursContainer2").businessHours({
100 |                 inputDisabled: true,
101 |                 checkedColorClass: 'workingBusinssDay',
102 |                 uncheckedColorClass: 'dayOff',
103 |                 dayTmpl: '
' + 104 | '
' + 105 | '
' 106 | }); 107 |
108 |
109 |
110 |
111 |
112 |
113 |

Using bootstrap, font-awesome and timepicker

114 |

115 | Ok, let's try to do more attractive widget by using font-awesome icons, 116 | bootstrap stylesheets and 117 | jquery timepicker plugin. 118 |

119 |
120 |

121 |                 // don't forget to include required libs & styles
122 |                 // http://netdna.bootstrapcdn.com/bootstrap/3.0.3/js/bootstrap.min.js
123 |                 // http://netdna.bootstrapcdn.com/bootstrap/3.0.3/css/bootstrap.min.css"
124 |                 // http://netdna.bootstrapcdn.com/font-awesome/3.1.1/css/font-awesome.css
125 | 
126 |                 // libs/jquery-timepicker/jquery.timepicker.min.js
127 |                 // libs/jquery-timepicker/jquery.timepicker.css
128 | 
129 |                 $("#businessHoursContainer3").businessHours({
130 |                     postInit:function(){
131 |                         $('.operationTimeFrom, .operationTimeTill').timepicker({
132 |                             'timeFormat': 'H:i',
133 |                             'step': 15
134 |                             });
135 |                     },
136 |                     dayTmpl:'
' + 137 | '
' + 138 | '
' + 139 | '
' + 140 | '
' + 141 | '
' + 142 | '
' 143 | }); 144 |
145 |
146 |
147 |
148 |
149 |
150 | 155 | 202 | 203 | 204 | -------------------------------------------------------------------------------- /jquery.businessHours.css: -------------------------------------------------------------------------------- 1 | .clean { 2 | clear: both; 3 | } 4 | 5 | .dayContainer { 6 | float: left; 7 | line-height: 20px; 8 | margin-right: 8px; 9 | width: 65px; 10 | font-size: 11px; 11 | font-weight: bold; 12 | } 13 | 14 | .colorBox { 15 | cursor: pointer; 16 | height: 45px; 17 | border: 2px solid #888; 18 | -webkit-border-radius: 4px; 19 | -moz-border-radius: 4px; 20 | border-radius: 4px; 21 | } 22 | 23 | .colorBox.WorkingDayState { 24 | border: 2px solid #4E8059; 25 | background-color: #8ade8f; 26 | } 27 | 28 | .colorBox.RestDayState { 29 | border: 2px solid #7a1c44; 30 | background-color: #de5962; 31 | } 32 | 33 | .operationTime .mini-time { 34 | width: 40px; 35 | padding: 3px; 36 | font-size: 12px; 37 | font-weight: normal; 38 | } 39 | 40 | .dayContainer .add-on { 41 | padding: 4px 2px; 42 | } 43 | 44 | .colorBoxLabel { 45 | clear: both; 46 | font-size: 12px; 47 | font-weight: bold; 48 | } 49 | 50 | .invisible { 51 | visibility: hidden; 52 | } 53 | 54 | .operationTime { 55 | margin-top: 5px; 56 | } -------------------------------------------------------------------------------- /jquery.businessHours.js: -------------------------------------------------------------------------------- 1 | /** 2 | jquery.businessHours v1.0.1 3 | https://github.com/gEndelf/jquery.businessHours 4 | 5 | requirements: 6 | - jQuery 1.7+ 7 | 8 | recommended time-picker: 9 | - jquery-timepicker 1.2.7+ // https://github.com/jonthornton/jquery-timepicker 10 | **/ 11 | 12 | (function($) { 13 | $.fn.businessHours = function(opts) { 14 | var defaults = { 15 | preInit: function() { 16 | }, 17 | postInit: function() { 18 | }, 19 | inputDisabled: false, 20 | checkedColorClass: "WorkingDayState", 21 | uncheckedColorClass: "RestDayState", 22 | colorBoxValContainerClass: "colorBoxContainer", 23 | weekdays: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], 24 | operationTime: [ 25 | {}, 26 | {}, 27 | {}, 28 | {}, 29 | {}, 30 | {isActive: false}, 31 | {isActive: false} 32 | ], 33 | defaultOperationTimeFrom: '9:00', 34 | defaultOperationTimeTill: '18:00', 35 | defaultActive: true, 36 | //labelOn: "Working day", 37 | //labelOff: "Day off", 38 | //labelTimeFrom: "from:", 39 | //labelTimeTill: "till:", 40 | containerTmpl: '
', 41 | dayTmpl: '
' + 42 | '
' + 43 | '
' + 44 | '
' + 45 | '
' + 46 | '
' + 47 | '
' 48 | }; 49 | 50 | var container = $(this); 51 | 52 | function initTimeBox(timeBoxSelector, time, isInputDisabled) { 53 | timeBoxSelector.val(time); 54 | 55 | if(isInputDisabled) { 56 | timeBoxSelector.prop('readonly', true); 57 | } 58 | } 59 | 60 | var methods = { 61 | getValueOrDefault: function(val, defaultVal) { 62 | return (jQuery.type(val) === "undefined" || val == null) ? defaultVal : val; 63 | }, 64 | init: function(opts) { 65 | this.options = $.extend(defaults, opts); 66 | container.html(""); 67 | 68 | if(typeof this.options.preInit === "function") { 69 | this.options.preInit(); 70 | } 71 | 72 | this.initView(this.options); 73 | 74 | if(typeof this.options.postInit === "function") { 75 | //$('.operationTimeFrom, .operationTimeTill').timepicker(options.timepickerOptions); 76 | this.options.postInit(); 77 | } 78 | 79 | return { 80 | serialize: function() { 81 | var data = []; 82 | 83 | container.find(".operationState").each(function(num, item) { 84 | var isWorkingDay = $(item).prop("checked"); 85 | var dayContainer = $(item).parents(".dayContainer"); 86 | 87 | data.push({ 88 | isActive: isWorkingDay, 89 | timeFrom: isWorkingDay ? dayContainer.find("[name='startTime']").val() : null, 90 | timeTill: isWorkingDay ? dayContainer.find("[name='endTime']").val() : null 91 | }); 92 | }); 93 | 94 | return data; 95 | } 96 | }; 97 | }, 98 | initView: function(options) { 99 | var stateClasses = [options.checkedColorClass, options.uncheckedColorClass]; 100 | var subContainer = container.append($(options.containerTmpl)); 101 | var $this = this; 102 | 103 | for(var i = 0; i < options.weekdays.length; i++) { 104 | subContainer.append(options.dayTmpl); 105 | } 106 | 107 | $.each(options.weekdays, function(pos, weekday) { 108 | // populate form 109 | var day = options.operationTime[pos]; 110 | var operationDayNode = container.find(".dayContainer").eq(pos); 111 | operationDayNode.find('.weekday').html(weekday); 112 | 113 | var isWorkingDay = $this.getValueOrDefault(day.isActive, options.defaultActive); 114 | operationDayNode.find('.operationState').prop('checked', isWorkingDay); 115 | 116 | var timeFrom = $this.getValueOrDefault(day.timeFrom, options.defaultOperationTimeFrom); 117 | initTimeBox(operationDayNode.find('[name="startTime"]'), timeFrom, options.inputDisabled); 118 | 119 | var endTime = $this.getValueOrDefault(day.timeTill, options.defaultOperationTimeTill); 120 | initTimeBox(operationDayNode.find('[name="endTime"]'), endTime, options.inputDisabled); 121 | }); 122 | 123 | container.find(".operationState").change(function() { 124 | var checkbox = $(this); 125 | var boxClass = options.checkedColorClass; 126 | var timeControlDisabled = false; 127 | 128 | if(!checkbox.prop("checked")) { 129 | // disabled 130 | boxClass = options.uncheckedColorClass; 131 | timeControlDisabled = true; 132 | } 133 | 134 | checkbox.parents(".colorBox").removeClass(stateClasses.join(' ')).addClass(boxClass); 135 | checkbox.parents(".dayContainer").find(".operationTime").toggle(!timeControlDisabled); 136 | }).trigger("change"); 137 | 138 | if(!options.inputDisabled) { 139 | container.find(".colorBox").on("click", function() { 140 | var checkbox = $(this).find(".operationState"); 141 | checkbox.prop("checked", !checkbox.prop('checked')).trigger("change"); 142 | }); 143 | } 144 | } 145 | }; 146 | 147 | return methods.init(opts); 148 | }; 149 | })(jQuery); 150 | -------------------------------------------------------------------------------- /jquery.businessHours.min.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * jquery.businessHours v1.0.1 - jQuery plugin allows you to easy show & manage business hours 3 | * Copyright (c) 2015 Alex Padalka - http://gendelf.github.io/jquery.businessHours/ 4 | * License: APACHE 5 | */ 6 | 7 | !function(a){a.fn.businessHours=function(b){function c(a,b,c){a.val(b),c&&a.prop("readonly",!0)}var d={preInit:function(){},postInit:function(){},inputDisabled:!1,checkedColorClass:"WorkingDayState",uncheckedColorClass:"RestDayState",colorBoxValContainerClass:"colorBoxContainer",weekdays:["Mon","Tue","Wed","Thu","Fri","Sat","Sun"],operationTime:[{},{},{},{},{},{isActive:!1},{isActive:!1}],defaultOperationTimeFrom:"9:00",defaultOperationTimeTill:"18:00",defaultActive:!0,containerTmpl:'
',dayTmpl:'
'},e=a(this),f={getValueOrDefault:function(a,b){return"undefined"===jQuery.type(a)||null==a?b:a},init:function(b){return this.options=a.extend(d,b),e.html(""),"function"==typeof this.options.preInit&&this.options.preInit(),this.initView(this.options),"function"==typeof this.options.postInit&&this.options.postInit(),{serialize:function(){var b=[];return e.find(".operationState").each(function(c,d){var e=a(d).prop("checked"),f=a(d).parents(".dayContainer");b.push({isActive:e,timeFrom:e?f.find("[name='startTime']").val():null,timeTill:e?f.find("[name='endTime']").val():null})}),b}}},initView:function(b){for(var d=[b.checkedColorClass,b.uncheckedColorClass],f=e.append(a(b.containerTmpl)),g=this,h=0;h=1.7", 13 | "jt.timepicker": "~1.4.13" 14 | }, 15 | "devDependencies": { 16 | "grunt": "~0.4.1", 17 | "grunt-contrib-uglify": "~0.2.2" 18 | }, 19 | "description": "jQuery plugin allows you to easy show & manage business hours", 20 | "keywords": ["jQuery", "plugin", "business hours"] 21 | } --------------------------------------------------------------------------------