2018-05-25 12:30:27 +00:00
const React = require ( 'react' ) ;
const { connect } = require ( 'react-redux' ) ;
const { reg } = require ( 'lib/registry.js' ) ;
const { bridge } = require ( 'electron' ) . remote . require ( './bridge' ) ;
const { Header } = require ( './Header.min.js' ) ;
const { themeStyle } = require ( '../theme.js' ) ;
const { _ } = require ( 'lib/locale.js' ) ;
const ClipperServer = require ( 'lib/ClipperServer' ) ;
const Setting = require ( 'lib/models/Setting' ) ;
class ClipperConfigScreenComponent extends React . Component {
disableClipperServer _click ( ) {
Setting . setValue ( 'clipperServer.autoStart' , false ) ;
ClipperServer . instance ( ) . stop ( ) ;
}
enableClipperServer _click ( ) {
Setting . setValue ( 'clipperServer.autoStart' , true ) ;
ClipperServer . instance ( ) . start ( ) ;
}
chromeButton _click ( ) {
bridge ( ) . openExternal ( "https://chrome.google.com/webstore/detail/joplin-web-clipper/alofnhikmmkdbbbgpnglcpdollgjjfek" )
}
firefoxButton _click ( ) {
2018-05-26 16:13:27 +00:00
bridge ( ) . openExternal ( "https://addons.mozilla.org/en-US/firefox/addon/joplin-web-clipper/" ) ;
2018-05-25 12:30:27 +00:00
}
render ( ) {
const style = this . props . style ;
const theme = themeStyle ( this . props . theme ) ;
const headerStyle = {
width : style . width ,
} ;
const stepBoxStyle = {
border : "1px solid #ccc" ,
padding : 15 ,
paddingTop : 0 ,
marginBottom : 15 ,
} ;
let webClipperStatusComps = [ ] ;
if ( this . props . clipperServerAutoStart ) {
2018-05-26 16:25:11 +00:00
webClipperStatusComps . push ( < p key = "text_1" style = { theme . textStyle } > < b > { _ ( 'The web clipper service is enabled and set to auto-start.' ) } < / b > < / p > )
2018-05-25 12:30:27 +00:00
if ( this . props . clipperServer . startState === 'started' ) {
webClipperStatusComps . push ( < p key = "text_2" style = { theme . textStyle } > { _ ( 'Status: Started on port %d' , this . props . clipperServer . port ) } < / p > )
} else {
webClipperStatusComps . push ( < p key = "text_3" style = { theme . textStyle } > { _ ( 'Status: %s' , this . props . clipperServer . startState ) } < / p > )
}
webClipperStatusComps . push ( < button key = "disable_button" onClick = { this . disableClipperServer _click } > { _ ( 'Disable Web Clipper Service' ) } < / button > )
} else {
webClipperStatusComps . push ( < p key = "text_4" style = { theme . textStyle } > { _ ( 'The web clipper service is not enabled.' ) } < / p > )
webClipperStatusComps . push ( < button key = "enable_button" onClick = { this . enableClipperServer _click } > { _ ( 'Enable Web Clipper Service' ) } < / button > )
}
return (
< div >
< Header style = { headerStyle } / >
< div style = { { padding : theme . margin } } >
< p style = { theme . textStyle } > { _ ( 'Joplin Web Clipper allows saving web pages and screenshots from your browser to Joplin.' ) } < / p >
< p style = { theme . textStyle } > { _ ( 'In order to use the web clipper, you need to do the following:' ) } < / p >
< div style = { stepBoxStyle } >
< p style = { theme . h1Style } > { _ ( 'Step 1: Enable the clipper service' ) } < / p >
< p style = { theme . textStyle } > { _ ( 'This service allows the browser extension to communicate with Joplin. When enabling it your firewall may ask you to give permission to Joplin to listen to a particular port.' ) } < / p >
< div >
{ webClipperStatusComps }
< / div >
< / div >
< div style = { stepBoxStyle } >
< p style = { theme . h1Style } > { _ ( 'Step 2: Install the extension' ) } < / p >
< p style = { theme . textStyle } > { _ ( 'Download and install the relevant extension for your browser:' ) } < / p >
< div >
< p > < a href = '#' onClick = { this . chromeButton _click } > < img src = " data : image / png ; base64 , iVBORw0KGgoAAAANSUhEUgAAAM4AAAA6CAYAAAD4HGbLAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAADlRJREFUeNrsXXtwVFcZ / 3azm8eGdxKnYh6gAvIYAwxTeY06SBkpFpnpMNWOU9oOf6jUzojtyFBrxalap1rHiFjGQKRVpjY61g4IIiAir2mUBsdSIFgDERxLEiBhN9lks + v9nbvf5uzNvXcfWWBTvt / MZTd3z + ve + / 2 + 1znn4jl3vvVbJBAIMoLHIE6sbMI4uRMCQZro6LxGPnyZMH6s3A2BIAPieOU2CASZQ4gjEAhxBAIhjkAgxBEIhDgCgRBHIBBkCl + 2FTs6OigcDqdVNhaL5WSww2mnsrJSnrbg9hPH4 / GQ1 + tNS6hRNhdEybYdgUBcNYFgJFuc4bpQ0WiUBgYG0moblsbn88nTErw3iJNtzAHClJaWUqCkJK3y / ZEIdRoxlc / vlycmGNnEGU6gPmbMGHWkiyLjKDDiqc6rVyXOEdy5MU5JmpZGR2FR0S0nTbth5c6cPZd1fdQNhXpUOxfb / uNYDr + hjBWom27 / Tm1kMk5BnhPnxo0bKsbJxLp1dXXd8nHufKWRnnv + R65C70Y61N23 / yAdOXpCteXWD8oMJUObaiMd1P30Rarf / lLaY3vt9d2Jv81rbBM23OrkQKbo7e1Vc0BOFsTODcyEaLmyNiffPKW + Q / jXPvJQRvXLy8pow5NfpeqqKlX / ZuPxdV + kQCA9S97eDuLsolUrVwgDRhJxmBxOcVKuJkyHA1iA8vIyJVywCKEHVisCgFBMoiPHjityrVr5GVUGLk91VSWtfXSN + oRWf / Bzq5Ncr52 / bjTqNBtCHqDFCxckhBca / 5ubvqPanztnNj34wOqk8aAfCDus39w5tapdkHNwvMepurpSERVjAYlQ5yPTpiaRCvXZ + sHS8PiOHDtB9Q2mxcKYMDaURZ9oB9eD60Tfgjycx8kH0jAp5s6uNY7ZSuBPNjcr4YGAciyx708HFQFAqFAopCwMyPbc8y9osUMoKZYAaSCsEEwmAhNDEcb4DWVAMN361TfsMIhRpUgAi2F1y1SM096p + kM / GBfKgpB6WyAQ2gFAKiaUGpdBVpzjtuu371B9Kctp1MEYJBbKU + LkAyB4EJhQT48iBcgACwRti + 8gDAQVx7KlS9SB87Awqp6DcEEoQQ60xUE / u4OLFy1IaHqQBwTVrY1KMhhts9uXKmkAq4jxLlv6KVVPdyEXL5yfsCxstdiasAVEP0xq / bokFrrNrlp + W5sTShNDWHBgvkmRydD8IImyMAapYIFwfPnx9UoAIfBnzrY4JhPYTVv7yJqEe5awBFqmMVASGJJdw3hAPAYImEvgOphY3Kc6b1gaPof + oSAEYnGGQLllhnBDA8NFwfHtZ55SggtLAYsAMsEiLLtnSaIOhArxhZslgBsFFwplQULdMsE1ZHLChUsmSW2CPCDucNPkVktmbx2nJNw49Kmu / 9hxEZB8szj5Ym0Qy0CYrEGwcrEMwVHulOFWgVwgEbs5EHZ265yAcoh / YKEgiHpZaHVOPUP7w3pxfGQmHB5SsQcH / nrSIXPrUqXaRArbrZ0NT65X42W3UbmkZWJxAPVetSkfqsm4IrYV9PX1jRjSTJw4UZ62ICdo + deF22dxBtouUP + pv1P / 2dM00N5O0Y4roNAgow0 / v6Cqhgoqa8g / bTr5Z8 + TJya4M121mOF6hA / upfCxv8aJ4mBtMMcTClLEIFXkzGkK79 + jiFS48ONUfM9y8pZVjEg3UCDEyVgge3f / jnr376VYTyhBjkQ72r + kNxnTSRc06u8xjj9Q8dJ7qfi + + 8kTCAhxBCOLOH6 / P61Fl5GL / 6Zgw1aKXrpIhThR6I8Twt7SJJNGo5ROtMP7qbfpKI1e9wT5ps8S0ghGDnGwbVrfOm2H8JFDFNrZoKyF144cQ8xKzOF0bOjJrj668b2nKfCFtVT86ftyfmN4rRpPUCKThUwbZ9KQDsaczeJF8 / M + 04QsITJ + SDHraW4n8LVxGtoJmBhNt01u11xlMZhaT7duvuGmzeOANMH6zYo0CVLErH5YlqTRyoZe / jkFt / 44p2NH2hnrxpD65eU1IBDSwThvLvdvUSlofVY + XwEh3bf / gOsKbSshUD7VolFcP + 5DOsD9Q7qdFZH1b16xne3WiPdEcoBJY29hbNy0lKRxKmt + Dx8 + QAXVk6l4 + cphjx1aEQSB0GDykzUia20IVKgnNOI0pLnU53hC27OCwLVC8 + vzObgHuV7MiXtn3tP1ag4JBIESOtl8SvXFK7ZhwUbCXFHOiTNwsdVwz7ZnThhX0qSOh0Iv15Nv0gdTxjzpaFuAH7CutTH5aee + QGvyqmWuA8GAMIB4PMuPiUfURVnUYfePBYXroBwmYrFok11BfZuDXofrmevrOpPGoAMCCeLopEhof0N4mTg8Vl1h8FjQrh2h3MY26C6aqyb0pT1YkcHXxsuU + FPvH2PCedTVF6ZyWV4exe3rY87ElbytxGlu3EqTg0F3wmRLGlsLNPi1 + 4fP0ri6beQJlGYd1 + AhYWWAnfDxQ9KB2XdetgKNydoby3PwN9rhB / yD7z + ryuvLZeA + YVUAYie7Ovgb49EXfeIcC51yIbVVy7xcB9YymThTk6yJubToVELoWDDZ9UIZnMPKAX1ZDspAqeirqtGnPjZe / W3tH1YH7hnukU4wvm6 + H8Av6n9m2z9WW2DVN8aBsrzeD2Vwn9C2tY51a0XexTi / fOcwbagMOscxdrFOLAvSOFgzxFM9v92ZfUIgHq9k4iqgLAiBQ62cjge / CU3b06MeGgQdq6qZmFvqXohvdKtU7pJ1YSjaY + EHabgOlu2gfQgbPkEaaFqUxe8ox0G4dZzoC9bFtDLN6hPtcR9MBFwHymNbAQBiQ5BBCLWfR9umgL / RBl8PC791DRzqQqgxNigPLDti6w6ryhYPn9wOyln7xzPi80wYVhRMGtNjMO8H95nrzYQ5szjd / T205dwfqSvgo8Ypo2l1S5e7hYnzAtahaN588s + YRQXl7zPPR4NU0PMW + YNN5IlccbE6dm3upb7IKor6KuhWAELDRBvcYzO46hl7XNi9QUyh1p3FN8LhgWPTm / L1466OKShrVJs4UAbtcR24i6ydeV2d6Q62qIPHgvYgNHZan10rzmyBNCAUrgVEAPl424SKRwyXh4UcpAK5SLsG3oqA7xBuKAKMzWp18Bv6wG9oj + 8VWxC2aOzegiQoz + 2oBa7xrRWsaNgCsTW13o9AfK7PtPIr8o84r7U1UVe / qWUaZoyj5a03aFR / 1NW9Kr3 / 81RiBPRW18q0Oh + jCD1Khdd3U9HVRvIYZDLb8miNeGwtT8G1VylYvi7ja9DdmXRvcirzr / + Oh1o9pyrpdxYY9Mn9W91ExDz2FrIzQRKdeM4JgloldFweBDE1 / gJlJVgrIy7gBaZMoFT3TLds + tjs7geIgIOzam6ZNIzF7hp4fLp3wG6mmU5PXj2e631EOSPO79veYIeJuv0eqqsdTxub2m0JA6KMe / q75KuZTFe6iRr / 7KHTlz10JW6kSouI5k2K0SemxWjGxBU0UDKTit / dTAXhVmdLo533hzCWdVldB8cTsA5WjcnZIbvz6ZLs4sW2IXGVnQCm5SaWT1Cf0Lh60M6WwknI2WJhh6v9 + dmJcVkzbta2rUqG6 / HYuA5cKGyq099zoFsW5yxnS9K9cVMQTDKOGfUx5TpTl5MY51Kok97uuqRIw9gzaRS1jCu0jWPGfu0pRZq / nPXQY7 / yqs8rmmcXDBMdMs5tet1LO456aaBwEvVWPEYxb2lK0ihiGtbJJE / mgGsFAYe7AXdC39oMDQnNrAfDGZEyvo8fe / v5tVF1m1 + 01axppZgNAVdjNeIc1rAgNlw / J59e39vDZAMReIsDvqvt1fFzUCC8Dwd9gAD8bgI + x3EdvvO2B4xNt6pwmXjrBScmeK5IJwZ + Z + trxowHEv3zWHDeTtFw1pL
2018-05-26 16:13:27 +00:00
< p > < a href = '#' onClick = { this . firefoxButton _click } > < img src = " data : image / jpeg ; base64 , / 9j / 4AAQSkZJRgABAgAAZABkAAD / 7AARRHVja3kAAQAEAAAAUAAA / + 4ADkFkb2JlAGTAAAAAAf / bAIQAAgICAgICAgICAgMCAgIDBAMCAgMEBQQEBAQEBQYFBQUFBQUGBgcHCAcHBgkJCgoJCQwMDAwMDAwMDAwMDAwMDAEDAwMFBAUJBgYJDQsJCw0PDg4ODg8PDAwMDAwPDwwMDAwMDA8MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwM / 8AAEQgAOgDOAwERAAIRAQMRAf / EALEAAQACAwEBAAMAAAAAAAAAAAAFBwQGCAkDAQIKAQEAAQQDAQAAAAAAAAAAAAAAAQUGBwgCAwkEEAABAwMCAQgHBgMHBQAAAAACAQMEAAUGEQcSITET05UXV5hBIjIUdBUIUWGzNLQ1cYEzwUJSIyQWOHKCQ0QYEQACAQMCAwYCBggHAAAAAAAAAQIRAwQhBTESBkFRYXEiEzIHgaGxUnIUkcHRQmKCI0Pw4aIzoxUI / 9oADAMBAAIRAxEAPwD2dteyuz71stzzu12Km67FZNw1tMTVSIEVVX / K9K1LZBndyGznhZinZETq6VJoO5DZzwsxTsiJ1dKig7kNnPCzFOyInV0qKDuQ2c8LMU7IidXSooYy7ObJpLGCu2OJpKNtXRa + URNeFF01 / pVTZbxixzVgua95wc1H + FOlf2LjRN8Ezs9mXJz09NaGT3IbOeFmKdkROrqpVOug7kNnPCzFOyInV0qKDuQ2c8LMU7IidXSooO5DZzwsxTsiJ1dKig7kNnPCzFOyInV0qKDuQ2c8LMU7IidXSooO5DZzwsxTsiJ1dKig7kNnPCzFOyInV0qKDuQ2c8LMU7IidXSooO5DZzwsxTsiJ1dKig7kNnPCzFOyInV0qKDuQ2c8LMU7IidXSooO5DZzwsxTsiJ1dKig7kNnPCzFOyInV0qKDuQ2c8LMU7IidXSooO5DZzwsxTsiJ1dKig7kNnPCzFOyInV0qKDuQ2c8LMU7IidXSooO5DZzwsxTsiJ1dKihgy9ldnwkWsQ2uxURelEDqJaYnrCjDxaL / lfaKLSpBZtn / aLV8Gx + GNHxJRJVAOV97PqWs2z25O22G3NpVtl + F6fl88GyediwSF2PGJtsEIl1fTjPRFXhDREVSr48rLjjuLk0o9rfYZA6V6Hu75t + Vk26u5BJW4 / ekqSn / o9MezmlrwOQ9xfrT3lze / uY7sphzmG48pGLOYXhhp2Y + A8nSoDimxHFU5hJDP08i6ol2YO / 9DbViSzN03CF1xp / StOTm2 + CUElOfjKsYLtZYO79I9WTvLGxcOVtyXxzoopd7k24ry1k + xFBpvhvZ82dbkbwXu5Osno7IhT3gikf95AAUbBUReTkHT7OSs87PtO07jttvK / 672FcVVC9CPuqL + FzSlPlclryuXMv3knVGs3VO + 7rtuZcsRzndcHRytSl7bfby1UapPSqVH2VWp6f7dXS7zcOxa73W7PXW9SoEaVKurpIrhuuNCWqqiInIi6c3Nz15b9Z7zcu9Vbjk2v6creZdhBLT242Je1BL + WOq4PmlVNNo2t6Wtzls2J70ueU7MJSb / ec1zv639RcuK5BPnT7lCurjZq6509ocbHhRGuEUNkk / wAQqilr6UX7qyx0B15d3i / cxcyiuv1W6aKUUlzR / FFrm4uqb + 6zu3TAt2rcJ2k9FSVe + ukvJ8PBrxN8rK5QxQCgFAKAUAoBQCgFAKAUAoBQCgFAKAUBGzvzVn + ML9M / UoCz / tFq + DY / DGj4hGe442y2486aNtNCpuOEuiCIpqqqv2IlQSk5Oi4ngbu9ug9vLu1e8wJsWrY258sxxnh4SC2xDNGOP08RqROFrzKSpzIlY76tvycmuxG7 / Q3TkNh2aFlfHJc033zklX6FpFeVeLN + x + J0llng2KkZxHRQR5FXUFRdFTl10rAGdmSs51q4nRxnGSejo4tNaPTj36FI3q3byG7V3WEvTLs9L0eq4FF3RjD7IMZqw3py4XFHVSXEQgdaZbRPS4Ip62uiaar6ddK9LPlJ1f1h1TG5d3vBt2MbkTt3UpW7l2ba4W5yl6OWrc6RVeVR5k3Tza + c3RPTHT91Wtoy53rzm + eDcZxtxo / 34qPqrRcvqfHmppXuz6cN57XcrNCwS7yhj3q1grdo6RdElxR1IRbVedxofVUedRRCTXQtNQP / AEp8p87pjeL / AFFi23PbsuSlecVX8vkSopSkl / buv1KXDnbi6Pk5r4 + UHV9ncMGG13pUyLKpCv8ActrhTxgtKfdSffTrRm6lFeYlx3E42iRxs05uT + z7a1623c54l + 3k2JeqDUovy / U + D8KozNPF54uElx0OgoUpubEjTGv6cpoHQTn0Qk10 / lW5 + 35sM3Gt5Fv4ZxUl / Mqlg3rTtTcHxToUpv5kN9s2PYfabDeXsadzvMbRi9yyaNwe8W + HPVxXnmScQgFwujRsSVPVU9U5dK + 6J1MqCPn0fZvJN0red / z7JIuMYhIv8XGMxQpISHIEpuKsuBeH3jdVl83hHgVpU9o0XkQKmlSK0IK / 74bz3KHicWHj7WNSJ2a4nBDIHrdeLbAubF3dIihAlzhtu8LbjaA + bevEBIoc6pSiFWX7u5kV7sl02hhWt02rjkWT + 4EDct2PENz3CQ6IShACJ1lTBNR5Pt500qEiWQ2wec5TedhLdn + f3ODKnHFuV0O8OuE02UVhx01cmKLXC1wEBoqNgoi2g6Jr6tJLUJ6FbWT6k8 / u1i3Efg4PFyG94vbrHdrE1bo1yjtSot4cIDMY81pqS + DKCpgbYD0yeyI89TyojmLw2Y3Oe3Ixu73K6P2sLlZLk9CnsQAmxlabEBcbKTFuDTTsc1EuUdTHk1Q15UTi1QlOpoe0m / F53B3EnYfOt1sctD + PSchsWQWtq4tx3G41wCCTbbtwYj + 9ivSIvTNAIcSEKa6a1LjREJ1Ooa4nIUAoBQCgFAKAUAoCNnfmrP8AGF + mfqUBZ / 2i1fBsfhjR8QiHztbgmD5ktoFDuqWO4 / LAXmWR7s50SL / 36VytJOarwqj7dt5PzVr3Ph5418qqv1H84GJyUX3Y1LXVU1X + NY86vx3G5NG / 1j12KLuLCyHJ9z7bYiumDALyQn1K5QQjBJcWGgEikIEikSouilw8qJzemrc6K2LpTM3VY2 + txjONLc + d24q9VNJyTSjpVR5vS3x1aMLfM + 3umNge7gUc1L1qnM / bo + C7dac1NacO05xx2Pk0iE9Ot + P3WZBgjrLmMQn3Gm0HnUzEFEdPTXodHrjace7DHyMuxC5PSMZXYRnLu5YuVX4d559br0VlXFK5bszcVxai2l5uhtuN5tIhX3HJcQlKUxdYBxkBeUjWQ2iCipy + trw / zrs64sYm47Bn42RT25491Sr2Lklr / Lx80W / 0 / tuTgbnj37VVOFyLVPP7H2rtPZuNd5FvkSrbJfV / 3V82UeLnMUVUA1 + / TnrxA27IcGmvhkq07n4G + lzEjejG5FUqk6d3evLuOoNpp824YqT0w1cBufIZgKqJyMNqKCiaeji4q3J + VeRdvbHD3HVRlJR / CqafQ6mMuqrFuzmUgtXGLl + J / wCVCaz624NeMYnWvcb5b / tacTbctLq + MZjpEJCbUXiNtQNCHUVEkJFTVFrJCLaZWOH7fbB235pKscy15JJy6OeNXG5XC9nenpkd0UMraLsmS + vCoihdEHKqIiqnJUtsJInWvp / 2kZs8yxhix + 4zpUGa86VyuJyxftqKMImphSVkNdAhKjaNuCgouiJpUczFEbXkdrwKbdcLYyZ + EF4sdwSdhMWTOKO + swGiYQmWkdBX1QHFHhJCTl5taKoPxj22mEYrjF1wux2IYuK3opRXCxOPyJEchmh0choBfcc6Nsx5Ojb4QTVdBTVaVFDUon097QQoN0tzWHo5EvUOJBuQSJ0 + QTjMBxXImjj0gzEmFXRsxVDEUQRJBFERzMURlYquzOCHcsZx7ILFBn3O4EN5hSryM
2018-05-25 12:30:27 +00:00
< / div >
< / div >
< / div >
< / div >
) ;
}
}
const mapStateToProps = ( state ) => {
return {
theme : state . settings . theme ,
clipperServer : state . clipperServer ,
clipperServerAutoStart : state . settings [ 'clipperServer.autoStart' ] ,
} ;
} ;
const ClipperConfigScreen = connect ( mapStateToProps ) ( ClipperConfigScreenComponent ) ;
module . exports = { ClipperConfigScreen } ;