CINXE.COM

<!doctype html><html lang="en"><head><title data-rh="true">Demystify Jetpack Compose Layout Constraint and Size Setting | by Elye - A One Eye Dev By His Grace | Mobile App Development Publication | Medium</title><meta data-rh="true" charset="utf-8"/><meta data-rh="true" name="viewport" content="width=device-width,minimum-scale=1,initial-scale=1,maximum-scale=1"/><meta data-rh="true" name="theme-color" content="#000000"/><meta data-rh="true" name="twitter:app:name:iphone" content="Medium"/><meta data-rh="true" name="twitter:app:id:iphone" content="828256236"/><meta data-rh="true" property="al:ios:app_name" content="Medium"/><meta data-rh="true" property="al:ios:app_store_id" content="828256236"/><meta data-rh="true" property="al:android:package" content="com.medium.reader"/><meta data-rh="true" property="fb:app_id" content="542599432471018"/><meta data-rh="true" property="og:site_name" content="Medium"/><meta data-rh="true" property="og:type" content="article"/><meta data-rh="true" property="article:published_time" content="2023-08-15T11:57:39.829Z"/><meta data-rh="true" name="title" content="Demystify Jetpack Compose Layout Constraint and Size Setting | by Elye - A One Eye Dev By His Grace | Mobile App Development Publication | Medium"/><meta data-rh="true" property="og:title" content="Demystify Jetpack Compose Layout Constraint and Size Setting"/><meta data-rh="true" property="al:android:url" content="medium://p/b89fa2c43f1c"/><meta data-rh="true" property="al:ios:url" content="medium://p/b89fa2c43f1c"/><meta data-rh="true" property="al:android:app_name" content="Medium"/><meta data-rh="true" name="description" content="I shared about how one can support negative padding in Jetpack Compose. The best solution used is to use Jetpack Compose Custom Layout Modifier. As we modify the width, we thought the divider’s…"/><meta data-rh="true" property="og:description" content="Mastering one of the most confusing Jetpack Compose APIs I encountered"/><meta data-rh="true" property="og:url" content="https://medium.com/mobile-app-development-publication/demystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c"/><meta data-rh="true" property="al:web:url" content="https://medium.com/mobile-app-development-publication/demystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c"/><meta data-rh="true" property="og:image" content="https://miro.medium.com/v2/da:true/resize:fit:1200/0*-P2EKQ3GDZRnXG2A"/><meta data-rh="true" property="article:author" content="https://elye-project.medium.com"/><meta data-rh="true" name="author" content="Elye - A One Eye Dev By His Grace"/><meta data-rh="true" name="robots" content="index,noarchive,follow,max-image-preview:large"/><meta data-rh="true" name="referrer" content="unsafe-url"/><meta data-rh="true" property="twitter:title" content="Demystify Jetpack Compose Layout Constraint and Size Setting"/><meta data-rh="true" name="twitter:site" content="@elye_project"/><meta data-rh="true" name="twitter:app:url:iphone" content="medium://p/b89fa2c43f1c"/><meta data-rh="true" property="twitter:description" content="Mastering one of the most confusing Jetpack Compose APIs I encountered"/><meta data-rh="true" name="twitter:image:src" content="https://miro.medium.com/v2/da:true/resize:fit:1200/0*-P2EKQ3GDZRnXG2A"/><meta data-rh="true" name="twitter:card" content="summary_large_image"/><meta data-rh="true" name="twitter:creator" content="@elye_project"/><meta data-rh="true" name="twitter:label1" content="Reading time"/><meta data-rh="true" name="twitter:data1" content="11 min read"/><link data-rh="true" rel="icon" href="https://miro.medium.com/v2/5d8de952517e8160e40ef9841c781cdc14a5db313057fa3c3de41c6f5b494b19"/><link data-rh="true" rel="search" type="application/opensearchdescription+xml" title="Medium" href="/osd.xml"/><link data-rh="true" rel="apple-touch-icon" sizes="152x152" href="https://miro.medium.com/v2/resize:fill:304:304/10fd5c419ac61637245384e7099e131627900034828f4f386bdaa47a74eae156"/><link data-rh="true" rel="apple-touch-icon" sizes="120x120" href="https://miro.medium.com/v2/resize:fill:240:240/10fd5c419ac61637245384e7099e131627900034828f4f386bdaa47a74eae156"/><link data-rh="true" rel="apple-touch-icon" sizes="76x76" href="https://miro.medium.com/v2/resize:fill:152:152/10fd5c419ac61637245384e7099e131627900034828f4f386bdaa47a74eae156"/><link data-rh="true" rel="apple-touch-icon" sizes="60x60" href="https://miro.medium.com/v2/resize:fill:120:120/10fd5c419ac61637245384e7099e131627900034828f4f386bdaa47a74eae156"/><link data-rh="true" rel="mask-icon" href="https://miro.medium.com/v2/resize:fill:1000:1000/7*GAOKVe--MXbEJmV9230oOQ.png" color="#171717"/><link data-rh="true" rel="preconnect" href="https://glyph.medium.com" crossOrigin=""/><link data-rh="true" id="glyph_preload_link" rel="preload" as="style" type="text/css" href="https://glyph.medium.com/css/unbound.css"/><link data-rh="true" id="glyph_link" rel="stylesheet" type="text/css" href="https://glyph.medium.com/css/unbound.css"/><link data-rh="true" rel="author" href="https://elye-project.medium.com"/><link data-rh="true" rel="canonical" href="https://medium.com/mobile-app-development-publication/demystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c"/><link data-rh="true" rel="alternate" href="android-app://com.medium.reader/https/medium.com/p/b89fa2c43f1c"/><script data-rh="true" type="application/ld+json">{"@context":"http:\u002F\u002Fschema.org","@type":"NewsArticle","image":["https:\u002F\u002Fmiro.medium.com\u002Fv2\u002Fda:true\u002Fresize:fit:1200\u002F0*-P2EKQ3GDZRnXG2A"],"url":"https:\u002F\u002Fmedium.com\u002Fmobile-app-development-publication\u002Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c","dateCreated":"2023-06-27T13:32:03.271Z","datePublished":"2023-06-27T13:32:03.271Z","dateModified":"2023-08-15T11:57:39.829Z","headline":"Demystify Jetpack Compose Layout Constraint and Size Setting","name":"Demystify Jetpack Compose Layout Constraint and Size Setting","description":"I shared about how one can support negative padding in Jetpack Compose. The best solution used is to use Jetpack Compose Custom Layout Modifier. As we modify the width, we thought the divider’s…","identifier":"b89fa2c43f1c","author":{"@type":"Person","name":"Elye - A One Eye Dev By His Grace","url":"https:\u002F\u002Felye-project.medium.com"},"creator":["Elye - A One Eye Dev By His Grace"],"publisher":{"@type":"Organization","name":"Mobile App Development Publication","url":"https:\u002F\u002Fmedium.com\u002Fmobile-app-development-publication","logo":{"@type":"ImageObject","width":272,"height":60,"url":"https:\u002F\u002Fmiro.medium.com\u002Fv2\u002Fresize:fit:544\u002F7*V1_7XP4snlmqrc_0Njontw.png"}},"mainEntityOfPage":"https:\u002F\u002Fmedium.com\u002Fmobile-app-development-publication\u002Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c","isAccessibleForFree":"False","hasPart":{"@type":"WebPageElement","isAccessibleForFree":"False","cssSelector":".meteredContent"}}</script><style type="text/css" data-fela-rehydration="560" data-fela-type="STATIC">html{box-sizing:border-box;-webkit-text-size-adjust:100%}*, *:before, *:after{box-sizing:inherit}body{margin:0;padding:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;color:rgba(0,0,0,0.8);position:relative;min-height:100vh}h1, h2, h3, h4, h5, h6, dl, dd, ol, ul, menu, figure, blockquote, p, pre, form{margin:0}menu, ol, ul{padding:0;list-style:none;list-style-image:none}main{display:block}a{color:inherit;text-decoration:none}a, button, input{-webkit-tap-highlight-color:transparent}img, svg{vertical-align:middle}button{background:transparent;overflow:visible}button, input, optgroup, select, textarea{margin:0}:root{--reach-tabs:1;--reach-menu-button:1}#speechify-root{font-family:Sohne, sans-serif}div[data-popper-reference-hidden="true"]{visibility:hidden;pointer-events:none}.grecaptcha-badge{visibility:hidden} /*XCode style (c) Angel Garcia <angelgarcia.mail@gmail.com>*/.hljs {background: #fff;color: black; }/* Gray DOCTYPE selectors like WebKit */ .xml .hljs-meta {color: #c0c0c0; }.hljs-comment, .hljs-quote {color: #007400; }.hljs-tag, .hljs-attribute, .hljs-keyword, .hljs-selector-tag, .hljs-literal, .hljs-name {color: #aa0d91; }.hljs-variable, .hljs-template-variable {color: #3F6E74; }.hljs-code, .hljs-string, .hljs-meta .hljs-string {color: #c41a16; }.hljs-regexp, .hljs-link {color: #0E0EFF; }.hljs-title, .hljs-symbol, .hljs-bullet, .hljs-number {color: #1c00cf; }.hljs-section, .hljs-meta {color: #643820; }.hljs-title.class_, .hljs-class .hljs-title, .hljs-type, .hljs-built_in, .hljs-params {color: #5c2699; }.hljs-attr {color: #836C28; }.hljs-subst {color: #000; }.hljs-formula {background-color: #eee;font-style: italic; }.hljs-addition {background-color: #baeeba; }.hljs-deletion {background-color: #ffc8bd; }.hljs-selector-id, .hljs-selector-class {color: #9b703f; }.hljs-doctag, .hljs-strong {font-weight: bold; }.hljs-emphasis {font-style: italic; } </style><style type="text/css" data-fela-rehydration="560" data-fela-type="KEYFRAME">@-webkit-keyframes k1{0%{opacity:0.8}50%{opacity:0.5}100%{opacity:0.8}}@-moz-keyframes k1{0%{opacity:0.8}50%{opacity:0.5}100%{opacity:0.8}}@keyframes k1{0%{opacity:0.8}50%{opacity:0.5}100%{opacity:0.8}}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE">.a{font-family:medium-content-sans-serif-font, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif}.b{font-weight:400}.c{background-color:rgba(255, 255, 255, 1)}.l{display:block}.m{position:sticky}.n{top:0}.o{z-index:500}.p{padding:0 24px}.q{align-items:center}.r{border-bottom:solid 1px #F2F2F2}.y{height:41px}.z{line-height:20px}.ab{display:flex}.ac{height:57px}.ae{flex:1 0 auto}.af{color:inherit}.ag{fill:inherit}.ah{font-size:inherit}.ai{border:inherit}.aj{font-family:inherit}.ak{letter-spacing:inherit}.al{font-weight:inherit}.am{padding:0}.an{margin:0}.ao{cursor:pointer}.ap:disabled{cursor:not-allowed}.aq:disabled{color:#6B6B6B}.ar:disabled{fill:#6B6B6B}.au{width:auto}.av path{fill:#242424}.aw{height:25px}.ax{margin-left:16px}.ay{border:none}.az{border-radius:20px}.ba{width:240px}.bb{background:#F9F9F9}.bc path{fill:#6B6B6B}.be{outline:none}.bf{font-family:sohne, "Helvetica Neue", Helvetica, Arial, sans-serif}.bg{font-size:14px}.bh{width:100%}.bi{padding:10px 20px 10px 0}.bj{background-color:transparent}.bk{color:#242424}.bl::placeholder{color:#6B6B6B}.bm{display:inline-block}.bn{margin-left:12px}.bo{margin-right:12px}.bp{border-radius:4px}.bq{margin-left:24px}.br{height:24px}.bx{background-color:#F9F9F9}.by{border-radius:50%}.bz{height:32px}.ca{width:32px}.cb{justify-content:center}.ch{max-width:680px}.ci{min-width:0}.cj{animation:k1 1.2s ease-in-out infinite}.ck{height:100vh}.cl{margin-bottom:16px}.cm{margin-top:48px}.cn{align-items:flex-start}.co{flex-direction:column}.cp{justify-content:space-between}.cq{margin-bottom:24px}.cw{width:80%}.cx{background-color:#F2F2F2}.dd{height:44px}.de{width:44px}.df{margin:auto 0}.dg{margin-bottom:4px}.dh{height:16px}.di{width:120px}.dj{width:80px}.dp{margin-bottom:8px}.dq{width:96%}.dr{width:98%}.ds{width:81%}.dt{margin-left:8px}.du{color:#6B6B6B}.dv{font-size:13px}.dw{height:100%}.ep{color:#FFFFFF}.eq{fill:#FFFFFF}.er{background:rgba(26, 137, 23, 1)}.es{border-color:rgba(26, 137, 23, 1)}.ew:disabled{cursor:inherit !important}.ex:disabled{opacity:0.3}.ey:disabled:hover{background:rgba(26, 137, 23, 1)}.ez:disabled:hover{border-color:rgba(26, 137, 23, 1)}.fa{border-radius:99em}.fb{border-width:1px}.fc{border-style:solid}.fd{box-sizing:border-box}.fe{text-decoration:none}.ff{text-align:center}.fi{margin-right:32px}.fj{position:relative}.fk{fill:#6B6B6B}.fn{background:transparent}.fo svg{margin-left:4px}.fp svg{fill:#6B6B6B}.fr{box-shadow:inset 0 0 0 1px rgba(0, 0, 0, 0.05)}.fs{position:absolute}.fz{margin:0 24px}.gd{background:rgba(255, 255, 255, 1)}.ge{border:1px solid #F2F2F2}.gf{box-shadow:0 1px 4px #F2F2F2}.gg{max-height:100vh}.gh{overflow-y:auto}.gi{left:0}.gj{top:calc(100vh + 100px)}.gk{bottom:calc(100vh + 100px)}.gl{width:10px}.gm{pointer-events:none}.gs{gap:12px}.gt{margin-right:4px}.gu{margin-top:2px}.gv{box-sizing:content-box}.gw{word-break:break-word}.gx{word-wrap:break-word}.gy:after{display:block}.gz:after{content:""}.ha:after{clear:both}.hb{line-height:18px}.hc{letter-spacing:0.077em}.hd{font-style:normal}.hj{margin-bottom:-0.31em}.hk{text-transform:uppercase}.hl{line-height:1.23}.hm{letter-spacing:0}.hn{font-weight:700}.id{margin-top:12px}.ie{margin-bottom:-0.27em}.if{line-height:1.394}.ja{align-items:baseline}.jb{width:48px}.jc{height:48px}.jd{border:2px solid rgba(255, 255, 255, 1)}.je{z-index:0}.jf{box-shadow:none}.jg{border:1px solid rgba(0, 0, 0, 0.05)}.jh{margin-left:-12px}.ji{width:28px}.jj{height:28px}.jk{z-index:1}.jl{width:24px}.jm{margin-bottom:2px}.jn{flex-wrap:nowrap}.jo{font-size:16px}.jp{line-height:24px}.jr{margin:0 8px}.js{display:inline}.jt{color:rgba(26, 137, 23, 1)}.ju{fill:rgba(26, 137, 23, 1)}.jx{flex:0 0 auto}.ka{flex-wrap:wrap}.kd{white-space:pre-wrap}.ke{overflow:hidden}.kf{max-height:20px}.kg{text-overflow:ellipsis}.kh{display:-webkit-box}.ki{-webkit-line-clamp:1}.kj{-webkit-box-orient:vertical}.kk{word-break:break-all}.km{padding-left:8px}.kn{padding-right:8px}.lo> *{flex-shrink:0}.lp{overflow-x:scroll}.lq::-webkit-scrollbar{display:none}.lr{scrollbar-width:none}.ls{-ms-overflow-style:none}.lt{width:74px}.lu{flex-direction:row}.lv{z-index:2}.ly{-webkit-user-select:none}.lz{border:0}.ma{fill:rgba(117, 117, 117, 1)}.md{outline:0}.me{user-select:none}.mf> svg{pointer-events:none}.mo{cursor:progress}.mp{opacity:1}.mq{padding:4px 0}.mt{margin-top:0px}.mu{width:16px}.mw{display:inline-flex}.nc{max-width:100%}.nd{padding:8px 2px}.ne svg{color:#6B6B6B}.nv{margin-left:auto}.nw{margin-right:auto}.nx{max-width:6240px}.od{clear:both}.of{cursor:zoom-in}.og{z-index:auto}.oi{height:auto}.oj{margin-top:10px}.ok{max-width:728px}.on{text-decoration:underline}.oo{line-height:1.58}.op{letter-spacing:-0.004em}.oq{font-family:source-serif-pro, Georgia, Cambria, "Times New Roman", Times, serif}.pj{margin-bottom:-0.46em}.pk{clear:left}.pl{float:left}.pm{font-size:66px}.pn{line-height:.83}.pt{overflow-x:auto}.pu{font-family:source-code-pro, Menlo, Monaco, "Courier New", Courier, monospace}.pv{padding:32px}.pw{border:1px solid #E5E5E5}.px{line-height:1.4}.py{letter-spacing:-0.022em}.pz{margin-top:-0.2em}.qa{margin-bottom:-0.2em}.qb{white-space:pre}.qc{min-width:fit-content}.qd{list-style-type:disc}.qe{margin-left:30px}.qf{padding-left:0px}.ql{border-top:none}.qm{margin-bottom:14px}.qn{height:52px}.qo{max-height:52px}.qp{position:static}.qr{max-width:155px}.qx{margin-right:20px}.rd{height:0px}.re{margin-bottom:40px}.rf{margin-bottom:48px}.rt{border-radius:2px}.rv{height:64px}.rw{width:64px}.rx{align-self:flex-end}.ry{flex:1 1 auto}.se{padding-right:4px}.sf{font-weight:500}.ss{margin-top:8px}.st{margin-top:16px}.su{color:rgba(255, 255, 255, 1)}.sv{padding:8px 16px}.sw{fill:rgba(255, 255, 255, 1)}.sx{background:rgba(25, 25, 25, 1)}.sy{border-color:rgba(25, 25, 25, 1)}.tb:disabled{opacity:0.1}.tc:disabled:hover{background:rgba(25, 25, 25, 1)}.td:disabled:hover{border-color:rgba(25, 25, 25, 1)}.te{margin-bottom:54px}.tx{gap:18px}.ty{fill:rgba(61, 61, 61, 1)}.uk{border-bottom:solid 1px #E5E5E5}.ul{margin-top:72px}.um{padding:24px 0}.un{margin-bottom:0px}.uo{margin-right:16px}.as:hover:not(:disabled){color:rgba(25, 25, 25, 1)}.at:hover:not(:disabled){fill:rgba(25, 25, 25, 1)}.et:hover{background:rgba(15, 115, 12, 1)}.eu:hover{border-color:rgba(15, 115, 12, 1)}.ev:hover{cursor:pointer}.fl:hover{color:#242424}.fm:hover{fill:#242424}.fq:hover svg{fill:#242424}.ft:hover{background-color:rgba(0, 0, 0, 0.1)}.jq:hover{text-decoration:underline}.jv:hover:not(:disabled){color:rgba(15, 115, 12, 1)}.jw:hover:not(:disabled){fill:rgba(15, 115, 12, 1)}.mc:hover{fill:rgba(8, 8, 8, 1)}.mr:hover{fill:#000000}.ms:hover p{color:#000000}.mv:hover{color:#000000}.nf:hover svg{color:#000000}.ru:hover{background-color:none}.sz:hover{background:#000000}.ta:hover{border-color:#242424}.tz:hover{fill:rgba(25, 25, 25, 1)}.bd:focus-within path{fill:#242424}.mb:focus{fill:rgba(8, 8, 8, 1)}.ng:focus svg{color:#000000}.oh:focus{transform:scale(1.01)}.mg:active{border-style:none}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="all and (min-width: 1080px)">.d{display:none}.bw{width:64px}.cg{margin:0 64px}.cv{height:48px}.dc{margin-bottom:52px}.do{margin-bottom:48px}.ef{font-size:14px}.eg{line-height:20px}.em{font-size:13px}.eo{padding:5px 12px}.fh{display:flex}.fy{margin-bottom:68px}.gc{max-width:680px}.gr{margin-top:40px}.hi{margin-top:16px}.ia{font-size:42px}.ib{line-height:52px}.ic{letter-spacing:-0.011em}.is{font-size:22px}.it{margin-top:0.92em}.iu{line-height:28px}.iz{align-items:center}.la{border-top:solid 1px #F2F2F2}.lb{border-bottom:solid 1px #F2F2F2}.lc{margin:32px 0 0}.ld{padding:3px 8px}.lm> *{margin-right:24px}.ln> :last-child{margin-right:0}.mn{margin-top:0px}.nb{margin:0}.oc{margin-top:56px}.pf{font-size:20px}.pg{margin-top:2.14em}.ph{line-height:32px}.pi{letter-spacing:-0.003em}.ps{padding-top:7px}.qk{margin-top:1.14em}.qw{display:inline-block}.rc{margin-bottom:104px}.rg{flex-direction:row}.rj{margin-bottom:0}.rk{margin-right:20px}.rz{max-width:500px}.sq{line-height:24px}.sr{letter-spacing:0}.tj{margin-bottom:72px}.tu{font-size:24px}.tv{line-height:30px}.tw{letter-spacing:-0.016em}.ue{margin:40px 0 0}.uj{padding-top:72px}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="all and (max-width: 1079.98px)">.e{display:none}.mm{margin-top:0px}.ol{margin-left:auto}.om{text-align:center}.qv{display:inline-block}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="all and (max-width: 903.98px)">.f{display:none}.ml{margin-top:0px}.qu{display:inline-block}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="all and (max-width: 727.98px)">.g{display:none}.mj{margin-top:0px}.mk{margin-right:0px}.qt{display:inline-block}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="all and (max-width: 551.98px)">.h{display:none}.s{display:flex}.t{justify-content:space-between}.bs{width:24px}.cc{margin:0 24px}.cr{height:40px}.cy{margin-bottom:44px}.dk{margin-bottom:32px}.dx{font-size:13px}.dy{line-height:20px}.eh{padding:0px 8px 1px}.fu{margin-bottom:4px}.gn{margin-top:32px}.he{margin-top:8px}.ho{font-size:32px}.hp{line-height:38px}.hq{letter-spacing:-0.014em}.ig{font-size:18px}.ih{margin-top:0.79em}.ii{line-height:24px}.iv{align-items:flex-start}.jy{flex-direction:column}.kb{margin-bottom:2px}.ko{margin:24px -24px 0}.kp{padding:0}.le> *{margin-right:8px}.lf> :last-child{margin-right:24px}.lw{margin-left:0px}.mh{margin-top:0px}.mi{margin-right:0px}.mx{margin:0}.nh{border:1px solid #F2F2F2}.ni{border-radius:99em}.nj{padding:0px 16px 0px 12px}.nk{height:38px}.nl{align-items:center}.nn svg{margin-right:8px}.ny{margin-top:40px}.or{margin-top:1.56em}.os{line-height:28px}.ot{letter-spacing:-0.003em}.po{padding-top:0}.qg{margin-top:1.34em}.qs{display:inline-block}.qy{margin-bottom:96px}.rr{margin-bottom:20px}.rs{margin-right:0}.sd{max-width:100%}.sg{font-size:24px}.sh{line-height:30px}.si{letter-spacing:-0.016em}.tf{margin-bottom:64px}.tk{font-size:20px}.tl{letter-spacing:0}.ua{margin:32px 0 0}.uf{padding-top:48px}.nm:hover{border-color:#E5E5E5}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="all and (min-width: 904px) and (max-width: 1079.98px)">.i{display:none}.bv{width:64px}.cf{margin:0 64px}.cu{height:48px}.db{margin-bottom:52px}.dn{margin-bottom:48px}.ed{font-size:14px}.ee{line-height:20px}.ek{font-size:13px}.el{padding:5px 12px}.fg{display:flex}.fx{margin-bottom:68px}.gb{max-width:680px}.gq{margin-top:40px}.hh{margin-top:16px}.hx{font-size:42px}.hy{line-height:52px}.hz{letter-spacing:-0.011em}.ip{font-size:22px}.iq{margin-top:0.92em}.ir{line-height:28px}.iy{align-items:center}.kw{border-top:solid 1px #F2F2F2}.kx{border-bottom:solid 1px #F2F2F2}.ky{margin:32px 0 0}.kz{padding:3px 8px}.lk> *{margin-right:24px}.ll> :last-child{margin-right:0}.na{margin:0}.ob{margin-top:56px}.pb{font-size:20px}.pc{margin-top:2.14em}.pd{line-height:32px}.pe{letter-spacing:-0.003em}.pr{padding-top:7px}.qj{margin-top:1.14em}.rb{margin-bottom:104px}.rh{flex-direction:row}.rl{margin-bottom:0}.rm{margin-right:20px}.sa{max-width:500px}.so{line-height:24px}.sp{letter-spacing:0}.ti{margin-bottom:72px}.tr{font-size:24px}.ts{line-height:30px}.tt{letter-spacing:-0.016em}.ud{margin:40px 0 0}.ui{padding-top:72px}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="all and (min-width: 728px) and (max-width: 903.98px)">.j{display:none}.w{display:flex}.x{justify-content:space-between}.bu{width:64px}.ce{margin:0 48px}.ct{height:48px}.da{margin-bottom:52px}.dm{margin-bottom:48px}.eb{font-size:13px}.ec{line-height:20px}.ej{padding:0px 8px 1px}.fw{margin-bottom:68px}.ga{max-width:680px}.gp{margin-top:40px}.hg{margin-top:16px}.hu{font-size:42px}.hv{line-height:52px}.hw{letter-spacing:-0.011em}.im{font-size:22px}.in{margin-top:0.92em}.io{line-height:28px}.ix{align-items:center}.ks{border-top:solid 1px #F2F2F2}.kt{border-bottom:solid 1px #F2F2F2}.ku{margin:32px 0 0}.kv{padding:3px 8px}.li> *{margin-right:24px}.lj> :last-child{margin-right:0}.mz{margin:0}.oa{margin-top:56px}.ox{font-size:20px}.oy{margin-top:2.14em}.oz{line-height:32px}.pa{letter-spacing:-0.003em}.pq{padding-top:7px}.qi{margin-top:1.14em}.ra{margin-bottom:104px}.ri{flex-direction:row}.rn{margin-bottom:0}.ro{margin-right:20px}.sb{max-width:500px}.sm{line-height:24px}.sn{letter-spacing:0}.th{margin-bottom:72px}.to{font-size:24px}.tp{line-height:30px}.tq{letter-spacing:-0.016em}.uc{margin:40px 0 0}.uh{padding-top:72px}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="all and (min-width: 552px) and (max-width: 727.98px)">.k{display:none}.u{display:flex}.v{justify-content:space-between}.bt{width:24px}.cd{margin:0 24px}.cs{height:40px}.cz{margin-bottom:44px}.dl{margin-bottom:32px}.dz{font-size:13px}.ea{line-height:20px}.ei{padding:0px 8px 1px}.fv{margin-bottom:4px}.go{margin-top:32px}.hf{margin-top:8px}.hr{font-size:32px}.hs{line-height:38px}.ht{letter-spacing:-0.014em}.ij{font-size:18px}.ik{margin-top:0.79em}.il{line-height:24px}.iw{align-items:flex-start}.jz{flex-direction:column}.kc{margin-bottom:2px}.kq{margin:24px 0 0}.kr{padding:0}.lg> *{margin-right:8px}.lh> :last-child{margin-right:8px}.lx{margin-left:0px}.my{margin:0}.no{border:1px solid #F2F2F2}.np{border-radius:99em}.nq{padding:0px 16px 0px 12px}.nr{height:38px}.ns{align-items:center}.nu svg{margin-right:8px}.nz{margin-top:40px}.ou{margin-top:1.56em}.ov{line-height:28px}.ow{letter-spacing:-0.003em}.pp{padding-top:0}.qh{margin-top:1.34em}.qz{margin-bottom:96px}.rp{margin-bottom:20px}.rq{margin-right:0}.sc{max-width:100%}.sj{font-size:24px}.sk{line-height:30px}.sl{letter-spacing:-0.016em}.tg{margin-bottom:64px}.tm{font-size:20px}.tn{letter-spacing:0}.ub{margin:32px 0 0}.ug{padding-top:48px}.nt:hover{border-color:#E5E5E5}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="print">.qq{display:none}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="(orientation: landscape) and (max-width: 903.98px)">.kl{max-height:none}</style><style type="text/css" data-fela-rehydration="560" data-fela-type="RULE" media="(prefers-reduced-motion: no-preference)">.oe{transition:transform 300ms cubic-bezier(0.2, 0, 0.2, 1)}</style></head><body><div id="root"><div class="a b c"><div class="d e f g h i j k"></div><script>document.domain = document.domain;</script><div class="l c"><div class="l m n o c"><div class="p q r s t u v w x i d y z"><a class="du ag dv bf ak b am an ao ap aq ar as at s u w i d q dw z" href="https://rsci.app.link/?%24canonical_url=https%3A%2F%2Fmedium.com%2Fp%2Fb89fa2c43f1c&amp;%7Efeature=LoOpenInAppButton&amp;%7Echannel=ShowPostUnderCollection&amp;source=---top_nav_layout_nav----------------------------------" rel="noopener follow">Open in app<svg xmlns="http://www.w3.org/2000/svg" width="10" height="10" fill="none" viewBox="0 0 10 10" class="dt"><path fill="currentColor" d="M.985 8.485a.375.375 0 1 0 .53.53zM8.75 1.25h.375A.375.375 0 0 0 8.75.875zM8.375 6.5a.375.375 0 1 0 .75 0zM3.5.875a.375.375 0 1 0 0 .75zm-1.985 8.14 7.5-7.5-.53-.53-7.5 7.5zm6.86-7.765V6.5h.75V1.25zM3.5 1.625h5.25v-.75H3.5z"></path></svg></a><div class="ab q"><p class="bf b dx dy dz ea eb ec ed ee ef eg du"><span><button class="bf b dx dy eh dz ea ei eb ec ej ek ee el em eg eo ep eq er es et eu ev ew ex ey ez fa fb fc fd bm fe ff" data-testid="headerSignUpButton">Sign up</button></span></p><div class="ax l"><p class="bf b dx dy dz ea eb ec ed ee ef eg du"><span><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="headerSignInButton" rel="noopener follow" href="/m/signin?operation=login&amp;redirect=https%3A%2F%2Fmedium.com%2Fmobile-app-development-publication%2Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c&amp;source=post_page---top_nav_layout_nav-----------------------global_nav-----------">Sign in</a></span></p></div></div></div><div class="p q r ab ac"><div class="ab q ae"><a class="af ag ah ai aj ak al am an ao ap aq ar as at ab" aria-label="Homepage" data-testid="headerMediumLogo" rel="noopener follow" href="/?source=---top_nav_layout_nav----------------------------------"><svg xmlns="http://www.w3.org/2000/svg" width="719" height="160" fill="none" viewBox="0 0 719 160" class="au av aw"><path fill="#242424" d="m174.104 9.734.215-.047V8.02H130.39L89.6 103.89 48.81 8.021H1.472v1.666l.212.047c8.018 1.81 12.09 4.509 12.09 14.242V137.93c0 9.734-4.087 12.433-12.106 14.243l-.212.047v1.671h32.118v-1.665l-.213-.048c-8.018-1.809-12.089-4.509-12.089-14.242V30.586l52.399 123.305h2.972l53.925-126.743V140.75c-.687 7.688-4.721 10.062-11.982 11.701l-.215.05v1.652h55.948v-1.652l-.215-.05c-7.269-1.639-11.4-4.013-12.087-11.701l-.037-116.774h.037c0-9.733 4.071-12.432 12.087-14.242m25.555 75.488c.915-20.474 8.268-35.252 20.606-35.507 3.806.063 6.998 1.312 9.479 3.714 5.272 5.118 7.751 15.812 7.368 31.793zm-.553 5.77h65.573v-.275c-.186-15.656-4.721-27.834-13.466-36.196-7.559-7.227-18.751-11.203-30.507-11.203h-.263c-6.101 0-13.584 1.48-18.909 4.16-6.061 2.807-11.407 7.003-15.855 12.511-7.161 8.874-11.499 20.866-12.554 34.343q-.05.606-.092 1.212a50 50 0 0 0-.065 1.151 85.807 85.807 0 0 0-.094 5.689c.71 30.524 17.198 54.917 46.483 54.917 25.705 0 40.675-18.791 44.407-44.013l-1.886-.664c-6.557 13.556-18.334 21.771-31.738 20.769-18.297-1.369-32.314-19.922-31.042-42.395m139.722 41.359c-2.151 5.101-6.639 7.908-12.653 7.908s-11.513-4.129-15.418-11.63c-4.197-8.053-6.405-19.436-6.405-32.92 0-28.067 8.729-46.22 22.24-46.22 5.657 0 10.111 2.807 12.236 7.704zm43.499 20.008c-8.019-1.897-12.089-4.722-12.089-14.951V1.309l-48.716 14.353v1.757l.299-.024c6.72-.543 11.278.386 13.925 2.83 2.072 1.915 3.082 4.853 3.082 8.987v18.66c-4.803-3.067-10.516-4.56-17.448-4.56-14.059 0-26.909 5.92-36.176 16.672-9.66 11.205-14.767 26.518-14.767 44.278-.003 31.72 15.612 53.039 38.851 53.039 13.595 0 24.533-7.449 29.54-20.013v16.865h43.711v-1.746zM424.1 19.819c0-9.904-7.468-17.374-17.375-17.374-9.859 0-17.573 7.632-17.573 17.374s7.721 17.374 17.573 17.374c9.907 0 17.375-7.47 17.375-17.374m11.499 132.546c-8.019-1.897-12.089-4.722-12.089-14.951h-.035V43.635l-43.714 12.551v1.705l.263.024c9.458.842 12.047 4.1 12.047 15.152v81.086h43.751v-1.746zm112.013 0c-8.018-1.897-12.089-4.722-12.089-14.951V43.635l-41.621 12.137v1.71l.246.026c7.733.813 9.967 4.257 9.967 15.36v59.279c-2.578 5.102-7.415 8.131-13.274 8.336-9.503 0-14.736-6.419-14.736-18.073V43.638l-43.714 12.55v1.703l.262.024c9.459.84 12.05 4.097 12.05 15.152v50.17a56.3 56.3 0 0 0 .91 10.444l.787 3.423c3.701 13.262 13.398 20.197 28.59 20.197 12.868 0 24.147-7.966 29.115-20.43v17.311h43.714v-1.747zm169.818 1.788v-1.749l-.213-.05c-8.7-2.006-12.089-5.789-12.089-13.49v-63.79c0-19.89-11.171-31.761-29.883-31.761-13.64 0-25.141 7.882-29.569 20.16-3.517-13.01-13.639-20.16-28.606-20.16-13.146 0-23.449 6.938-27.869 18.657V43.643L545.487 55.68v1.715l.263.024c9.345.829 12.047 4.181 12.047 14.95v81.784h40.787v-1.746l-.215-.053c-6.941-1.631-9.181-4.606-9.181-12.239V66.998c1.836-4.289 5.537-9.37 12.853-9.37 9.086 0 13.692 6.296 13.692 18.697v77.828h40.797v-1.746l-.215-.053c-6.94-1.631-9.18-4.606-9.18-12.239V75.066a42 42 0 0 0-.578-7.26c1.947-4.661 5.86-10.177 13.475-10.177 9.214 0 13.691 6.114 13.691 18.696v77.828z"></path></svg></a><div class="ax h"><div class="ab ay az ba bb q bc bd"><div class="bm" aria-hidden="false" aria-describedby="searchResults" aria-labelledby="searchResults"></div><div class="bn bo ab"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="none" viewBox="0 0 24 24"><path fill="currentColor" fill-rule="evenodd" d="M4.092 11.06a6.95 6.95 0 1 1 13.9 0 6.95 6.95 0 0 1-13.9 0m6.95-8.05a8.05 8.05 0 1 0 5.13 14.26l3.75 3.75a.56.56 0 1 0 .79-.79l-3.73-3.73A8.05 8.05 0 0 0 11.042 3z" clip-rule="evenodd"></path></svg></div><input role="combobox" aria-controls="searchResults" aria-expanded="false" aria-label="search" data-testid="headerSearchInput" tabindex="0" class="ay be bf bg z bh bi bj bk bl" placeholder="Search" value=""/></div></div></div><div class="h k w fg fh"><div class="fi ab"><span><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="headerWriteButton" rel="noopener follow" href="/m/signin?operation=register&amp;redirect=https%3A%2F%2Fmedium.com%2Fnew-story&amp;source=---top_nav_layout_nav-----------------------new_post_topnav-----------"><div class="bf b bg z du fj fk ab q fl fm"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="none" viewBox="0 0 24 24" aria-label="Write"><path fill="currentColor" d="M14 4a.5.5 0 0 0 0-1zm7 6a.5.5 0 0 0-1 0zm-7-7H4v1h10zM3 4v16h1V4zm1 17h16v-1H4zm17-1V10h-1v10zm-1 1a1 1 0 0 0 1-1h-1zM3 20a1 1 0 0 0 1 1v-1zM4 3a1 1 0 0 0-1 1h1z"></path><path stroke="currentColor" d="m17.5 4.5-8.458 8.458a.25.25 0 0 0-.06.098l-.824 2.47a.25.25 0 0 0 .316.316l2.47-.823a.25.25 0 0 0 .098-.06L19.5 6.5m-2-2 2.323-2.323a.25.25 0 0 1 .354 0l1.646 1.646a.25.25 0 0 1 0 .354L19.5 6.5m-2-2 2 2"></path></svg><div class="dt l">Write</div></div></a></span></div></div><div class="k j i d"><div class="fi ab"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="headerSearchButton" rel="noopener follow" href="/search?source=---top_nav_layout_nav----------------------------------"><div class="bf b bg z du fj fk ab q fl fm"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="none" viewBox="0 0 24 24" aria-label="Search"><path fill="currentColor" fill-rule="evenodd" d="M4.092 11.06a6.95 6.95 0 1 1 13.9 0 6.95 6.95 0 0 1-13.9 0m6.95-8.05a8.05 8.05 0 1 0 5.13 14.26l3.75 3.75a.56.56 0 1 0 .79-.79l-3.73-3.73A8.05 8.05 0 0 0 11.042 3z" clip-rule="evenodd"></path></svg></div></a></div></div><div class="fi h k j"><div class="ab q"><p class="bf b dx dy dz ea eb ec ed ee ef eg du"><span><button class="bf b dx dy eh dz ea ei eb ec ej ek ee el em eg eo ep eq er es et eu ev ew ex ey ez fa fb fc fd bm fe ff" data-testid="headerSignUpButton">Sign up</button></span></p><div class="ax l"><p class="bf b dx dy dz ea eb ec ed ee ef eg du"><span><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="headerSignInButton" rel="noopener follow" href="/m/signin?operation=login&amp;redirect=https%3A%2F%2Fmedium.com%2Fmobile-app-development-publication%2Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c&amp;source=post_page---top_nav_layout_nav-----------------------global_nav-----------">Sign in</a></span></p></div></div></div><div class="l" aria-hidden="false"><button class="ay fn am ab q ao fo fp fq" aria-label="user options menu" data-testid="headerUserIcon"><div class="l fj"><img alt="" class="l fd by bz ca cx" src="https://miro.medium.com/v2/resize:fill:64:64/1*dmbNkD5D-u45r44go_cf0g.png" width="32" height="32" loading="lazy" role="presentation"/><div class="fr by l bz ca fs n ay ft"></div></div></button></div></div></div><div class="l"><div class="fu fv fw fx fy l"><div class="ab cb"><div class="ci bh fz ga gb gc"></div></div><article class="meteredContent"><div class="l"><div class="l"><span class="l"></span><section><div><div class="fs gi gj gk gl gm"></div><div><div class="speechify-ignore l"><div class="gn go gp gq gr l"></div><div class="ab cb"><div class="ci bh fz ga gb gc"><div class="cl ab gs"><div class="gv ab"><div class="bm" aria-hidden="false"><button class="l ay ao am" aria-label="Member-only story"><div class="h k j i d"><div><div class="bm" aria-hidden="false"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="none" viewBox="0 0 64 64"><path fill="#FFC017" d="m39.637 40.831-5.771 15.871a1.99 1.99 0 0 1-3.732 0l-5.771-15.87a2.02 2.02 0 0 0-1.194-1.195L7.298 33.866a1.99 1.99 0 0 1 0-3.732l15.87-5.771a2.02 2.02 0 0 0 1.195-1.194l5.771-15.871a1.99 1.99 0 0 1 3.732 0l5.771 15.87a2.02 2.02 0 0 0 1.194 1.195l15.871 5.771a1.99 1.99 0 0 1 0 3.732l-15.87 5.771a2.02 2.02 0 0 0-1.195 1.194"></path></svg></div></div></div><div class="s u w fg fh q"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="none" viewBox="0 0 64 64" class="gt gu"><path fill="#FFC017" d="m39.637 40.831-5.771 15.871a1.99 1.99 0 0 1-3.732 0l-5.771-15.87a2.02 2.02 0 0 0-1.194-1.195L7.298 33.866a1.99 1.99 0 0 1 0-3.732l15.87-5.771a2.02 2.02 0 0 0 1.195-1.194l5.771-15.871a1.99 1.99 0 0 1 3.732 0l5.771 15.87a2.02 2.02 0 0 0 1.194 1.195l15.871 5.771a1.99 1.99 0 0 1 0 3.732l-15.87 5.771a2.02 2.02 0 0 0-1.195 1.194"></path></svg><p class="bf b bg z du">Member-only story</p></div></button></div></div></div></div></div></div></div><div class="gw gx gy gz ha"><div class="ab cb"><div class="ci bh fz ga gb gc"><h2 id="2cfe" class="hb hc hd bf b dv he hf hg hh hi hj du hk" aria-label="kicker paragraph">Learn Android Development</h2><div><h1 id="7b48" class="pw-post-title hl hm hd bf hn ho hp hq hr hs ht hu hv hw hx hy hz ia ib ic id ie bk" data-testid="storyTitle">Demystify Jetpack Compose Layout Constraint and Size Setting</h1></div><div><h2 id="6b40" class="pw-subtitle-paragraph if hm hd bf b ig ih ii ij ik il im in io ip iq ir is it iu cq du">Mastering one of the most confusing Jetpack Compose APIs I encountered</h2><div><div class="speechify-ignore ab cp"><div class="speechify-ignore bh l"><div class="iv iw ix iy iz ab"><div><div class="ab ja"><div><div class="bm" aria-hidden="false"><a rel="noopener follow" href="/@elye-project?source=post_page---byline--b89fa2c43f1c--------------------------------"><div class="l jb jc by jd je"><div class="l fj"><img alt="Elye - A One Eye Dev By His Grace" class="l fd by dd de cx" src="https://miro.medium.com/v2/resize:fill:88:88/1*0wVPGGR_3FMoPVGzT4nbTw.png" width="44" height="44" loading="lazy" data-testid="authorPhoto"/><div class="jf by l dd de fs n jg ft"></div></div></div></a></div></div><div class="jh ab fj"><div><div class="bm" aria-hidden="false"><a href="https://medium.com/mobile-app-development-publication?source=post_page---byline--b89fa2c43f1c--------------------------------" rel="noopener follow"><div class="l ji jj by jd jk"><div class="l fj"><img alt="Mobile App Development Publication" class="l fd by br jl cx" src="https://miro.medium.com/v2/resize:fill:48:48/1*r5bO5bEjNCKLt6fKZbPdCA.png" width="24" height="24" loading="lazy" data-testid="publicationPhoto"/><div class="jf by l br jl fs n jg ft"></div></div></div></a></div></div></div></div></div><div class="bn bh l"><div class="ab"><div style="flex:1"><span class="bf b bg z bk"><div class="jm ab q"><div class="ab q jn"><div class="ab q"><div><div class="bm" aria-hidden="false"><p class="bf b jo jp bk"><a class="af ag ah ai aj ak al am an ao ap aq ar jq" data-testid="authorName" rel="noopener follow" href="/@elye-project?source=post_page---byline--b89fa2c43f1c--------------------------------">Elye - A One Eye Dev By His Grace</a></p></div></div></div><span class="jr js" aria-hidden="true"><span class="bf b bg z du">·</span></span><p class="bf b jo jp du"><span><a class="jt ju ah ai aj ak al am an ao ap aq ar ex jv jw" rel="noopener follow" href="/m/signin?actionUrl=https%3A%2F%2Fmedium.com%2F_%2Fsubscribe%2Fuser%2F5742b4fcf89e&amp;operation=register&amp;redirect=https%3A%2F%2Fmedium.com%2Fmobile-app-development-publication%2Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c&amp;user=Elye+-+A+One+Eye+Dev+By+His+Grace&amp;userId=5742b4fcf89e&amp;source=post_page-5742b4fcf89e--byline--b89fa2c43f1c---------------------post_header-----------">Follow</a></span></p></div></div></span></div></div><div class="l jx"><span class="bf b bg z du"><div class="ab cn jy jz ka"><div class="kb kc ab"><div class="bf b bg z du ab kd"><span class="gt l jx">Published in</span><div><div class="l" aria-hidden="false"><a class="af ag ah ai aj ak al am an ao ap aq ar jq ab q" data-testid="publicationName" href="https://medium.com/mobile-app-development-publication?source=post_page---byline--b89fa2c43f1c--------------------------------" rel="noopener follow"><p class="bf b bg z ke kf kg kh ki kj kk kl bk">Mobile App Development Publication</p></a></div></div></div><div class="h k"><span class="jr js" aria-hidden="true"><span class="bf b bg z du">·</span></span></div></div><span class="bf b bg z du"><div class="ab ae"><span data-testid="storyReadTime">11 min read</span><div class="km kn l" aria-hidden="true"><span class="l" aria-hidden="true"><span class="bf b bg z du">·</span></span></div><span data-testid="storyPublishDate">Jun 27, 2023</span></div></span></div></span></div></div></div><div class="ab cp ko kp kq kr ks kt ku kv kw kx ky kz la lb lc ld"><div class="h k w fg fh q"><div class="lt l"><div class="ab q lu lv"><div class="pw-multi-vote-icon fj gt lw lx ly"><span><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="headerClapButton" rel="noopener follow" href="/m/signin?actionUrl=https%3A%2F%2Fmedium.com%2F_%2Fvote%2Fmobile-app-development-publication%2Fb89fa2c43f1c&amp;operation=register&amp;redirect=https%3A%2F%2Fmedium.com%2Fmobile-app-development-publication%2Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c&amp;user=Elye+-+A+One+Eye+Dev+By+His+Grace&amp;userId=5742b4fcf89e&amp;source=---header_actions--b89fa2c43f1c---------------------clap_footer-----------"><div><div class="bm" aria-hidden="false"><div class="lz ao ma mb mc md am me mf mg ly"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" aria-label="clap"><path fill-rule="evenodd" d="M11.37.828 12 3.282l.63-2.454zM13.916 3.953l1.523-2.112-1.184-.39zM8.589 1.84l1.522 2.112-.337-2.501zM18.523 18.92c-.86.86-1.75 1.246-2.62 1.33a6 6 0 0 0 .407-.372c2.388-2.389 2.86-4.951 1.399-7.623l-.912-1.603-.79-1.672c-.26-.56-.194-.98.203-1.288a.7.7 0 0 1 .546-.132c.283.046.546.231.728.5l2.363 4.157c.976 1.624 1.141 4.237-1.324 6.702m-10.999-.438L3.37 14.328a.828.828 0 0 1 .585-1.408.83.83 0 0 1 .585.242l2.158 2.157a.365.365 0 0 0 .516-.516l-2.157-2.158-1.449-1.449a.826.826 0 0 1 1.167-1.17l3.438 3.44a.363.363 0 0 0 .516 0 .364.364 0 0 0 0-.516L5.293 9.513l-.97-.97a.826.826 0 0 1 0-1.166.84.84 0 0 1 1.167 0l.97.968 3.437 3.436a.36.36 0 0 0 .517 0 .366.366 0 0 0 0-.516L6.977 7.83a.82.82 0 0 1-.241-.584.82.82 0 0 1 .824-.826c.219 0 .43.087.584.242l5.787 5.787a.366.366 0 0 0 .587-.415l-1.117-2.363c-.26-.56-.194-.98.204-1.289a.7.7 0 0 1 .546-.132c.283.046.545.232.727.501l2.193 3.86c1.302 2.38.883 4.59-1.277 6.75-1.156 1.156-2.602 1.627-4.19 1.367-1.418-.236-2.866-1.033-4.079-2.246M10.75 5.971l2.12 2.12c-.41.502-.465 1.17-.128 1.89l.22.465-3.523-3.523a.8.8 0 0 1-.097-.368c0-.22.086-.428.241-.584a.847.847 0 0 1 1.167 0m7.355 1.705c-.31-.461-.746-.758-1.23-.837a1.44 1.44 0 0 0-1.11.275c-.312.24-.505.543-.59.881a1.74 1.74 0 0 0-.906-.465 1.47 1.47 0 0 0-.82.106l-2.182-2.182a1.56 1.56 0 0 0-2.2 0 1.54 1.54 0 0 0-.396.701 1.56 1.56 0 0 0-2.21-.01 1.55 1.55 0 0 0-.416.753c-.624-.624-1.649-.624-2.237-.037a1.557 1.557 0 0 0 0 2.2c-.239.1-.501.238-.715.453a1.56 1.56 0 0 0 0 2.2l.516.515a1.556 1.556 0 0 0-.753 2.615L7.01 19c1.32 1.319 2.909 2.189 4.475 2.449q.482.08.971.08c.85 0 1.653-.198 2.393-.579.231.033.46.054.686.054 1.266 0 2.457-.52 3.505-1.567 2.763-2.763 2.552-5.734 1.439-7.586z" clip-rule="evenodd"></path></svg></div></div></div></a></span></div><div class="pw-multi-vote-count l mh mi mj mk ml mm mn"><p class="bf b dv z du"><span class="mo">--</span></p></div></div></div><div><div class="bm" aria-hidden="false"><button class="ao lz mp mq ab q fk mr ms" aria-label="responses"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" class="mt"><path d="M18.006 16.803c1.533-1.456 2.234-3.325 2.234-5.321C20.24 7.357 16.709 4 12.191 4S4 7.357 4 11.482c0 4.126 3.674 7.482 8.191 7.482.817 0 1.622-.111 2.393-.327.231.2.48.391.744.559 1.06.693 2.203 1.044 3.399 1.044.224-.008.4-.112.486-.287a.49.49 0 0 0-.042-.518c-.495-.67-.845-1.364-1.04-2.057a4 4 0 0 1-.125-.598zm-3.122 1.055-.067-.223-.315.096a8 8 0 0 1-2.311.338c-4.023 0-7.292-2.955-7.292-6.587 0-3.633 3.269-6.588 7.292-6.588 4.014 0 7.112 2.958 7.112 6.593 0 1.794-.608 3.469-2.027 4.72l-.195.168v.255c0 .056 0 .151.016.295.025.231.081.478.154.733.154.558.398 1.117.722 1.659a5.3 5.3 0 0 1-2.165-.845c-.276-.176-.714-.383-.941-.59z"></path></svg></button></div></div></div><div class="ab q le lf lg lh li lj lk ll lm ln lo lp lq lr ls"><div class="mu k j i d"></div><div class="h k"><div><div class="bm" aria-hidden="false"><span><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="headerBookmarkButton" rel="noopener follow" href="/m/signin?actionUrl=https%3A%2F%2Fmedium.com%2F_%2Fbookmark%2Fp%2Fb89fa2c43f1c&amp;operation=register&amp;redirect=https%3A%2F%2Fmedium.com%2Fmobile-app-development-publication%2Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c&amp;source=---header_actions--b89fa2c43f1c---------------------bookmark_footer-----------"><svg xmlns="http://www.w3.org/2000/svg" width="25" height="25" fill="none" viewBox="0 0 25 25" class="du mv" aria-label="Add to list bookmark button"><path fill="currentColor" d="M18 2.5a.5.5 0 0 1 1 0V5h2.5a.5.5 0 0 1 0 1H19v2.5a.5.5 0 1 1-1 0V6h-2.5a.5.5 0 0 1 0-1H18zM7 7a1 1 0 0 1 1-1h3.5a.5.5 0 0 0 0-1H8a2 2 0 0 0-2 2v14a.5.5 0 0 0 .805.396L12.5 17l5.695 4.396A.5.5 0 0 0 19 21v-8.5a.5.5 0 0 0-1 0v7.485l-5.195-4.012a.5.5 0 0 0-.61 0L7 19.985z"></path></svg></a></span></div></div></div><div class="fd mw cn"><div class="l ae"><div class="ab cb"><div class="mx my mz na nb nc ci bh"><div class="ab"></div></div></div></div></div><div class="bm" aria-hidden="false" aria-describedby="postFooterSocialMenu" aria-labelledby="postFooterSocialMenu"><div><div class="bm" aria-hidden="false"><button aria-controls="postFooterSocialMenu" aria-expanded="false" aria-label="Share Post" data-testid="headerSocialShareButton" class="af fk ah ai aj ak al nd an ao ap ex ne nf ms ng nh ni nj nk s nl nm nn no np nq nr u ns nt nu"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="none" viewBox="0 0 24 24"><path fill="currentColor" fill-rule="evenodd" d="M15.218 4.931a.4.4 0 0 1-.118.132l.012.006a.45.45 0 0 1-.292.074.5.5 0 0 1-.3-.13l-2.02-2.02v7.07c0 .28-.23.5-.5.5s-.5-.22-.5-.5v-7.04l-2 2a.45.45 0 0 1-.57.04h-.02a.4.4 0 0 1-.16-.3.4.4 0 0 1 .1-.32l2.8-2.8a.5.5 0 0 1 .7 0l2.8 2.79a.42.42 0 0 1 .068.498m-.106.138.008.004v-.01zM16 7.063h1.5a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2h-11c-1.1 0-2-.9-2-2v-10a2 2 0 0 1 2-2H8a.5.5 0 0 1 .35.15.5.5 0 0 1 .15.35.5.5 0 0 1-.15.35.5.5 0 0 1-.35.15H6.4c-.5 0-.9.4-.9.9v10.2a.9.9 0 0 0 .9.9h11.2c.5 0 .9-.4.9-.9v-10.2c0-.5-.4-.9-.9-.9H16a.5.5 0 0 1 0-1" clip-rule="evenodd"></path></svg><div class="j i d"><p class="bf b bg z du">Share</p></div></button></div></div></div></div></div></div></div></div></div><figure class="ny nz oa ob oc od nv nw paragraph-image"><div role="button" tabindex="0" class="oe of fj og bh oh"><div class="nv nw nx"><picture><source srcSet="https://miro.medium.com/v2/resize:fit:640/format:webp/0*-P2EKQ3GDZRnXG2A 640w, https://miro.medium.com/v2/resize:fit:720/format:webp/0*-P2EKQ3GDZRnXG2A 720w, https://miro.medium.com/v2/resize:fit:750/format:webp/0*-P2EKQ3GDZRnXG2A 750w, https://miro.medium.com/v2/resize:fit:786/format:webp/0*-P2EKQ3GDZRnXG2A 786w, https://miro.medium.com/v2/resize:fit:828/format:webp/0*-P2EKQ3GDZRnXG2A 828w, https://miro.medium.com/v2/resize:fit:1100/format:webp/0*-P2EKQ3GDZRnXG2A 1100w, https://miro.medium.com/v2/resize:fit:1400/format:webp/0*-P2EKQ3GDZRnXG2A 1400w" sizes="(min-resolution: 4dppx) and (max-width: 700px) 50vw, (-webkit-min-device-pixel-ratio: 4) and (max-width: 700px) 50vw, (min-resolution: 3dppx) and (max-width: 700px) 67vw, (-webkit-min-device-pixel-ratio: 3) and (max-width: 700px) 65vw, (min-resolution: 2.5dppx) and (max-width: 700px) 80vw, (-webkit-min-device-pixel-ratio: 2.5) and (max-width: 700px) 80vw, (min-resolution: 2dppx) and (max-width: 700px) 100vw, (-webkit-min-device-pixel-ratio: 2) and (max-width: 700px) 100vw, 700px" type="image/webp"/><source data-testid="og" srcSet="https://miro.medium.com/v2/resize:fit:640/0*-P2EKQ3GDZRnXG2A 640w, https://miro.medium.com/v2/resize:fit:720/0*-P2EKQ3GDZRnXG2A 720w, https://miro.medium.com/v2/resize:fit:750/0*-P2EKQ3GDZRnXG2A 750w, https://miro.medium.com/v2/resize:fit:786/0*-P2EKQ3GDZRnXG2A 786w, https://miro.medium.com/v2/resize:fit:828/0*-P2EKQ3GDZRnXG2A 828w, https://miro.medium.com/v2/resize:fit:1100/0*-P2EKQ3GDZRnXG2A 1100w, https://miro.medium.com/v2/resize:fit:1400/0*-P2EKQ3GDZRnXG2A 1400w" sizes="(min-resolution: 4dppx) and (max-width: 700px) 50vw, (-webkit-min-device-pixel-ratio: 4) and (max-width: 700px) 50vw, (min-resolution: 3dppx) and (max-width: 700px) 67vw, (-webkit-min-device-pixel-ratio: 3) and (max-width: 700px) 65vw, (min-resolution: 2.5dppx) and (max-width: 700px) 80vw, (-webkit-min-device-pixel-ratio: 2.5) and (max-width: 700px) 80vw, (min-resolution: 2dppx) and (max-width: 700px) 100vw, (-webkit-min-device-pixel-ratio: 2) and (max-width: 700px) 100vw, 700px"/><img alt="" class="bh nc oi c" width="700" height="467" loading="lazy" role="presentation"/></picture></div></div><figcaption class="oj ff ok nv nw ol om bf b bg z du">Photo by <a class="af on" href="https://unsplash.com/@bahtiarirham?utm_source=medium&amp;utm_medium=referral" rel="noopener ugc nofollow" target="_blank">Irham Bahtiar</a> on <a class="af on" href="https://unsplash.com/?utm_source=medium&amp;utm_medium=referral" rel="noopener ugc nofollow" target="_blank">Unsplash</a></figcaption></figure><p id="c6ad" class="pw-post-body-paragraph oo op hd oq b ig or os ot ij ou ov ow ox oy oz pa pb pc pd pe pf pg ph pi pj gw bk pk"><span class="l pl pm pn bo po pp pq pr ps fj">I</span> shared about how one can <a class="af on" rel="noopener" href="/mobile-app-development-publication/negative-padding-for-jetpack-compose-made-possible-c82283d15564">support negative padding in Jetpack Compose</a>. The best solution used is to use <a class="af on" rel="noopener" href="/mobile-app-development-publication/jetpack-compose-custom-layout-made-easy-b5743f8cc82c">Jetpack Compose Custom Layout</a> Modifier.</p><p id="418a" class="pw-post-body-paragraph oo op hd oq b ig or os ot ij ou ov ow ox oy oz pa pb pc pd pe pf pg ph pi pj gw bk">However, although the code seems clear, the logic behind how that happened is most confusing for me.</p><p id="140c" class="pw-post-body-paragraph oo op hd oq b ig or os ot ij ou ov ow ox oy oz pa pb pc pd pe pf pg ph pi pj gw bk">Take for example the below divider, where we change the layout width</p><pre class="ny nz oa ob oc pt pu pv bp pw bb bk"><span id="0f92" class="px py hd pu b bg pz qa l qb qc"> @Composable<br/> private fun DividerLayoutWidthChanged(layoutWidth: Int) {<br/> Divider(modifier = Modifier<br/> .height(20.dp)<br/> .layout { measurable, constraints -&gt;<br/> val placeable = measurable.measure(constraints)<br/> layout(<br/> width = layoutWidth.dp.roundToPx(),<br/> height = placeable.height<br/> ) { placeable.place(0, 0) }<br/> }<br/> )<br/> }</span></pre><p id="1013" class="pw-post-body-paragraph oo op hd oq b ig or os ot ij ou ov ow ox oy oz pa pb pc pd pe pf pg ph pi pj gw bk">As we modify the width, we thought the divider’s length would change. But it didn’t. Instead, confusingly 😕</p><ul class=""><li id="796c" class="oo op hd oq b ig or os ot ij ou ov ow ox oy oz pa pb pc pd pe pf pg ph pi pj qd qe qf bk">It just got moved around, like placement functionality.</li><li id="b9d4" class="oo op hd oq b ig qg os ot ij qh ov ow ox qi oz pa pb qj pd pe pf qk ph pi pj qd qe qf bk">And sometimes, no visual different change as we change the width size.</li></ul></div></div></div></div></section></div></div></article></div><div class="l"></div><footer class="ql qm qn qo gv ab q qp jk c"><div class="l ae"><div class="ab cb"><div class="ci bh fz ga gb gc"><div class="ab cp qq"><div class="ab q lu"><div class="qr l"><span class="l qs qt qu e d"><div class="ab q lu lv"><div class="pw-multi-vote-icon fj gt lw lx ly"><span><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="footerClapButton" rel="noopener follow" href="/m/signin?actionUrl=https%3A%2F%2Fmedium.com%2F_%2Fvote%2Fmobile-app-development-publication%2Fb89fa2c43f1c&amp;operation=register&amp;redirect=https%3A%2F%2Fmedium.com%2Fmobile-app-development-publication%2Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c&amp;user=Elye+-+A+One+Eye+Dev+By+His+Grace&amp;userId=5742b4fcf89e&amp;source=---footer_actions--b89fa2c43f1c---------------------clap_footer-----------"><div><div class="bm" aria-hidden="false"><div class="lz ao ma mb mc md am me mf mg ly"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" aria-label="clap"><path fill-rule="evenodd" d="M11.37.828 12 3.282l.63-2.454zM13.916 3.953l1.523-2.112-1.184-.39zM8.589 1.84l1.522 2.112-.337-2.501zM18.523 18.92c-.86.86-1.75 1.246-2.62 1.33a6 6 0 0 0 .407-.372c2.388-2.389 2.86-4.951 1.399-7.623l-.912-1.603-.79-1.672c-.26-.56-.194-.98.203-1.288a.7.7 0 0 1 .546-.132c.283.046.546.231.728.5l2.363 4.157c.976 1.624 1.141 4.237-1.324 6.702m-10.999-.438L3.37 14.328a.828.828 0 0 1 .585-1.408.83.83 0 0 1 .585.242l2.158 2.157a.365.365 0 0 0 .516-.516l-2.157-2.158-1.449-1.449a.826.826 0 0 1 1.167-1.17l3.438 3.44a.363.363 0 0 0 .516 0 .364.364 0 0 0 0-.516L5.293 9.513l-.97-.97a.826.826 0 0 1 0-1.166.84.84 0 0 1 1.167 0l.97.968 3.437 3.436a.36.36 0 0 0 .517 0 .366.366 0 0 0 0-.516L6.977 7.83a.82.82 0 0 1-.241-.584.82.82 0 0 1 .824-.826c.219 0 .43.087.584.242l5.787 5.787a.366.366 0 0 0 .587-.415l-1.117-2.363c-.26-.56-.194-.98.204-1.289a.7.7 0 0 1 .546-.132c.283.046.545.232.727.501l2.193 3.86c1.302 2.38.883 4.59-1.277 6.75-1.156 1.156-2.602 1.627-4.19 1.367-1.418-.236-2.866-1.033-4.079-2.246M10.75 5.971l2.12 2.12c-.41.502-.465 1.17-.128 1.89l.22.465-3.523-3.523a.8.8 0 0 1-.097-.368c0-.22.086-.428.241-.584a.847.847 0 0 1 1.167 0m7.355 1.705c-.31-.461-.746-.758-1.23-.837a1.44 1.44 0 0 0-1.11.275c-.312.24-.505.543-.59.881a1.74 1.74 0 0 0-.906-.465 1.47 1.47 0 0 0-.82.106l-2.182-2.182a1.56 1.56 0 0 0-2.2 0 1.54 1.54 0 0 0-.396.701 1.56 1.56 0 0 0-2.21-.01 1.55 1.55 0 0 0-.416.753c-.624-.624-1.649-.624-2.237-.037a1.557 1.557 0 0 0 0 2.2c-.239.1-.501.238-.715.453a1.56 1.56 0 0 0 0 2.2l.516.515a1.556 1.556 0 0 0-.753 2.615L7.01 19c1.32 1.319 2.909 2.189 4.475 2.449q.482.08.971.08c.85 0 1.653-.198 2.393-.579.231.033.46.054.686.054 1.266 0 2.457-.52 3.505-1.567 2.763-2.763 2.552-5.734 1.439-7.586z" clip-rule="evenodd"></path></svg></div></div></div></a></span></div><div class="pw-multi-vote-count l mh mi mj mk ml mm mn"><p class="bf b dv z du"><span class="mo">--</span></p></div></div></span><span class="l h g f qv qw"><div class="ab q lu lv"><div class="pw-multi-vote-icon fj gt lw lx ly"><span><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="footerClapButton" rel="noopener follow" href="/m/signin?actionUrl=https%3A%2F%2Fmedium.com%2F_%2Fvote%2Fmobile-app-development-publication%2Fb89fa2c43f1c&amp;operation=register&amp;redirect=https%3A%2F%2Fmedium.com%2Fmobile-app-development-publication%2Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c&amp;user=Elye+-+A+One+Eye+Dev+By+His+Grace&amp;userId=5742b4fcf89e&amp;source=---footer_actions--b89fa2c43f1c---------------------clap_footer-----------"><div><div class="bm" aria-hidden="false"><div class="lz ao ma mb mc md am me mf mg ly"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" aria-label="clap"><path fill-rule="evenodd" d="M11.37.828 12 3.282l.63-2.454zM13.916 3.953l1.523-2.112-1.184-.39zM8.589 1.84l1.522 2.112-.337-2.501zM18.523 18.92c-.86.86-1.75 1.246-2.62 1.33a6 6 0 0 0 .407-.372c2.388-2.389 2.86-4.951 1.399-7.623l-.912-1.603-.79-1.672c-.26-.56-.194-.98.203-1.288a.7.7 0 0 1 .546-.132c.283.046.546.231.728.5l2.363 4.157c.976 1.624 1.141 4.237-1.324 6.702m-10.999-.438L3.37 14.328a.828.828 0 0 1 .585-1.408.83.83 0 0 1 .585.242l2.158 2.157a.365.365 0 0 0 .516-.516l-2.157-2.158-1.449-1.449a.826.826 0 0 1 1.167-1.17l3.438 3.44a.363.363 0 0 0 .516 0 .364.364 0 0 0 0-.516L5.293 9.513l-.97-.97a.826.826 0 0 1 0-1.166.84.84 0 0 1 1.167 0l.97.968 3.437 3.436a.36.36 0 0 0 .517 0 .366.366 0 0 0 0-.516L6.977 7.83a.82.82 0 0 1-.241-.584.82.82 0 0 1 .824-.826c.219 0 .43.087.584.242l5.787 5.787a.366.366 0 0 0 .587-.415l-1.117-2.363c-.26-.56-.194-.98.204-1.289a.7.7 0 0 1 .546-.132c.283.046.545.232.727.501l2.193 3.86c1.302 2.38.883 4.59-1.277 6.75-1.156 1.156-2.602 1.627-4.19 1.367-1.418-.236-2.866-1.033-4.079-2.246M10.75 5.971l2.12 2.12c-.41.502-.465 1.17-.128 1.89l.22.465-3.523-3.523a.8.8 0 0 1-.097-.368c0-.22.086-.428.241-.584a.847.847 0 0 1 1.167 0m7.355 1.705c-.31-.461-.746-.758-1.23-.837a1.44 1.44 0 0 0-1.11.275c-.312.24-.505.543-.59.881a1.74 1.74 0 0 0-.906-.465 1.47 1.47 0 0 0-.82.106l-2.182-2.182a1.56 1.56 0 0 0-2.2 0 1.54 1.54 0 0 0-.396.701 1.56 1.56 0 0 0-2.21-.01 1.55 1.55 0 0 0-.416.753c-.624-.624-1.649-.624-2.237-.037a1.557 1.557 0 0 0 0 2.2c-.239.1-.501.238-.715.453a1.56 1.56 0 0 0 0 2.2l.516.515a1.556 1.556 0 0 0-.753 2.615L7.01 19c1.32 1.319 2.909 2.189 4.475 2.449q.482.08.971.08c.85 0 1.653-.198 2.393-.579.231.033.46.054.686.054 1.266 0 2.457-.52 3.505-1.567 2.763-2.763 2.552-5.734 1.439-7.586z" clip-rule="evenodd"></path></svg></div></div></div></a></span></div><div class="pw-multi-vote-count l mh mi mj mk ml mm mn"><p class="bf b dv z du"><span class="mo">--</span></p></div></div></span></div><div class="bq ab"><div><div class="bm" aria-hidden="false"><button class="ao lz mp mq ab q fk mr ms" aria-label="responses"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" class="mt"><path d="M18.006 16.803c1.533-1.456 2.234-3.325 2.234-5.321C20.24 7.357 16.709 4 12.191 4S4 7.357 4 11.482c0 4.126 3.674 7.482 8.191 7.482.817 0 1.622-.111 2.393-.327.231.2.48.391.744.559 1.06.693 2.203 1.044 3.399 1.044.224-.008.4-.112.486-.287a.49.49 0 0 0-.042-.518c-.495-.67-.845-1.364-1.04-2.057a4 4 0 0 1-.125-.598zm-3.122 1.055-.067-.223-.315.096a8 8 0 0 1-2.311.338c-4.023 0-7.292-2.955-7.292-6.587 0-3.633 3.269-6.588 7.292-6.588 4.014 0 7.112 2.958 7.112 6.593 0 1.794-.608 3.469-2.027 4.72l-.195.168v.255c0 .056 0 .151.016.295.025.231.081.478.154.733.154.558.398 1.117.722 1.659a5.3 5.3 0 0 1-2.165-.845c-.276-.176-.714-.383-.941-.59z"></path></svg></button></div></div></div></div><div class="ab q"><div class="qx l jx"><div><div class="bm" aria-hidden="false"><span><a class="af ag ah ai aj ak al am an ao ap aq ar as at" data-testid="footerBookmarkButton" rel="noopener follow" href="/m/signin?actionUrl=https%3A%2F%2Fmedium.com%2F_%2Fbookmark%2Fp%2Fb89fa2c43f1c&amp;operation=register&amp;redirect=https%3A%2F%2Fmedium.com%2Fmobile-app-development-publication%2Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c&amp;source=---footer_actions--b89fa2c43f1c---------------------bookmark_footer-----------"><svg xmlns="http://www.w3.org/2000/svg" width="25" height="25" fill="none" viewBox="0 0 25 25" class="du mv" aria-label="Add to list bookmark button"><path fill="currentColor" d="M18 2.5a.5.5 0 0 1 1 0V5h2.5a.5.5 0 0 1 0 1H19v2.5a.5.5 0 1 1-1 0V6h-2.5a.5.5 0 0 1 0-1H18zM7 7a1 1 0 0 1 1-1h3.5a.5.5 0 0 0 0-1H8a2 2 0 0 0-2 2v14a.5.5 0 0 0 .805.396L12.5 17l5.695 4.396A.5.5 0 0 0 19 21v-8.5a.5.5 0 0 0-1 0v7.485l-5.195-4.012a.5.5 0 0 0-.61 0L7 19.985z"></path></svg></a></span></div></div></div><div class="qx l jx"><div class="bm" aria-hidden="false" aria-describedby="postFooterSocialMenu" aria-labelledby="postFooterSocialMenu"><div><div class="bm" aria-hidden="false"><button aria-controls="postFooterSocialMenu" aria-expanded="false" aria-label="Share Post" data-testid="footerSocialShareButton" class="af fk ah ai aj ak al nd an ao ap ex ne nf ms ng"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="none" viewBox="0 0 24 24"><path fill="currentColor" fill-rule="evenodd" d="M15.218 4.931a.4.4 0 0 1-.118.132l.012.006a.45.45 0 0 1-.292.074.5.5 0 0 1-.3-.13l-2.02-2.02v7.07c0 .28-.23.5-.5.5s-.5-.22-.5-.5v-7.04l-2 2a.45.45 0 0 1-.57.04h-.02a.4.4 0 0 1-.16-.3.4.4 0 0 1 .1-.32l2.8-2.8a.5.5 0 0 1 .7 0l2.8 2.79a.42.42 0 0 1 .068.498m-.106.138.008.004v-.01zM16 7.063h1.5a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2h-11c-1.1 0-2-.9-2-2v-10a2 2 0 0 1 2-2H8a.5.5 0 0 1 .35.15.5.5 0 0 1 .15.35.5.5 0 0 1-.15.35.5.5 0 0 1-.35.15H6.4c-.5 0-.9.4-.9.9v10.2a.9.9 0 0 0 .9.9h11.2c.5 0 .9-.4.9-.9v-10.2c0-.5-.4-.9-.9-.9H16a.5.5 0 0 1 0-1" clip-rule="evenodd"></path></svg></button></div></div></div></div></div></div></div></div></div></footer><div class="qy qz ra rb rc l"><div class="ab cb"><div class="ci bh fz ga gb gc"><div class="rd bh r re"></div><div class="rf l"><div class="ab rg rh ri jz jy"><div class="rj rk rl rm rn ro rp rq rr rs ab cp"><div class="h k"><a href="https://medium.com/mobile-app-development-publication?source=post_page---post_publication_info--b89fa2c43f1c--------------------------------" rel="noopener follow"><div class="fj ab"><img alt="Mobile App Development Publication" class="rt jb jc cx" src="https://miro.medium.com/v2/resize:fill:96:96/1*r5bO5bEjNCKLt6fKZbPdCA.png" width="48" height="48" loading="lazy"/><div class="rt l jc jb fs n fr ru"></div></div></a></div><div class="j i d"><a href="https://medium.com/mobile-app-development-publication?source=post_page---post_publication_info--b89fa2c43f1c--------------------------------" rel="noopener follow"><div class="fj ab"><img alt="Mobile App Development Publication" class="rt rw rv cx" src="https://miro.medium.com/v2/resize:fill:128:128/1*r5bO5bEjNCKLt6fKZbPdCA.png" width="64" height="64" loading="lazy"/><div class="rt l rv rw fs n fr ru"></div></div></a></div><div class="j i d rx jx"><div class="ab"></div></div></div><div class="ab co ry"><div class="rz sa sb sc sd l"><a class="af ag ah aj ak al am an ao ap aq ar as at ab q" href="https://medium.com/mobile-app-development-publication?source=post_page---post_publication_info--b89fa2c43f1c--------------------------------" rel="noopener follow"><h2 class="pw-author-name bf sf sg sh si sj sk sl ox sm sn pb so sp pf sq sr bk"><span class="gw se">Published in <!-- -->Mobile App Development Publication</span></h2></a><div class="ss ab ja"><div class="l jx"><span class="pw-follower-count bf b bg z du"><a class="af ag ah ai aj ak al am an ao ap aq ar jq" rel="noopener follow" href="/mobile-app-development-publication/followers?source=post_page---post_publication_info--b89fa2c43f1c--------------------------------">3.6K Followers</a></span></div><div class="bf b bg z du ab kd"><span class="jr l" aria-hidden="true"><span class="bf b bg z du">·</span></span><a class="af ag ah ai aj ak al am an ao ap aq ar jq" rel="noopener follow" href="/mobile-app-development-publication/custom-android-push-notification-use-case-cloning-grab-live-tracking-notification-c4975bd00621?source=post_page---post_publication_info--b89fa2c43f1c--------------------------------">Last published <span>Nov 22, 2024</span></a></div></div><div class="st l"><p class="bf b bg z bk"><span class="gw">Sharing iOS, Android and relevant Mobile App Development Technology and Learning</span></p></div></div></div><div class="h k"><div class="ab"></div></div></div></div><div class="ab rg rh ri jz jy"><div class="rj rk rl rm rn ro rp rq rr rs ab cp"><div class="h k"><a tabindex="0" rel="noopener follow" href="/@elye-project?source=post_page---post_author_info--b89fa2c43f1c--------------------------------"><div class="l fj"><img alt="Elye - A One Eye Dev By His Grace" class="l fd by jc jb cx" src="https://miro.medium.com/v2/resize:fill:96:96/1*0wVPGGR_3FMoPVGzT4nbTw.png" width="48" height="48" loading="lazy"/><div class="fr by l jc jb fs n ay ru"></div></div></a></div><div class="j i d"><a tabindex="0" rel="noopener follow" href="/@elye-project?source=post_page---post_author_info--b89fa2c43f1c--------------------------------"><div class="l fj"><img alt="Elye - A One Eye Dev By His Grace" class="l fd by rv rw cx" src="https://miro.medium.com/v2/resize:fill:128:128/1*0wVPGGR_3FMoPVGzT4nbTw.png" width="64" height="64" loading="lazy"/><div class="fr by l rv rw fs n ay ru"></div></div></a></div><div class="j i d rx jx"><div class="ab"><span><button class="bf b bg z su sv sw sx sy sz ta ev ew tb tc td fa fb fc fd bm fe ff">Follow</button></span></div></div></div><div class="ab co ry"><div class="rz sa sb sc sd l"><a class="af ag ah aj ak al am an ao ap aq ar as at ab q" rel="noopener follow" href="/@elye-project?source=post_page---post_author_info--b89fa2c43f1c--------------------------------"><h2 class="pw-author-name bf sf sg sh si sj sk sl ox sm sn pb so sp pf sq sr bk"><span class="gw se">Written by <!-- -->Elye - A One Eye Dev By His Grace</span></h2></a><div class="ss ab ja"><div class="l jx"><span class="pw-follower-count bf b bg z du"><a class="af ag ah ai aj ak al am an ao ap aq ar jq" rel="noopener follow" href="/@elye-project/followers?source=post_page---post_author_info--b89fa2c43f1c--------------------------------">68K Followers</a></span></div><div class="bf b bg z du ab kd"><span class="jr l" aria-hidden="true"><span class="bf b bg z du">·</span></span><a class="af ag ah ai aj ak al am an ao ap aq ar jq" rel="noopener follow" href="/@elye-project/following?source=post_page---post_author_info--b89fa2c43f1c--------------------------------">270 Following</a></div></div><div class="st l"><p class="bf b bg z bk"><span class="gw">Sharing Software Learning, Life and Faith Journey</span></p></div></div></div><div class="h k"><div class="ab"><span><button class="bf b bg z su sv sw sx sy sz ta ev ew tb tc td fa fb fc fd bm fe ff">Follow</button></span></div></div></div></div></div></div><div class="te l"><div class="rd bh r tf tg th ti tj"></div><div class="ab cb"><div class="ci bh fz ga gb gc"><div class="ab q cp"><h2 class="bf sf tk ii tl tm il tn to tp tq tr ts tt tu tv tw bk">No responses yet</h2><div class="ab tx"><div><div class="bm" aria-hidden="false"><a class="ty tz" href="https://policy.medium.com/medium-rules-30e5502c4eb4?source=post_page---post_responses--b89fa2c43f1c--------------------------------" rel="noopener follow" target="_blank"><svg xmlns="http://www.w3.org/2000/svg" width="25" height="25" viewBox="0 0 25 25"><path fill-rule="evenodd" d="M11.987 5.036a.754.754 0 0 1 .914-.01c.972.721 1.767 1.218 2.6 1.543.828.322 1.719.485 2.887.505a.755.755 0 0 1 .741.757c-.018 3.623-.43 6.256-1.449 8.21-1.034 1.984-2.662 3.209-4.966 4.083a.75.75 0 0 1-.537-.003c-2.243-.874-3.858-2.095-4.897-4.074-1.024-1.951-1.457-4.583-1.476-8.216a.755.755 0 0 1 .741-.757c1.195-.02 2.1-.182 2.923-.503.827-.322 1.6-.815 2.519-1.535m.468.903c-.897.69-1.717 1.21-2.623 1.564-.898.35-1.856.527-3.026.565.037 3.45.469 5.817 1.36 7.515.884 1.684 2.25 2.762 4.284 3.571 2.092-.81 3.465-1.89 4.344-3.575.886-1.698 1.299-4.065 1.334-7.512-1.149-.039-2.091-.217-2.99-.567-.906-.353-1.745-.873-2.683-1.561m-.009 9.155a2.672 2.672 0 1 0 0-5.344 2.672 2.672 0 0 0 0 5.344m0 1a3.672 3.672 0 1 0 0-7.344 3.672 3.672 0 0 0 0 7.344m-1.813-3.777.525-.526.916.917 1.623-1.625.526.526-2.149 2.152z" clip-rule="evenodd"></path></svg></a></div></div></div></div><div class="ua ub uc ud ue l"></div></div></div></div><div class="uf ug uh ui uj l bx"><div class="h k j"><div class="rd bh uk ul"></div><div class="ab cb"><div class="ci bh fz ga gb gc"><div class="um ab lu ka"><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" href="https://help.medium.com/hc/en-us?source=post_page-----b89fa2c43f1c--------------------------------" rel="noopener follow"><p class="bf b dv z du">Help</p></a></div><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" href="https://medium.statuspage.io/?source=post_page-----b89fa2c43f1c--------------------------------" rel="noopener follow"><p class="bf b dv z du">Status</p></a></div><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" rel="noopener follow" href="/about?autoplay=1&amp;source=post_page-----b89fa2c43f1c--------------------------------"><p class="bf b dv z du">About</p></a></div><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" rel="noopener follow" href="/jobs-at-medium/work-at-medium-959d1a85284e?source=post_page-----b89fa2c43f1c--------------------------------"><p class="bf b dv z du">Careers</p></a></div><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" href="pressinquiries@medium.com?source=post_page-----b89fa2c43f1c--------------------------------" rel="noopener follow"><p class="bf b dv z du">Press</p></a></div><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" href="https://blog.medium.com/?source=post_page-----b89fa2c43f1c--------------------------------" rel="noopener follow"><p class="bf b dv z du">Blog</p></a></div><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" href="https://policy.medium.com/medium-privacy-policy-f03bf92035c9?source=post_page-----b89fa2c43f1c--------------------------------" rel="noopener follow"><p class="bf b dv z du">Privacy</p></a></div><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" href="https://policy.medium.com/medium-terms-of-service-9db0094a1e0f?source=post_page-----b89fa2c43f1c--------------------------------" rel="noopener follow"><p class="bf b dv z du">Terms</p></a></div><div class="un uo l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" href="https://speechify.com/medium?source=post_page-----b89fa2c43f1c--------------------------------" rel="noopener follow"><p class="bf b dv z du">Text to speech</p></a></div><div class="un l"><a class="af ag ah ai aj ak al am an ao ap aq ar as at" rel="noopener follow" href="/business?source=post_page-----b89fa2c43f1c--------------------------------"><p class="bf b dv z du">Teams</p></a></div></div></div></div></div></div></div></div></div></div><script>window.__BUILD_ID__="main-20241216-164309-0d4958d8a6"</script><script>window.__GRAPHQL_URI__ = "https://medium.com/_/graphql"</script><script>window.__PRELOADED_STATE__ = {"algolia":{"queries":{}},"cache":{"experimentGroupSet":true,"reason":"","group":"enabled","tags":["group-edgeCachePosts","post-b89fa2c43f1c","user-5742b4fcf89e","collection-f9c208bdbb09"],"serverVariantState":"44136fa355b3678a1146ad16f7e8649e94fb4fc21fe77e8310c060f61caaff8a","middlewareEnabled":true,"cacheStatus":"DYNAMIC","shouldUseCache":true,"vary":[],"lohpSummerUpsellEnabled":false},"client":{"hydrated":false,"isUs":false,"isNativeMedium":false,"isSafariMobile":false,"isSafari":false,"isFirefox":false,"routingEntity":{"type":"DEFAULT","explicit":false},"viewerIsBot":false},"debug":{"requestId":"a7fae08f-4852-4b46-ac01-84853e5a1ee0","hybridDevServices":[],"originalSpanCarrier":{"traceparent":"00-030d3ee075d4f5aeb4b0bc1bec105446-faf30065205a02d2-01"}},"multiVote":{"clapsPerPost":{}},"navigation":{"branch":{"show":null,"hasRendered":null,"blockedByCTA":false},"hideGoogleOneTap":false,"hasRenderedAlternateUserBanner":null,"currentLocation":"https:\u002F\u002Fmedium.com\u002Fmobile-app-development-publication\u002Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c","host":"medium.com","hostname":"medium.com","referrer":"","hasSetReferrer":false,"susiModal":{"step":null,"operation":"register"},"postRead":false,"partnerProgram":{"selectedCountryCode":null},"queryString":"","currentHash":""},"config":{"nodeEnv":"production","version":"main-20241216-164309-0d4958d8a6","target":"production","productName":"Medium","publicUrl":"https:\u002F\u002Fcdn-client.medium.com\u002Flite","authDomain":"medium.com","authGoogleClientId":"216296035834-k1k6qe060s2tp2a2jam4ljdcms00sttg.apps.googleusercontent.com","favicon":"production","glyphUrl":"https:\u002F\u002Fglyph.medium.com","branchKey":"key_live_ofxXr2qTrrU9NqURK8ZwEhknBxiI6KBm","algolia":{"appId":"MQ57UUUQZ2","apiKeySearch":"394474ced050e3911ae2249ecc774921","indexPrefix":"medium_","host":"-dsn.algolia.net"},"recaptchaKey":"6Lfc37IUAAAAAKGGtC6rLS13R1Hrw_BqADfS1LRk","recaptcha3Key":"6Lf8R9wUAAAAABMI_85Wb8melS7Zj6ziuf99Yot5","recaptchaEnterpriseKeyId":"6Le-uGgpAAAAAPprRaokM8AKthQ9KNGdoxaGUvVp","datadog":{"applicationId":"6702d87d-a7e0-42fe-bbcb-95b469547ea0","clientToken":"pub853ea8d17ad6821d9f8f11861d23dfed","rumToken":"pubf9cc52896502b9413b68ba36fc0c7162","context":{"deployment":{"target":"production","tag":"main-20241216-164309-0d4958d8a6","commit":"0d4958d8a6e728d0bc7ba6245eaad002411a6eb7"}},"datacenter":"us"},"googleAnalyticsCode":"G-7JY7T788PK","googlePay":{"apiVersion":"2","apiVersionMinor":"0","merchantId":"BCR2DN6TV7EMTGBM","merchantName":"Medium","instanceMerchantId":"13685562959212738550"},"applePay":{"version":3},"signInWallCustomDomainCollectionIds":["3a8144eabfe3","336d898217ee","61061eb0c96b","138adf9c44c","819cc2aaeee0"],"mediumMastodonDomainName":"me.dm","mediumOwnedAndOperatedCollectionIds":["8a9336e5bb4","b7e45b22fec3","193b68bd4fba","8d6b8a439e32","54c98c43354d","3f6ecf56618","d944778ce714","92d2092dc598","ae2a65f35510","1285ba81cada","544c7006046e","fc8964313712","40187e704f1c","88d9857e584e","7b6769f2748b","bcc38c8f6edf","cef6983b292","cb8577c9149e","444d13b52878","713d7dbc99b0","ef8e90590e66","191186aaafa0","55760f21cdc5","9dc80918cc93","bdc4052bbdba","8ccfed20cbb2"],"tierOneDomains":["medium.com","thebolditalic.com","arcdigital.media","towardsdatascience.com","uxdesign.cc","codeburst.io","psiloveyou.xyz","writingcooperative.com","entrepreneurshandbook.co","prototypr.io","betterhumans.coach.me","theascent.pub"],"topicsToFollow":["d61cf867d93f","8a146bc21b28","1eca0103fff3","4d562ee63426","aef1078a3ef5","e15e46793f8d","6158eb913466","55f1c20aba7a","3d18b94f6858","4861fee224fd","63c6f1f93ee","1d98b3a9a871","decb52b64abf","ae5d4995e225","830cded25262"],"topicToTagMappings":{"accessibility":"accessibility","addiction":"addiction","android-development":"android-development","art":"art","artificial-intelligence":"artificial-intelligence","astrology":"astrology","basic-income":"basic-income","beauty":"beauty","biotech":"biotech","blockchain":"blockchain","books":"books","business":"business","cannabis":"cannabis","cities":"cities","climate-change":"climate-change","comics":"comics","coronavirus":"coronavirus","creativity":"creativity","cryptocurrency":"cryptocurrency","culture":"culture","cybersecurity":"cybersecurity","data-science":"data-science","design":"design","digital-life":"digital-life","disability":"disability","economy":"economy","education":"education","equality":"equality","family":"family","feminism":"feminism","fiction":"fiction","film":"film","fitness":"fitness","food":"food","freelancing":"freelancing","future":"future","gadgets":"gadgets","gaming":"gaming","gun-control":"gun-control","health":"health","history":"history","humor":"humor","immigration":"immigration","ios-development":"ios-development","javascript":"javascript","justice":"justice","language":"language","leadership":"leadership","lgbtqia":"lgbtqia","lifestyle":"lifestyle","machine-learning":"machine-learning","makers":"makers","marketing":"marketing","math":"math","media":"media","mental-health":"mental-health","mindfulness":"mindfulness","money":"money","music":"music","neuroscience":"neuroscience","nonfiction":"nonfiction","outdoors":"outdoors","parenting":"parenting","pets":"pets","philosophy":"philosophy","photography":"photography","podcasts":"podcast","poetry":"poetry","politics":"politics","privacy":"privacy","product-management":"product-management","productivity":"productivity","programming":"programming","psychedelics":"psychedelics","psychology":"psychology","race":"race","relationships":"relationships","religion":"religion","remote-work":"remote-work","san-francisco":"san-francisco","science":"science","self":"self","self-driving-cars":"self-driving-cars","sexuality":"sexuality","social-media":"social-media","society":"society","software-engineering":"software-engineering","space":"space","spirituality":"spirituality","sports":"sports","startups":"startup","style":"style","technology":"technology","transportation":"transportation","travel":"travel","true-crime":"true-crime","tv":"tv","ux":"ux","venture-capital":"venture-capital","visual-design":"visual-design","work":"work","world":"world","writing":"writing"},"defaultImages":{"avatar":{"imageId":"1*dmbNkD5D-u45r44go_cf0g.png","height":150,"width":150},"orgLogo":{"imageId":"7*V1_7XP4snlmqrc_0Njontw.png","height":110,"width":500},"postLogo":{"imageId":"bd978bb536350a710e8efb012513429cabdc4c28700604261aeda246d0f980b7","height":810,"width":1440},"postPreviewImage":{"imageId":"1*hn4v1tCaJy7cWMyb0bpNpQ.png","height":386,"width":579}},"collectionStructuredData":{"8d6b8a439e32":{"name":"Elemental","data":{"@type":"NewsMediaOrganization","ethicsPolicy":"https:\u002F\u002Fhelp.medium.com\u002Fhc\u002Fen-us\u002Farticles\u002F360043290473","logo":{"@type":"ImageObject","url":"https:\u002F\u002Fcdn-images-1.medium.com\u002Fmax\u002F980\u002F1*9ygdqoKprhwuTVKUM0DLPA@2x.png","width":980,"height":159}}},"3f6ecf56618":{"name":"Forge","data":{"@type":"NewsMediaOrganization","ethicsPolicy":"https:\u002F\u002Fhelp.medium.com\u002Fhc\u002Fen-us\u002Farticles\u002F360043290473","logo":{"@type":"ImageObject","url":"https:\u002F\u002Fcdn-images-1.medium.com\u002Fmax\u002F596\u002F1*uULpIlImcO5TDuBZ6lm7Lg@2x.png","width":596,"height":183}}},"ae2a65f35510":{"name":"GEN","data":{"@type":"NewsMediaOrganization","ethicsPolicy":"https:\u002F\u002Fhelp.medium.com\u002Fhc\u002Fen-us\u002Farticles\u002F360043290473","logo":{"@type":"ImageObject","url":"https:\u002F\u002Fmiro.medium.com\u002Fmax\u002F264\u002F1*RdVZMdvfV3YiZTw6mX7yWA.png","width":264,"height":140}}},"88d9857e584e":{"name":"LEVEL","data":{"@type":"NewsMediaOrganization","ethicsPolicy":"https:\u002F\u002Fhelp.medium.com\u002Fhc\u002Fen-us\u002Farticles\u002F360043290473","logo":{"@type":"ImageObject","url":"https:\u002F\u002Fmiro.medium.com\u002Fmax\u002F540\u002F1*JqYMhNX6KNNb2UlqGqO2WQ.png","width":540,"height":108}}},"7b6769f2748b":{"name":"Marker","data":{"@type":"NewsMediaOrganization","ethicsPolicy":"https:\u002F\u002Fhelp.medium.com\u002Fhc\u002Fen-us\u002Farticles\u002F360043290473","logo":{"@type":"ImageObject","url":"https:\u002F\u002Fcdn-images-1.medium.com\u002Fmax\u002F383\u002F1*haCUs0wF6TgOOvfoY-jEoQ@2x.png","width":383,"height":92}}},"444d13b52878":{"name":"OneZero","data":{"@type":"NewsMediaOrganization","ethicsPolicy":"https:\u002F\u002Fhelp.medium.com\u002Fhc\u002Fen-us\u002Farticles\u002F360043290473","logo":{"@type":"ImageObject","url":"https:\u002F\u002Fmiro.medium.com\u002Fmax\u002F540\u002F1*cw32fIqCbRWzwJaoQw6BUg.png","width":540,"height":123}}},"8ccfed20cbb2":{"name":"Zora","data":{"@type":"NewsMediaOrganization","ethicsPolicy":"https:\u002F\u002Fhelp.medium.com\u002Fhc\u002Fen-us\u002Farticles\u002F360043290473","logo":{"@type":"ImageObject","url":"https:\u002F\u002Fmiro.medium.com\u002Fmax\u002F540\u002F1*tZUQqRcCCZDXjjiZ4bDvgQ.png","width":540,"height":106}}}},"embeddedPostIds":{"coronavirus":"cd3010f9d81f"},"sharedCdcMessaging":{"COVID_APPLICABLE_TAG_SLUGS":[],"COVID_APPLICABLE_TOPIC_NAMES":[],"COVID_APPLICABLE_TOPIC_NAMES_FOR_TOPIC_PAGE":[],"COVID_MESSAGES":{"tierA":{"text":"For more information on the novel coronavirus and Covid-19, visit cdc.gov.","markups":[{"start":66,"end":73,"href":"https:\u002F\u002Fwww.cdc.gov\u002Fcoronavirus\u002F2019-nCoV"}]},"tierB":{"text":"Anyone can publish on Medium per our Policies, but we don’t fact-check every story. For more info about the coronavirus, see cdc.gov.","markups":[{"start":37,"end":45,"href":"https:\u002F\u002Fhelp.medium.com\u002Fhc\u002Fen-us\u002Fcategories\u002F201931128-Policies-Safety"},{"start":125,"end":132,"href":"https:\u002F\u002Fwww.cdc.gov\u002Fcoronavirus\u002F2019-nCoV"}]},"paywall":{"text":"This article has been made free for everyone, thanks to Medium Members. For more information on the novel coronavirus and Covid-19, visit cdc.gov.","markups":[{"start":56,"end":70,"href":"https:\u002F\u002Fmedium.com\u002Fmembership"},{"start":138,"end":145,"href":"https:\u002F\u002Fwww.cdc.gov\u002Fcoronavirus\u002F2019-nCoV"}]},"unbound":{"text":"This article is free for everyone, thanks to Medium Members. For more information on the novel coronavirus and Covid-19, visit cdc.gov.","markups":[{"start":45,"end":59,"href":"https:\u002F\u002Fmedium.com\u002Fmembership"},{"start":127,"end":134,"href":"https:\u002F\u002Fwww.cdc.gov\u002Fcoronavirus\u002F2019-nCoV"}]}},"COVID_BANNER_POST_ID_OVERRIDE_WHITELIST":["3b31a67bff4a"]},"sharedVoteMessaging":{"TAGS":["politics","election-2020","government","us-politics","election","2020-presidential-race","trump","donald-trump","democrats","republicans","congress","republican-party","democratic-party","biden","joe-biden","maga"],"TOPICS":["politics","election"],"MESSAGE":{"text":"Find out more about the U.S. election results here.","markups":[{"start":46,"end":50,"href":"https:\u002F\u002Fcookpolitical.com\u002F2020-national-popular-vote-tracker"}]},"EXCLUDE_POSTS":["397ef29e3ca5"]},"embedPostRules":[],"recircOptions":{"v1":{"limit":3},"v2":{"limit":8}},"braintreeClientKey":"production_zjkj96jm_m56f8fqpf7ngnrd4","braintree":{"enabled":true,"merchantId":"m56f8fqpf7ngnrd4","merchantAccountId":{"usd":"AMediumCorporation_instant","eur":"amediumcorporation_EUR","cad":"amediumcorporation_CAD"},"publicKey":"ds2nn34bg2z7j5gd","braintreeEnvironment":"production","dashboardUrl":"https:\u002F\u002Fwww.braintreegateway.com\u002Fmerchants","gracePeriodDurationInDays":14,"mediumMembershipPlanId":{"monthly":"ce105f8c57a3","monthlyV2":"e8a5e126-792b-4ee6-8fba-d574c1b02fc5","monthlyWithTrial":"d5ee3dbe3db8","monthlyPremium":"fa741a9b47a2","yearly":"a40ad4a43185","yearlyV2":"3815d7d6-b8ca-4224-9b8c-182f9047866e","yearlyStaff":"d74fb811198a","yearlyWithTrial":"b3bc7350e5c7","yearlyPremium":"e21bd2c12166","monthlyOneYearFree":"e6c0637a-2bad-4171-ab4f-3c268633d83c","monthly25PercentOffFirstYear":"235ecc62-0cdb-49ae-9378-726cd21c504b","monthly20PercentOffFirstYear":"ba518864-9c13-4a99-91ca-411bf0cac756","monthly15PercentOffFirstYear":"594c029b-9f89-43d5-88f8-8173af4e070e","monthly10PercentOffFirstYear":"c6c7bc9a-40f2-4b51-8126-e28511d5bdb0","monthlyForStudents":"629ebe51-da7d-41fd-8293-34cd2f2030a8","yearlyOneYearFree":"78ba7be9-0d9f-4ece-aa3e-b54b826f2bf1","yearly25PercentOffFirstYear":"2dbb010d-bb8f-4eeb-ad5c-a08509f42d34","yearly20PercentOffFirstYear":"47565488-435b-47f8-bf93-40d5fbe0ebc8","yearly15PercentOffFirstYear":"8259809b-0881-47d9-acf7-6c001c7f720f","yearly10PercentOffFirstYear":"9dd694fb-96e1-472c-8d9e-3c868d5c1506","yearlyForStudents":"e29345ef-ab1c-4234-95c5-70e50fe6bc23","monthlyCad":"p52orjkaceei","yearlyCad":"h4q9g2up9ktt"},"braintreeDiscountId":{"oneMonthFree":"MONTHS_FREE_01","threeMonthsFree":"MONTHS_FREE_03","sixMonthsFree":"MONTHS_FREE_06","fiftyPercentOffOneYear":"FIFTY_PERCENT_OFF_ONE_YEAR"},"3DSecureVersion":"2","defaultCurrency":"usd","providerPlanIdCurrency":{"4ycw":"usd","rz3b":"usd","3kqm":"usd","jzw6":"usd","c2q2":"usd","nnsw":"usd","q8qw":"usd","d9y6":"usd","fx7w":"cad","nwf2":"cad"}},"paypalClientId":"AXj1G4fotC2GE8KzWX9mSxCH1wmPE3nJglf4Z2ig_amnhvlMVX87otaq58niAg9iuLktVNF_1WCMnN7v","paypal":{"host":"https:\u002F\u002Fapi.paypal.com:443","clientMode":"production","serverMode":"live","webhookId":"4G466076A0294510S","monthlyPlan":{"planId":"P-9WR0658853113943TMU5FDQA","name":"Medium Membership (Monthly) with setup fee","description":"Unlimited access to the best and brightest stories on Medium. Membership billed monthly."},"yearlyPlan":{"planId":"P-7N8963881P8875835MU5JOPQ","name":"Medium Membership (Annual) with setup fee","description":"Unlimited access to the best and brightest stories on Medium. Membership billed annually."},"oneYearGift":{"name":"Medium Membership (1 Year, Digital Gift Code)","description":"Unlimited access to the best and brightest stories on Medium. Gift codes can be redeemed at medium.com\u002Fredeem.","price":"50.00","currency":"USD","sku":"membership-gift-1-yr"},"oldMonthlyPlan":{"planId":"P-96U02458LM656772MJZUVH2Y","name":"Medium Membership (Monthly)","description":"Unlimited access to the best and brightest stories on Medium. Membership billed monthly."},"oldYearlyPlan":{"planId":"P-59P80963JF186412JJZU3SMI","name":"Medium Membership (Annual)","description":"Unlimited access to the best and brightest stories on Medium. Membership billed annually."},"monthlyPlanWithTrial":{"planId":"P-66C21969LR178604GJPVKUKY","name":"Medium Membership (Monthly) with setup fee","description":"Unlimited access to the best and brightest stories on Medium. Membership billed monthly."},"yearlyPlanWithTrial":{"planId":"P-6XW32684EX226940VKCT2MFA","name":"Medium Membership (Annual) with setup fee","description":"Unlimited access to the best and brightest stories on Medium. Membership billed annually."},"oldMonthlyPlanNoSetupFee":{"planId":"P-4N046520HR188054PCJC7LJI","name":"Medium Membership (Monthly)","description":"Unlimited access to the best and brightest stories on Medium. Membership billed monthly."},"oldYearlyPlanNoSetupFee":{"planId":"P-7A4913502Y5181304CJEJMXQ","name":"Medium Membership (Annual)","description":"Unlimited access to the best and brightest stories on Medium. Membership billed annually."},"sdkUrl":"https:\u002F\u002Fwww.paypal.com\u002Fsdk\u002Fjs"},"stripePublishableKey":"pk_live_7FReX44VnNIInZwrIIx6ghjl","log":{"json":true,"level":"info"},"imageUploadMaxSizeMb":25,"staffPicks":{"title":"Staff Picks","catalogId":"c7bc6e1ee00f"}},"session":{"xsrf":""}}</script><script>window.__APOLLO_STATE__ = {"ROOT_QUERY":{"__typename":"Query","viewer":null,"collectionByDomainOrSlug({\"domainOrSlug\":\"mobile-app-development-publication\"})":{"__ref":"Collection:f9c208bdbb09"},"postResult({\"id\":\"b89fa2c43f1c\"})":{"__ref":"Post:b89fa2c43f1c"}},"ImageMetadata:":{"__typename":"ImageMetadata","id":""},"Collection:f9c208bdbb09":{"__typename":"Collection","id":"f9c208bdbb09","favicon":{"__ref":"ImageMetadata:"},"customStyleSheet":null,"colorPalette":{"__typename":"ColorPalette","highlightSpectrum":{"__typename":"ColorSpectrum","backgroundColor":"#FFFFFFFF","colorPoints":[{"__typename":"ColorPoint","color":"#FFFFFFFF","point":0},{"__typename":"ColorPoint","color":"#FFE8F3E8","point":0.1},{"__typename":"ColorPoint","color":"#FFE8F3E8","point":0.2},{"__typename":"ColorPoint","color":"#FFD1E7D1","point":0.6},{"__typename":"ColorPoint","color":"#FFA3D0A2","point":1}]},"defaultBackgroundSpectrum":{"__typename":"ColorSpectrum","backgroundColor":"#FFFFFFFF","colorPoints":[{"__typename":"ColorPoint","color":"#FF1A8917","point":0},{"__typename":"ColorPoint","color":"#FF11800E","point":0.1},{"__typename":"ColorPoint","color":"#FF0F730C","point":0.2},{"__typename":"ColorPoint","color":"#FF095407","point":1}]},"tintBackgroundSpectrum":null},"domain":null,"slug":"mobile-app-development-publication","googleAnalyticsId":null,"name":"Mobile App Development Publication","subscriberCount":3636,"description":"Sharing iOS, Android and relevant Mobile App Development Technology and Learning","avatar":{"__ref":"ImageMetadata:1*r5bO5bEjNCKLt6fKZbPdCA.png"},"latestPostsConnection({\"paging\":{\"limit\":1}})":{"__typename":"PostConnection","posts":[{"__ref":"Post:c4975bd00621"}]},"viewerEdge":{"__ref":"CollectionViewerEdge:collectionId:f9c208bdbb09-viewerId:lo_517b642d49fd"},"twitterUsername":"elye_project","facebookPageId":null,"logo":{"__ref":"ImageMetadata:1*MdMgVRTnupYGv9gYoKASQQ.png"}},"ImageMetadata:1*r5bO5bEjNCKLt6fKZbPdCA.png":{"__typename":"ImageMetadata","id":"1*r5bO5bEjNCKLt6fKZbPdCA.png"},"User:7b8cf0bd846":{"__typename":"User","id":"7b8cf0bd846","customDomainState":null,"hasSubdomain":false,"username":"adiandrea"},"Post:c4975bd00621":{"__typename":"Post","id":"c4975bd00621","firstPublishedAt":1732250947785,"creator":{"__ref":"User:7b8cf0bd846"},"collection":{"__ref":"Collection:f9c208bdbb09"},"isSeries":false,"mediumUrl":"https:\u002F\u002Fmedium.com\u002Fmobile-app-development-publication\u002Fcustom-android-push-notification-use-case-cloning-grab-live-tracking-notification-c4975bd00621","sequence":null,"uniqueSlug":"custom-android-push-notification-use-case-cloning-grab-live-tracking-notification-c4975bd00621"},"LinkedAccounts:5742b4fcf89e":{"__typename":"LinkedAccounts","mastodon":null,"id":"5742b4fcf89e"},"User:5742b4fcf89e":{"__typename":"User","id":"5742b4fcf89e","linkedAccounts":{"__ref":"LinkedAccounts:5742b4fcf89e"},"isSuspended":false,"name":"Elye - A One Eye Dev By His Grace","imageId":"1*0wVPGGR_3FMoPVGzT4nbTw.png","customDomainState":{"__typename":"CustomDomainState","live":{"__typename":"CustomDomain","domain":"elye-project.medium.com"}},"hasSubdomain":true,"username":"elye-project","verifications":{"__typename":"VerifiedInfo","isBookAuthor":false},"socialStats":{"__typename":"SocialStats","followerCount":68016,"followingCount":230,"collectionFollowingCount":40},"bio":"Sharing Software Learning, Life and Faith Journey","membership":null,"allowNotes":true,"viewerEdge":{"__ref":"UserViewerEdge:userId:5742b4fcf89e-viewerId:lo_517b642d49fd"},"twitterScreenName":"elye_project"},"Paragraph:a5304bb01f96_0":{"__typename":"Paragraph","id":"a5304bb01f96_0","name":"2cfe","type":"H4","href":null,"layout":null,"metadata":null,"text":"Learn Android Development","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_1":{"__typename":"Paragraph","id":"a5304bb01f96_1","name":"7b48","type":"H3","href":null,"layout":null,"metadata":null,"text":"Demystify Jetpack Compose Layout Constraint and Size Setting","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_2":{"__typename":"Paragraph","id":"a5304bb01f96_2","name":"6b40","type":"H4","href":null,"layout":null,"metadata":null,"text":"Mastering one of the most confusing Jetpack Compose APIs I encountered","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"ImageMetadata:0*-P2EKQ3GDZRnXG2A":{"__typename":"ImageMetadata","id":"0*-P2EKQ3GDZRnXG2A","originalHeight":4160,"originalWidth":6240,"focusPercentX":null,"focusPercentY":null,"alt":null},"Paragraph:a5304bb01f96_3":{"__typename":"Paragraph","id":"a5304bb01f96_3","name":"fc32","type":"IMG","href":null,"layout":"INSET_CENTER","metadata":{"__ref":"ImageMetadata:0*-P2EKQ3GDZRnXG2A"},"text":"Photo by Irham Bahtiar on Unsplash","hasDropCap":null,"dropCapImage":null,"markups":[{"__typename":"Markup","type":"A","start":9,"end":22,"href":"https:\u002F\u002Funsplash.com\u002F@bahtiarirham?utm_source=medium&utm_medium=referral","anchorType":"LINK","userId":null,"linkMetadata":null},{"__typename":"Markup","type":"A","start":26,"end":34,"href":"https:\u002F\u002Funsplash.com?utm_source=medium&utm_medium=referral","anchorType":"LINK","userId":null,"linkMetadata":null}],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_4":{"__typename":"Paragraph","id":"a5304bb01f96_4","name":"c6ad","type":"P","href":null,"layout":null,"metadata":null,"text":"I shared about how one can support negative padding in Jetpack Compose. The best solution used is to use Jetpack Compose Custom Layout Modifier.","hasDropCap":true,"dropCapImage":null,"markups":[{"__typename":"Markup","type":"A","start":27,"end":70,"href":"https:\u002F\u002Fmedium.com\u002Fmobile-app-development-publication\u002Fnegative-padding-for-jetpack-compose-made-possible-c82283d15564","anchorType":"LINK","userId":null,"linkMetadata":null},{"__typename":"Markup","type":"A","start":105,"end":134,"href":"https:\u002F\u002Fmedium.com\u002Fmobile-app-development-publication\u002Fjetpack-compose-custom-layout-made-easy-b5743f8cc82c","anchorType":"LINK","userId":null,"linkMetadata":null}],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_5":{"__typename":"Paragraph","id":"a5304bb01f96_5","name":"418a","type":"P","href":null,"layout":null,"metadata":null,"text":"However, although the code seems clear, the logic behind how that happened is most confusing for me.","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_6":{"__typename":"Paragraph","id":"a5304bb01f96_6","name":"140c","type":"P","href":null,"layout":null,"metadata":null,"text":"Take for example the below divider, where we change the layout width","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_7":{"__typename":"Paragraph","id":"a5304bb01f96_7","name":"0f92","type":"PRE","href":null,"layout":null,"metadata":null,"text":" @Composable\n private fun DividerLayoutWidthChanged(layoutWidth: Int) {\n Divider(modifier = Modifier\n .height(20.dp)\n .layout { measurable, constraints -\u003E\n val placeable = measurable.measure(constraints)\n layout(\n width = layoutWidth.dp.roundToPx(),\n height = placeable.height\n ) { placeable.place(0, 0) }\n }\n )\n }","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":{"__typename":"CodeBlockMetadata","mode":"AUTO","lang":"kotlin"},"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_8":{"__typename":"Paragraph","id":"a5304bb01f96_8","name":"1013","type":"P","href":null,"layout":null,"metadata":null,"text":"As we modify the width, we thought the divider’s length would change. But it didn’t. Instead, confusingly 😕","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_9":{"__typename":"Paragraph","id":"a5304bb01f96_9","name":"796c","type":"ULI","href":null,"layout":null,"metadata":null,"text":"It just got moved around, like placement functionality.","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"Paragraph:a5304bb01f96_10":{"__typename":"Paragraph","id":"a5304bb01f96_10","name":"b9d4","type":"ULI","href":null,"layout":null,"metadata":null,"text":"And sometimes, no visual different change as we change the width size.","hasDropCap":null,"dropCapImage":null,"markups":[],"codeBlockMetadata":null,"iframe":null,"mixtapeMetadata":null},"CollectionViewerEdge:collectionId:f9c208bdbb09-viewerId:lo_517b642d49fd":{"__typename":"CollectionViewerEdge","id":"collectionId:f9c208bdbb09-viewerId:lo_517b642d49fd","isEditor":false,"isMuting":false},"UserViewerEdge:userId:5742b4fcf89e-viewerId:lo_517b642d49fd":{"__typename":"UserViewerEdge","id":"userId:5742b4fcf89e-viewerId:lo_517b642d49fd","isMuting":false},"ImageMetadata:1*MdMgVRTnupYGv9gYoKASQQ.png":{"__typename":"ImageMetadata","id":"1*MdMgVRTnupYGv9gYoKASQQ.png","originalWidth":1233,"originalHeight":115},"PostViewerEdge:postId:b89fa2c43f1c-viewerId:lo_517b642d49fd":{"__typename":"PostViewerEdge","shouldIndexPostForExternalSearch":true,"id":"postId:b89fa2c43f1c-viewerId:lo_517b642d49fd"},"Tag:jetpack-compose":{"__typename":"Tag","id":"jetpack-compose","displayTitle":"Jetpack Compose","normalizedTagSlug":"jetpack-compose"},"Tag:android-app-development":{"__typename":"Tag","id":"android-app-development","displayTitle":"Android App Development","normalizedTagSlug":"android-app-development"},"Tag:app-development":{"__typename":"Tag","id":"app-development","displayTitle":"App Development","normalizedTagSlug":"app-development"},"Tag:androiddev":{"__typename":"Tag","id":"androiddev","displayTitle":"AndroidDev","normalizedTagSlug":"androiddev"},"Tag:mobile-app-development":{"__typename":"Tag","id":"mobile-app-development","displayTitle":"Mobile App Development","normalizedTagSlug":"mobile-app-development"},"Post:b89fa2c43f1c":{"__typename":"Post","id":"b89fa2c43f1c","collection":{"__ref":"Collection:f9c208bdbb09"},"content({\"postMeteringOptions\":{}})":{"__typename":"PostContent","isLockedPreviewOnly":true,"bodyModel":{"__typename":"RichText","sections":[{"__typename":"Section","name":null,"startIndex":0,"textLayout":null,"imageLayout":null,"backgroundImage":null,"videoLayout":null,"backgroundVideo":null}],"paragraphs":[{"__ref":"Paragraph:a5304bb01f96_0"},{"__ref":"Paragraph:a5304bb01f96_1"},{"__ref":"Paragraph:a5304bb01f96_2"},{"__ref":"Paragraph:a5304bb01f96_3"},{"__ref":"Paragraph:a5304bb01f96_4"},{"__ref":"Paragraph:a5304bb01f96_5"},{"__ref":"Paragraph:a5304bb01f96_6"},{"__ref":"Paragraph:a5304bb01f96_7"},{"__ref":"Paragraph:a5304bb01f96_8"},{"__ref":"Paragraph:a5304bb01f96_9"},{"__ref":"Paragraph:a5304bb01f96_10"}]},"validatedShareKey":"","shareKeyCreator":null},"creator":{"__ref":"User:5742b4fcf89e"},"inResponseToEntityType":null,"isLocked":true,"isMarkedPaywallOnly":false,"lockedSource":"LOCKED_POST_SOURCE_UGC","mediumUrl":"https:\u002F\u002Fmedium.com\u002Fmobile-app-development-publication\u002Fdemystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c","primaryTopic":null,"topics":[{"__typename":"Topic","slug":"android-development"},{"__typename":"Topic","slug":"programming"}],"isPublished":true,"latestPublishedVersion":"a5304bb01f96","visibility":"LOCKED","postResponses":{"__typename":"PostResponses","count":0},"clapCount":137,"allowResponses":true,"isLimitedState":false,"title":"Demystify Jetpack Compose Layout Constraint and Size Setting","isSeries":false,"sequence":null,"uniqueSlug":"demystify-jetpack-compose-layout-constraint-and-size-setting-b89fa2c43f1c","socialTitle":"","socialDek":"","canonicalUrl":"","metaDescription":"","latestPublishedAt":1692100659829,"readingTime":10.450943396226414,"previewContent":{"__typename":"PreviewContent","subtitle":"Mastering one of the most confusing Jetpack Compose APIs I encountered"},"previewImage":{"__ref":"ImageMetadata:0*-P2EKQ3GDZRnXG2A"},"isShortform":false,"seoTitle":"","firstPublishedAt":1687872723271,"updatedAt":1692100659829,"shortformType":"SHORTFORM_TYPE_LINK","seoDescription":"","viewerEdge":{"__ref":"PostViewerEdge:postId:b89fa2c43f1c-viewerId:lo_517b642d49fd"},"isSuspended":false,"license":"ALL_RIGHTS_RESERVED","tags":[{"__ref":"Tag:jetpack-compose"},{"__ref":"Tag:android-app-development"},{"__ref":"Tag:app-development"},{"__ref":"Tag:androiddev"},{"__ref":"Tag:mobile-app-development"}],"isNewsletter":false,"statusForCollection":"APPROVED","pendingCollection":null,"detectedLanguage":"en","wordCount":2160,"layerCake":6,"responsesLocked":false}}</script><script>window.__MIDDLEWARE_STATE__={"session":{"xsrf":""},"cache":{"cacheStatus":"HIT"}}</script><script src="https://cdn-client.medium.com/lite/static/js/manifest.48bdf878.js"></script><script src="https://cdn-client.medium.com/lite/static/js/9865.1496d74a.js"></script><script src="https://cdn-client.medium.com/lite/static/js/main.872afbe3.js"></script><script src="https://cdn-client.medium.com/lite/static/js/instrumentation.d9108df7.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/reporting.ff22a7a5.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/9120.5df29668.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/5049.d1ead72d.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/4810.6318add7.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/6618.db187378.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/2707.a4e221ac.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/9977.933c1c9a.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/8599.73cb8339.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/5250.9f9e01d2.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/9898.d9e26c5e.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/2648.26563adf.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/8393.826a25fb.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/4863.28ab43f6.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/6589.247b1d02.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/5642.0f82ef97.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/6546.cd03f950.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/6834.8aa8d357.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/2420.2a5e2d95.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/839.1c286b32.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/7975.60bcefe8.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/2106.0350840b.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/7394.73a57633.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/5794.9e8ff5dd.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/8204.7749bc66.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/4391.59acaed3.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/PostPage.MainContent.2dc8b1c6.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/8414.6565ad5f.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/3974.8d3e0217.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/2527.d5e0c2f5.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/PostResponsesContent.7ad7ca92.chunk.js"></script> <script src="https://cdn-client.medium.com/lite/static/js/responses.editor.5a11f4da.chunk.js"></script><script>window.main();</script><script>(function(){function c(){var b=a.contentDocument||a.contentWindow.document;if(b){var d=b.createElement('script');d.innerHTML="window.__CF$cv$params={r:'8f3d4394db1387ef',t:'MTczNDUwNTEwMS4wMDAwMDA='};var a=document.createElement('script');a.nonce='';a.src='/cdn-cgi/challenge-platform/scripts/jsd/main.js';document.getElementsByTagName('head')[0].appendChild(a);";b.getElementsByTagName('head')[0].appendChild(d)}}if(document.body){var a=document.createElement('iframe');a.height=1;a.width=1;a.style.position='absolute';a.style.top=0;a.style.left=0;a.style.border='none';a.style.visibility='hidden';document.body.appendChild(a);if('loading'!==document.readyState)c();else if(window.addEventListener)document.addEventListener('DOMContentLoaded',c);else{var e=document.onreadystatechange||function(){};document.onreadystatechange=function(b){e(b);'loading'!==document.readyState&&(document.onreadystatechange=e,c())}}}})();</script></body></html>

Pages: 1 2 3 4 5 6 7 8 9 10